/* =========================================================
   Agent IA Sur Mesure --- Design System
   Manrope + Space Mono · Deep blue / blue / light blue
   ========================================================= */

:root{
  /* ink & neutrals (cool, premium) */
  --ink:        #0c1426;
  --ink-2:      #2c3850;
  --body:       #475068;
  --muted:      #717c95;
  --faint:      #9aa3b8;
  --line:       #e7eaf3;
  --line-soft:  #eef1f8;

  /* surfaces */
  --bg:         #ffffff;
  --bg-soft:    #f6f7fb;
  --bg-blue:    #eef3ff;
  --bg-deep:    #0a1430;
  --bg-deep-2:  #0e1c46;

  /* blues */
  --blue-50:    #eef4ff;
  --blue-100:   #dce7ff;
  --blue-300:   #8fb4ff;
  --blue-400:   #60a5fa;
  --blue-500:   #2f6bf3;
  --blue-600:   #2563eb;
  --blue-700:   #1d4ed8;
  --blue-900:   #1e3a8a;

  --grad: linear-gradient(135deg, #2f6bf3 0%, #1e3a8a 100%);
  --grad-soft: linear-gradient(135deg, #f3f7ff 0%, #eaf0ff 100%);

  /* radii */
  --r-sm: 10px;
  --r:    14px;
  --r-lg: 20px;
  --r-xl: 26px;
  --pill: 999px;

  /* shadows (very soft) */
  --sh-xs: 0 1px 2px rgba(12,20,38,.05);
  --sh-sm: 0 1px 3px rgba(12,20,38,.06), 0 1px 2px rgba(12,20,38,.04);
  --sh-md: 0 14px 40px -22px rgba(30,58,138,.30), 0 4px 12px -6px rgba(12,20,38,.06);
  --sh-lg: 0 40px 90px -40px rgba(20,40,110,.42), 0 12px 34px -20px rgba(12,20,38,.12);
  --sh-blue: 0 14px 30px -12px rgba(37,99,235,.45);

  --maxw: 1200px;
  --gut: 24px;

  --font: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'Space Mono', ui-monospace, 'SFMono-Regular', monospace;
}

*{ box-sizing: border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family: var(--font);
  color: var(--ink-2);
  background: var(--bg);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
html, body{ overflow-x:hidden; }
h1,h2,h3,h4{ color: var(--ink); margin:0; line-height:1.08; letter-spacing:-0.02em; font-weight:800; text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }
a{ color: inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background: var(--blue-100); color: var(--blue-900); }

/* WordPress / Elementor reset for AISM pages. Keep the theme accent away
   from the mockup design system. */
.elementor .aism-root,
.elementor .aism-root *{ box-sizing:border-box; }
.elementor .aism-root a,
.header a,
.mega a,
.footer a,
.aism-el-rest-shell a{ color:inherit; }
.elementor .aism-root .btn--primary,
.header .btn--primary{ color:#fff; }
.elementor .aism-root .btn--white,
.header .btn--white,
.mega .btn--white{ color:var(--blue-900); }
.elementor .aism-root .linkarrow,
.elementor .aism-root .megapanel__all,
.elementor .aism-root .crumb a:hover{ color:var(--blue-700); }
.elementor .aism-root button,
body.aism-code-page .aism-root button,
body.aism-article-body button{
  color:var(--ink);
}
.elementor .aism-root .simback,
.elementor .aism-root .wback,
body.aism-code-page .aism-root .simback,
body.aism-code-page .aism-root .wback{
  color:var(--muted);
}
.elementor .aism-root .btn--primary,
.elementor .aism-root .btn--light,
.elementor .aism-root .btn--white,
.elementor .aism-root .btn--ghost,
body.aism-code-page .aism-root .btn--primary,
body.aism-code-page .aism-root .btn--light,
body.aism-code-page .aism-root .btn--white,
body.aism-code-page .aism-root .btn--ghost,
body.aism-article-body .btn--primary,
body.aism-article-body .btn--light,
body.aism-article-body .btn--white,
body.aism-article-body .btn--ghost{
  color:inherit;
}
.elementor .aism-root .btn--primary,
body.aism-code-page .aism-root .btn--primary,
body.aism-article-body .btn--primary{
  color:#fff;
}
.elementor .aism-root .btn--white,
body.aism-code-page .aism-root .btn--white,
body.aism-article-body .btn--white{
  color:var(--blue-900);
}

/* The first import used an Elementor HTML widget. Make that wrapper full
   browser-width so the page no longer looks clipped inside Elementor's
   default 1140px content container. */
.elementor .elementor-widget-html:has(.aism-root){
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
}
.elementor .elementor-widget-html:has(.aism-root) > .elementor-widget-container{
  width:100%;
}
.elementor .aism-root{
  width:100%;
  max-width:none;
}
body.aism-code-page .elementor{
  width:100%;
  max-width:none;
}
body.aism-code-page .elementor-section,
body.aism-code-page .elementor-section > .elementor-container,
body.aism-code-page .elementor-column,
body.aism-code-page .elementor-widget-wrap,
body.aism-code-page .elementor-widget,
body.aism-code-page .elementor-widget-container{
  width:100%;
  max-width:none !important;
}
body.aism-code-page .elementor-section,
body.aism-code-page .elementor-section > .elementor-container,
body.aism-code-page .elementor-column-gap-default > .elementor-column > .elementor-element-populated{
  padding:0 !important;
}
body.aism-code-page .elementor-widget-wrap{
  padding:0 !important;
}
body.aism-code-page .elementor-widget-html{
  width:100vw;
  max-width:100vw !important;
  margin-left:calc(50% - 50vw);
}
body.aism-code-page .aism-root,
body.aism-article-body{
  --e-global-color-primary:var(--blue-600);
  --e-global-color-secondary:var(--ink);
  --e-global-color-accent:var(--blue-600);
  --e-global-color-text:var(--ink-2);
}

/* Editable Elementor V2 sections. */
.elementor-section.aism-el-section{
  padding:104px 0;
}
.elementor-section.aism-el-section > .elementor-container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gut);
}
.elementor-section.aism-el-hero{
  position:relative;
  overflow:hidden;
  padding:80px 0 96px;
  background:radial-gradient(120% 130% at 86% -10%, var(--bg-blue) 0%, transparent 55%), #fff;
}
.elementor-section.aism-el-hero::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.55;
  background-image:linear-gradient(var(--line-soft) 1px, transparent 1px), linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(90% 70% at 72% 10%, #000, transparent 72%);
  mask-image:radial-gradient(90% 70% at 72% 10%, #000, transparent 72%);
}
.elementor-section.aism-el-hero > .elementor-container{
  position:relative;
  z-index:1;
  align-items:center;
  gap:56px;
}
.aism-el-hero-copy .elementor-widget-heading .elementor-heading-title{
  font-size:clamp(38px,5.4vw,64px);
  line-height:1.08;
  letter-spacing:-.02em;
}
.aism-el-hero-copy .elementor-widget-text-editor p{
  color:var(--body);
  margin:0;
}
.aism-el-section .elementor-widget{
  margin-bottom:0;
}
.aism-el-section .elementor-widget + .elementor-widget{
  margin-top:18px;
}
.aism-el-trust{
  padding:28px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#fff;
}
.aism-el-trust .elementor-container{
  display:block;
}
.aism-el-head{
  padding-bottom:36px;
}
.aism-el-section-head{
  max-width:720px;
}
.aism-el-center{
  text-align:center;
}
.aism-el-center.aism-el-section-head{
  margin:0 auto;
}
.aism-el-cards{
  padding-top:0;
  padding-bottom:0;
}
.aism-el-cards-follow{
  padding-top:22px;
  padding-bottom:104px;
}
.aism-el-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:26px;
  box-shadow:var(--sh-xs);
  min-height:270px;
  transition:transform .2s ease, box-shadow .25s ease, border-color .2s ease;
}
.aism-el-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--sh-lg);
  border-color:transparent;
}
.aism-el-card .elementor-widget-heading .elementor-heading-title{
  font-size:21px;
}
.aism-el-card .elementor-widget-text-editor p{
  color:var(--body);
  font-size:15px;
  line-height:1.55;
  margin:0;
}
.aism-el-linkbtn .elementor-button{
  padding:0;
  background:transparent;
  color:var(--blue-700);
  box-shadow:none;
  font-size:14.5px;
  font-weight:800;
}
.aism-el-steps-band{
  background:var(--bg-soft);
  border-top:1px solid var(--line);
  border-bottom:0;
}
.aism-el-steps-band + .aism-el-steps-band{
  border-top:0;
}
.aism-el-steps{
  padding-top:0;
  padding-bottom:28px;
}
.aism-el-step{
  text-align:center;
  padding:0 12px;
}
.aism-el-step .step__num{
  margin:0 auto 18px;
}
.aism-el-step .elementor-heading-title{
  font-size:18px;
}
.aism-el-step .elementor-widget-text-editor p{
  color:var(--body);
  font-size:14.5px;
  line-height:1.55;
}
.aism-el-steps-cta{
  padding-top:0;
}
.aism-el-center-btn{
  display:inline-flex;
}
.aism-el-data{
  background:var(--bg-deep);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.aism-el-data .elementor-heading-title{
  color:#fff;
}
.aism-el-data .elementor-widget-text-editor p{
  color:#aebbd8;
}
.aism-el-data .flow{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-xl);
  padding:24px;
}
.elementor-section.aism-el-rest-shell{
  padding:0;
}
.elementor-section.aism-el-rest-shell > .elementor-container{
  max-width:none;
  width:100%;
  padding:0;
}
.aism-el-rest-shell .elementor-column,
.aism-el-rest-shell .elementor-widget-html,
.aism-el-rest-shell .elementor-widget-container{
  width:100%;
}
@media (max-width:1080px){
  .elementor-section.aism-el-hero > .elementor-container{
    flex-direction:column;
    align-items:stretch;
  }
}
@media (max-width:900px){
  .elementor-section.aism-el-cards > .elementor-container,
  .elementor-section.aism-el-steps > .elementor-container,
  .elementor-section.aism-el-data > .elementor-container{
    flex-direction:column;
  }
  .aism-el-card,
  .aism-el-step{
    width:100%;
  }
}

.container{ width:100%; max-width: var(--maxw); margin:0 auto; padding:0 var(--gut); }
.section{ padding: 104px 0; }
.section--tight{ padding: 76px 0; }

/* ---------- shared bits ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--mono);
  font-size:12.5px; letter-spacing:.12em; text-transform:uppercase;
  color: var(--blue-700); font-weight:700;
}
.eyebrow::before{
  content:""; width:7px; height:7px; border-radius:50%;
  background: var(--blue-600); box-shadow:0 0 0 4px var(--blue-50);
}
.eyebrow--light{ color: var(--blue-300); }
.eyebrow--light::before{ background: var(--blue-400); box-shadow:0 0 0 4px rgba(96,165,250,.18); }

.h-sec{ font-size: clamp(30px, 4vw, 46px); }
.h-hero{ font-size: clamp(38px, 5.4vw, 64px); }
.lead{ font-size: clamp(17px,1.4vw,20px); color: var(--body); line-height:1.55; }

.sec-head{ max-width: 720px; }
.sec-head .lead{ margin-top:18px; }
.sec-head--center{ margin:0 auto; text-align:center; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-weight:700; font-size:15.5px; letter-spacing:-0.01em;
  padding:14px 22px; border-radius: var(--pill);
  border:1px solid transparent; white-space:nowrap;
  transition: transform .18s ease, box-shadow .25s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.btn svg{ width:18px; height:18px; flex:none; }
.btn--primary{
  background: var(--grad); color:#fff; box-shadow: var(--sh-blue);
}
.btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 18px 36px -12px rgba(37,99,235,.55); color:#fff; }
.header__cta .btn--primary{ padding:12px 18px; font-size:14.5px; }
.btn--ghost{
  background:#fff; color: var(--ink); border-color: var(--line);
  box-shadow: var(--sh-xs);
}
.btn--ghost:hover{ background:#fff; border-color: var(--blue-300); color: var(--blue-700); transform: translateY(-2px); box-shadow: var(--sh-sm); }
.btn--light{
  background: #dce7ff; color:var(--blue-900); border-color: rgba(255,255,255,.62);
  box-shadow:0 10px 26px -18px rgba(255,255,255,.38);
}
.btn--light:hover{ background:#fff; color:var(--blue-900); transform: translateY(-2px); box-shadow:var(--sh-md); }
.btn--white{ background:#fff; color: var(--blue-900); }
.btn--white:hover{ color:var(--blue-900); transform: translateY(-2px); box-shadow: var(--sh-lg); }

.btn--lg{ padding:16px 28px; font-size:16.5px; }
.btn--block{ width:100%; }
.linkarrow{
  display:inline-flex; align-items:center; gap:6px;
  font-weight:700; font-size:14.5px; color: var(--blue-700);
}

.linkarrow svg{ width:15px; height:15px; transition: transform .2s ease; }
.linkarrow:hover svg{ transform: translateX(3px); }
.header{
  position: sticky; top:0; z-index:60;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(16px) saturate(160%);
  border-bottom:1px solid transparent;
  transition: border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.header.is-stuck{ border-color: var(--line); box-shadow: 0 8px 30px -22px rgba(12,20,38,.35); }
.header__inner{ display:flex; align-items:center; gap:16px; height:74px; position:relative; }
.brand{ display:flex; align-items:center; gap:11px; font-weight:800; color:var(--ink); letter-spacing:-0.02em; font-size:17px; white-space:nowrap; }
.brand__mark{ width:34px; height:34px; flex:none; }
.brand small{ display:block; font-family:var(--mono); font-size:9.5px; letter-spacing:.18em; color:var(--muted); font-weight:700; text-transform:uppercase; margin-top:1px; }
.nav{ display:flex; align-items:center; gap:1px; margin-left:0; position:absolute; left:50%; transform:translateX(-50%); }
.nav a{
  padding:9px 11px; border-radius:10px; font-size:14px; font-weight:600; color:var(--body); white-space:nowrap; letter-spacing:-0.01em;
  transition: color .18s ease, background .18s ease;
}
.nav a:hover{ color: var(--ink); background: var(--bg-soft); }
.header__cta{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.header__sec{ font-size:13.5px; font-weight:600; color:var(--body); white-space:nowrap; }
.header__sec:hover{ color: var(--blue-700); }
.burger{ display:none; width:42px; height:42px; border-radius:11px; border:1px solid var(--line); background:#fff; align-items:center; justify-content:center; }
.burger svg{ width:20px; height:20px; }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:80; display:none; }
.drawer.open{ display:block; }
.drawer__scrim{ position:absolute; inset:0; background:rgba(8,14,30,.4); backdrop-filter:blur(2px); }
.drawer__panel{
  position:absolute; top:0; right:0; bottom:0; width:min(86vw,360px);
  background:#fff; padding:22px; box-shadow: var(--sh-lg);
  display:flex; flex-direction:column; gap:6px; transform:translateX(100%); transition:transform .3s ease;
}
.drawer.open .drawer__panel{ transform:translateX(0); }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.drawer__panel a.dlink{ padding:13px 12px; border-radius:11px; font-weight:600; color:var(--ink-2); }
.drawer__panel a.dlink:hover{ background:var(--bg-soft); }
.drawer__panel .btn{ margin-top:14px; }
.iconbtn{ width:40px; height:40px; border-radius:11px; border:1px solid var(--line); background:#fff; display:flex; align-items:center; justify-content:center; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; overflow:hidden; padding-top:64px; padding-bottom:96px; }
.hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero__bg::before{
  content:""; position:absolute; top:-220px; right:-160px; width:720px; height:720px;
  background: radial-gradient(closest-side, rgba(47,107,243,.16), rgba(47,107,243,0));
}
.hero__bg::after{
  content:""; position:absolute; bottom:-260px; left:-180px; width:640px; height:640px;
  background: radial-gradient(closest-side, rgba(96,165,250,.12), rgba(96,165,250,0));
}
.grid-overlay{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(12,20,38,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,20,38,.035) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(120% 90% at 70% 0%, #000 0%, transparent 65%);
          mask-image: radial-gradient(120% 90% at 70% 0%, #000 0%, transparent 65%);
}
.hero__inner{ position:relative; z-index:1; display:grid; grid-template-columns: 1.02fr 1fr; gap:56px; align-items:center; }
.hero__copy{ max-width:560px; }
.hero h1{ margin-top:22px; }
.hero h1 .grad{
  background: var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__sub{ margin-top:22px; font-size: clamp(17px,1.45vw,20px); color:var(--body); line-height:1.55; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:13px; margin-top:32px; }
.hero__assure{ display:flex; flex-wrap:wrap; align-items:center; gap:8px 16px; margin-top:26px; font-size:13.5px; color:var(--muted); font-weight:600; }
.hero__assure span{ display:inline-flex; align-items:center; gap:7px; }
.hero__assure svg{ width:16px; height:16px; color:var(--blue-600); flex:none; }
.dot-sep{ width:4px; height:4px; border-radius:50%; background:var(--faint); }

/* ---- hero SaaS illustration ---- */
.heroviz{ position:relative; }
.heroviz__panel{
  position:relative; background:#fff; border:1px solid var(--line);
  border-radius: var(--r-xl); box-shadow: var(--sh-lg); padding:20px; overflow:hidden;
}
.heroviz__bar{ display:flex; align-items:center; gap:7px; margin-bottom:16px; }
.heroviz__bar i{ width:10px; height:10px; border-radius:50%; background:#e2e6f0; }
.heroviz__bar i:nth-child(1){ background:#dce7ff; }
.heroviz__bar i:nth-child(2){ background:#ffd9a0; }
.heroviz__bar i:nth-child(3){ background:#a9e0bd; }
.heroviz__bar span{ margin-left:8px; font-family:var(--mono); font-size:11px; color:var(--faint); letter-spacing:.04em; }
.heroviz__stage{ position:relative; height:404px; border-radius:var(--r-lg); background:
    radial-gradient(120% 120% at 50% 30%, #f7f9ff 0%, #f1f4fc 100%);
  border:1px solid var(--line-soft); overflow:hidden; }
.heroviz__wires{ position:absolute; inset:0; width:100%; height:100%; z-index:1; }
.heroviz__wires path{ fill:none; stroke:url(#wireGrad); stroke-width:2; stroke-linecap:round;
  stroke-dasharray:7 9; animation: dashflow 1.6s linear infinite; opacity:.85; }
@keyframes dashflow{ to{ stroke-dashoffset:-32; } }

.node{ position:absolute; z-index:2; transform:translate(-50%,-50%); }
.tool{
  display:flex; align-items:center; gap:9px; background:#fff; border:1px solid var(--line);
  border-radius:var(--pill); padding:8px 13px 8px 8px; box-shadow:var(--sh-sm); white-space:nowrap;
  animation: floaty 5s ease-in-out infinite;
}
.tool b{ font-size:13px; font-weight:700; color:var(--ink); letter-spacing:-0.01em; }
.tool__ic{ width:26px; height:26px; border-radius:8px; display:grid; place-items:center; color:#fff; font-family:var(--mono); font-weight:700; font-size:12px; flex:none; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }

.core{
  width:118px; height:118px; border-radius:26px; background:var(--grad); color:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; text-align:center;
  box-shadow: 0 22px 50px -18px rgba(30,58,138,.7); border:1px solid rgba(255,255,255,.25);
}
.core span{ font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; opacity:.85; }
.core b{ font-size:15px; line-height:1.15; padding:0 8px; }
.core__pulse{ position:absolute; inset:-1px; border-radius:26px; box-shadow:0 0 0 0 rgba(47,107,243,.5); animation: pulse 2.6s ease-out infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(47,107,243,.45);} 100%{ box-shadow:0 0 0 26px rgba(47,107,243,0);} }

.reco{
  position:absolute; left:50%; bottom:16px; transform:translateX(-50%); z-index:3;
  width: calc(100% - 36px); background:#fff; border:1px solid var(--line); border-radius:16px;
  box-shadow: var(--sh-md); padding:13px 15px; display:flex; align-items:center; gap:13px;
  animation: rise 0.7s cubic-bezier(.2,.7,.2,1) both; animation-delay:.4s;
}
@keyframes rise{ from{ opacity:0; transform:translate(-50%,16px);} to{ opacity:1; transform:translate(-50%,0);} }
.reco__badge{ width:42px; height:42px; border-radius:12px; background:var(--blue-50); color:var(--blue-700); display:grid; place-items:center; flex:none; }
.reco__badge svg{ width:22px; height:22px; }
.reco__t{ font-size:11px; font-family:var(--mono); letter-spacing:.08em; color:var(--blue-600); text-transform:uppercase; }
.reco__n{ font-size:15px; font-weight:800; color:var(--ink); margin-top:1px; }
.reco__meta{ font-size:12.5px; color:var(--muted); }
.reco__match{ margin-left:auto; text-align:right; flex:none; }
.reco__pct{ font-size:19px; font-weight:800; color:var(--blue-700); }
.reco__pl{ font-size:10.5px; color:var(--muted); font-family:var(--mono); }

/* =========================================================
   TRUST STRIP
   ========================================================= */
.trust{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-soft); }
.trust__inner{ padding:30px 0; }
.trust__label{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); font-weight:700; text-align:center; margin-bottom:20px; }
.chips{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.chip{
  display:inline-flex; align-items:center; gap:9px; background:#fff; border:1px solid var(--line);
  border-radius:var(--pill); padding:10px 17px 10px 12px; font-size:14.5px; font-weight:600; color:var(--ink-2);
  box-shadow: var(--sh-xs); transition: transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}
.chip:hover{ transform:translateY(-2px); border-color:var(--blue-300); box-shadow:var(--sh-sm); }
.chip__ic{ width:24px; height:24px; border-radius:7px; background:var(--blue-50); color:var(--blue-700); display:grid; place-items:center; flex:none; }
.chip__ic svg{ width:15px; height:15px; }

/* =========================================================
   SOLUTION CARDS
   ========================================================= */
.cards-6{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:52px; }
.scard{
  position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px; transition: transform .2s ease, box-shadow .25s ease, border-color .2s ease;
  display:flex; flex-direction:column; overflow:hidden;
}
.scard::after{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(135deg, rgba(47,107,243,.5), transparent 45%); opacity:0;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; transition:opacity .25s ease; }
.scard:hover{ transform:translateY(-4px); box-shadow:var(--sh-md); border-color:transparent; }
.scard:hover::after{ opacity:1; }
.scard__ic{ width:50px; height:50px; border-radius:14px; background:var(--grad-soft); border:1px solid var(--blue-100); color:var(--blue-700); display:grid; place-items:center; margin-bottom:18px; }
.scard__ic svg{ width:24px; height:24px; }
.scard h3{ font-size:19px; }
.scard p{ margin-top:9px; color:var(--body); font-size:15px; line-height:1.55; flex:1; }
.scard .linkarrow{ margin-top:18px; }

/* =========================================================
   HOW IT WORKS
   ========================================================= */
.steps{ position:relative; margin-top:56px; }
.steps__line{ position:absolute; top:38px; left:8%; right:8%; height:2px; background:linear-gradient(90deg,var(--blue-200,#cfe0ff),var(--blue-300)); z-index:0; }
.steps__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; z-index:1; }
.step{ text-align:center; }
.step__num{
  width:76px; height:76px; margin:0 auto 20px; border-radius:22px; background:#fff; border:1px solid var(--line);
  box-shadow:var(--sh-sm); display:grid; place-items:center; position:relative;
}
.step__num span{ font-family:var(--mono); font-weight:700; font-size:22px; color:var(--blue-700); }
.step__num::before{ content:""; position:absolute; inset:-1px; border-radius:22px; border:2px solid transparent; }
.step.is-on .step__num{ background:var(--grad); box-shadow:var(--sh-blue); }
.step.is-on .step__num span{ color:#fff; }
.step h3{ font-size:18px; }
.step p{ margin-top:9px; color:var(--body); font-size:14.5px; padding:0 6px; }
.steps__cta{ text-align:center; margin-top:48px; }

/* =========================================================
   DATA / MEMORY (dark contrasted section)
   ========================================================= */
.data{ background:
    radial-gradient(120% 120% at 85% 0%, #122a66 0%, transparent 55%),
    radial-gradient(90% 90% at 0% 100%, #16205a 0%, transparent 55%),
    var(--bg-deep);
  color:#dfe6f6; position:relative; overflow:hidden; }
.data .grid-overlay{ -webkit-mask-image:radial-gradient(120% 100% at 50% 0%, #000, transparent 70%); mask-image:radial-gradient(120% 100% at 50% 0%, #000, transparent 70%); opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px); }
.data__inner{ position:relative; z-index:1; display:grid; grid-template-columns: 1fr 1.05fr; gap:64px; align-items:center; }
.data h2{ color:#fff; }
.data__lead{ margin-top:20px; font-size:18px; color:#aebbd8; line-height:1.6; max-width:440px; }
.benefits{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.benefit{ display:flex; align-items:center; gap:13px; font-size:15.5px; color:#d4ddf2; font-weight:600; }
.benefit svg{ width:20px; height:20px; color:var(--blue-400); flex:none; }
.data .btn{ margin-top:34px; }

/* flow diagram */
.flow{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-xl); padding:26px; backdrop-filter:blur(4px); }
.flow__row{ display:flex; align-items:center; gap:11px; }
.flow__sources{ display:flex; flex-direction:column; gap:9px; }
.fsrc{ display:flex; align-items:center; gap:9px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:11px; padding:9px 12px; font-size:13px; font-weight:600; color:#e8eefb; }
.fsrc .tool__ic{ width:22px; height:22px; font-size:10px; border-radius:6px; }
.flow__arrow{ color:var(--blue-400); flex:none; display:grid; place-items:center; }
.flow__arrow svg{ width:22px; height:22px; }
.flow__stage{ flex:1; display:flex; flex-direction:column; gap:12px; }
.fcap{
  background:linear-gradient(135deg, rgba(47,107,243,.22), rgba(30,58,138,.18));
  border:1px solid rgba(143,180,255,.32); border-radius:13px; padding:13px 15px; color:#fff;
}
.fcap--solid{ background:var(--grad); border-color:rgba(255,255,255,.25); }
.fcap__k{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-300); }
.fcap--solid .fcap__k{ color:rgba(255,255,255,.8); }
.fcap__v{ font-size:14.5px; font-weight:700; margin-top:2px; }

/* =========================================================
   WHY US
   ========================================================= */
.why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:52px; }
.why{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:26px; transition:transform .2s ease, box-shadow .25s ease; }
.why:hover{ transform:translateY(-4px); box-shadow:var(--sh-md); }
.why__ic{ width:46px; height:46px; border-radius:13px; background:var(--blue-50); color:var(--blue-700); display:grid; place-items:center; margin-bottom:18px; }
.why__ic svg{ width:23px; height:23px; }
.why h3{ font-size:17.5px; }
.why p{ margin-top:9px; font-size:14.5px; color:var(--body); }

/* =========================================================
   SIMULATOR FORM
   ========================================================= */
.simwrap{ background:
    radial-gradient(110% 120% at 100% 0%, var(--bg-blue) 0%, transparent 50%),
    var(--bg-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.sim{ display:grid; grid-template-columns: 0.92fr 1.08fr; gap:56px; align-items:center; }
.sim__copy .lead{ margin-top:18px; }
.sim__assure{ margin-top:24px; display:inline-flex; align-items:center; gap:9px; background:#fff; border:1px solid var(--line); border-radius:var(--pill); padding:9px 16px; font-size:13.5px; font-weight:600; color:var(--ink-2); box-shadow:var(--sh-xs); }
.sim__assure svg{ width:16px; height:16px; color:var(--blue-600); }

.simcard{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--sh-lg); padding:30px; }
.simcard__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.simcard__step{ font-family:var(--mono); font-size:12px; color:var(--muted); letter-spacing:.04em; }
.simcard__step b{ color:var(--blue-700); }
.progress{ height:7px; border-radius:var(--pill); background:var(--line); overflow:hidden; margin-bottom:24px; }
.progress__bar{ height:100%; border-radius:inherit; background:var(--grad); width:25%; transition:width .45s cubic-bezier(.2,.7,.2,1); }
.simcard h3{ font-size:21px; }
.simcard__hint{ margin-top:7px; font-size:14px; color:var(--muted); }
.opts{ margin-top:20px; display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.opt{
  display:flex; align-items:center; gap:12px; text-align:left; width:100%;
  background:#fff; border:1.5px solid var(--line); border-radius:var(--r); padding:14px 15px;
  transition: border-color .18s ease, background .18s ease, transform .15s ease; color:var(--ink);
}
.opt:hover{ border-color:var(--blue-300); transform:translateY(-1px); }
.opt.sel{ border-color:var(--blue-600); background:var(--blue-50); }
.opt__check{ width:22px; height:22px; border-radius:50%; border:2px solid var(--line); flex:none; display:grid; place-items:center; transition:.18s; }
.opt.sel .opt__check{ border-color:var(--blue-600); background:var(--blue-600); }
.opt__check svg{ width:13px; height:13px; color:#fff; opacity:0; transition:.18s; }
.opt.sel .opt__check svg{ opacity:1; }
.opt b{ font-size:14.5px; font-weight:600; line-height:1.25; }
.simcard__foot{ margin-top:24px; display:flex; align-items:center; gap:12px; }
.simcard__foot .btn{ flex:1; }
.simback{ background:transparent; border:none; color:var(--muted); font-weight:600; font-size:14px; padding:10px; display:none; }
.simback.show{ display:inline-flex; align-items:center; gap:6px; }
.simback svg{ width:16px; height:16px; }
.simcard__assure{ margin-top:16px; text-align:center; font-size:12.5px; color:var(--muted); }

/* final sim state */
.simdone{ text-align:center; padding:18px 6px; }
.simdone__ic{ width:64px; height:64px; margin:0 auto 18px; border-radius:50%; background:var(--blue-50); color:var(--blue-700); display:grid; place-items:center; }
.simdone__ic svg{ width:32px; height:32px; }

/* =========================================================
   EXAMPLES
   ========================================================= */
.ex-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:52px; }
.excard{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:transform .2s ease, box-shadow .25s ease; display:flex; flex-direction:column; }
.excard:hover{ transform:translateY(-4px); box-shadow:var(--sh-md); }
.excard__head{ padding:22px 24px; border-bottom:1px dashed var(--line); display:flex; align-items:center; gap:13px; }
.excard__tag{ width:46px; height:46px; border-radius:13px; background:var(--grad-soft); border:1px solid var(--blue-100); color:var(--blue-700); display:grid; place-items:center; flex:none; }
.excard__tag svg{ width:23px; height:23px; }
.excard__head h3{ font-size:18px; }
.excard__kicker{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:2px; }
.excard__body{ padding:6px 24px 24px; }
.exrow{ padding:15px 0; border-bottom:1px solid var(--line-soft); }
.exrow:last-child{ border-bottom:none; padding-bottom:2px; }
.exrow__k{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--blue-700); font-weight:700; }
.exrow__v{ margin-top:5px; font-size:14.5px; color:var(--ink-2); line-height:1.5; }

/* =========================================================
   RESOURCES
   ========================================================= */
.res-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.res-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
.acard{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:transform .2s ease, box-shadow .25s ease; }
.acard:hover{ transform:translateY(-4px); box-shadow:var(--sh-md); }
.acard__img{ height:158px; position:relative; overflow:hidden; background:var(--grad-soft); border-bottom:1px solid var(--line); }
.acard__img svg{ position:absolute; inset:0; width:100%; height:100%; }
.acard__cat{ position:absolute; left:14px; top:14px; font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; background:rgba(255,255,255,.9); border:1px solid var(--line); border-radius:var(--pill); padding:5px 11px; color:var(--blue-700); font-weight:700; }
.acard__body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.acard h3{ font-size:18px; line-height:1.28; }
.acard__meta{ margin-top:auto; padding-top:18px; display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); font-family:var(--mono); }
.acard .linkarrow{ margin-top:16px; }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ max-width:840px; margin:48px auto 0; }
.qa{ border-bottom:1px solid var(--line); }
.qa__q{ width:100%; background:none; border:none; display:flex; align-items:center; gap:18px; text-align:left; padding:24px 4px; font-size:18px; font-weight:700; color:var(--ink); }
.qa__q:hover{ color:var(--blue-700); }
.qa__sign{ margin-left:auto; width:30px; height:30px; flex:none; border-radius:9px; border:1px solid var(--line); display:grid; place-items:center; color:var(--blue-700); transition:.25s; }
.qa__sign svg{ width:16px; height:16px; transition:transform .3s ease; }
.qa.open .qa__sign{ background:var(--blue-600); border-color:var(--blue-600); color:#fff; }
.qa.open .qa__sign svg{ transform:rotate(45deg); }
.qa__a{ overflow:hidden; max-height:0; transition:max-height .35s ease; }
.qa__a p{ padding:0 50px 24px 4px; color:var(--body); font-size:15.5px; line-height:1.62; }

/* =========================================================
   FINAL CTA
   ========================================================= */
.cta{ padding:104px 0; }
.cta__card{
  position:relative; overflow:hidden; border-radius:var(--r-xl);
  background:
    radial-gradient(110% 130% at 88% 5%, #2f6bf3 0%, transparent 52%),
    radial-gradient(90% 120% at 0% 100%, #1e3a8a 0%, transparent 52%),
    var(--bg-deep);
  padding:72px 64px; text-align:center; box-shadow:var(--sh-lg);
}
.cta__card .grid-overlay{ opacity:.4; background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  -webkit-mask-image:radial-gradient(100% 100% at 50% 0%, #000, transparent 75%); mask-image:radial-gradient(100% 100% at 50% 0%, #000, transparent 75%); }
.cta__inner{ position:relative; z-index:1; max-width:680px; margin:0 auto; }
.cta h2{ color:#fff; font-size:clamp(28px,3.6vw,42px); }
.cta p{ margin-top:18px; color:#b9c6e6; font-size:18px; }
.cta__actions{ margin-top:34px; display:flex; justify-content:center; gap:13px; flex-wrap:wrap; }
.cta__assure{ margin-top:22px; font-size:13.5px; color:#8fa0c8; font-family:var(--mono); letter-spacing:.02em; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--bg-deep); color:#9fadcc; padding:72px 0 34px; }
.footer__top{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap:40px; }
.footer .brand{ color:#fff; }
.footer .brand small{ color:#7286ad; }
.footer__about{ margin-top:18px; font-size:14px; line-height:1.6; color:#8c9bbd; max-width:300px; }
.footer__provider{
  margin-top:24px;
  max-width:330px;
  padding:18px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r);
  background:rgba(255,255,255,.05);
}
.footer__provider h4{
  color:#fff;
  font-size:16px;
  margin:0;
  letter-spacing:0;
}
.footer__provider p{
  margin-top:9px;
  color:#9fadcc;
  font-size:13.5px;
  line-height:1.55;
}
.footer__provider .btn{
  margin-top:16px;
  padding:11px 16px;
  font-size:14px;
}
.footer__col h4{ color:#fff; font-size:13px; font-family:var(--mono); letter-spacing:.06em; text-transform:uppercase; font-weight:700; margin-bottom:18px; }
.footer__col a{ display:block; padding:7px 0; font-size:14.5px; color:#9fadcc; transition:color .18s ease; }
.footer__col a:hover{ color:#fff; }
.footer__bottom{ margin-top:52px; padding-top:26px; border-top:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer__bottom small{ font-size:13px; color:#7286ad; }
.footer__disc{ margin-top:18px; font-size:12.5px; color:#6f80a6; line-height:1.6; max-width:760px; }

/* =========================================================
   REVEAL ANIMATION (progressive enhancement only)
   Base state is VISIBLE. Hiding is enabled only when JS adds
   .rv to <html> AND a probe confirms transitions actually run,
   so content never gets stuck hidden in frozen/preview contexts.
   ========================================================= */
@media (prefers-reduced-motion: no-preference){
  html.rv .reveal{ opacity:0; transform:translateY(22px);
    transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
  html.rv .reveal.in{ opacity:1; transform:none; }
  html.rv .reveal[data-d="1"]{ transition-delay:.06s; }
  html.rv .reveal[data-d="2"]{ transition-delay:.12s; }
  html.rv .reveal[data-d="3"]{ transition-delay:.18s; }
  html.rv .reveal[data-d="4"]{ transition-delay:.24s; }
  html.rv .reveal[data-d="5"]{ transition-delay:.30s; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1080px){
  .hero__inner{ grid-template-columns:1fr; gap:44px; }
  .heroviz{ max-width:560px; }
  .data__inner{ grid-template-columns:1fr; gap:40px; }
  .sim{ grid-template-columns:1fr; gap:36px; }
  .cards-6{ grid-template-columns:repeat(2,1fr); }
  .why-grid{ grid-template-columns:repeat(2,1fr); }
  .nav, .header__sec{ display:none; }
  .burger{ display:flex; }
}
@media (max-width: 940px){
  .steps__grid{ grid-template-columns:1fr 1fr; gap:34px 20px; }
  .steps__line{ display:none; }
  .ex-grid{ grid-template-columns:1fr; }
  .res-grid{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr 1fr; gap:34px; }
}
@media (max-width: 680px){
  :root{ --gut:16px; }
  body{ font-size:16px; }
  .section{ padding:72px 0; }
  .cta{ padding:64px 0; }
  .cta__card{ padding:48px 24px; }
  .cards-6{ grid-template-columns:1fr; }
  .why-grid{ grid-template-columns:1fr; }
  .steps__grid{ grid-template-columns:1fr; }
  .opts{ grid-template-columns:1fr; }
  .simcard{ padding:24px 20px; }
  .footer__top{ grid-template-columns:1fr; gap:30px; }
  .flow__row{ flex-direction:column; align-items:stretch; }
  .flow__arrow{ transform:rotate(90deg); margin:0 auto; }
  .heroviz__stage{ height:360px; }
  .hero__actions .btn{ flex:1; }
  .qa__a p{ padding-right:8px; }
}
@media (max-width: 420px){
  .header__inner{ gap:8px; height:70px; }
  .brand{ gap:9px; font-size:16px; }
  .brand__mark{ width:32px; height:32px; }
  .header__cta{ gap:8px; }
  .header__cta .btn--primary{ padding:10px 12px; font-size:13px; gap:7px; }
  .header__cta .btn--primary svg{ width:15px; height:15px; }
  .burger{ width:42px; padding:0; justify-content:center; }
  .burger__txt{ display:none; }
  .heroviz__stage{ height:330px; }
  .tool b{ font-size:11.5px; }
}

/* WordPress/Elementor final guard: the theme accent must never leak into
   AISM links, buttons or form controls, including hover/focus states. */
.aism-root a:hover,
.aism-root a:focus,
.aism-root button:hover,
.aism-root button:focus,
.aism-root input:focus,
.aism-root textarea:focus,
.aism-root select:focus,
body.aism-article-body a:hover,
body.aism-article-body a:focus,
body.aism-article-body button:hover,
body.aism-article-body button:focus{
  --e-global-color-accent:var(--blue-600);
  border-color:var(--blue-300);
  outline-color:var(--blue-300);
}
.aism-root,
.aism-root *,
body.aism-article-body,
body.aism-article-body *{
  --e-global-color-accent:var(--blue-600);
  accent-color:var(--blue-600);
}
.aism-root button,
.aism-root button:hover,
.aism-root button:focus,
.aism-root .qa__q,
.aism-root .qa__q:hover,
body.aism-article-body button,
body.aism-article-body button:hover,
body.aism-article-body button:focus{
  color:var(--ink) !important;
}
.aism-root button:not(.btn),
.aism-root button:not(.btn):hover,
.aism-root button:not(.btn):focus,
body.aism-article-body button:not(.btn),
body.aism-article-body button:not(.btn):hover,
body.aism-article-body button:not(.btn):focus{
  border-color:transparent !important;
  box-shadow:none;
}
.aism-root .opt,
.aism-root .choice{
  background:#fff !important;
  color:var(--ink) !important;
  border-color:var(--line) !important;
}
.aism-root .opt:hover,
.aism-root .choice:hover{
  background:#fff !important;
  color:var(--ink) !important;
  border-color:var(--blue-300) !important;
}
.aism-root .opt:hover b,
.aism-root .opt:hover span,
.aism-root .choice:hover b,
.aism-root .choice:hover small{
  color:inherit;
}
.aism-root .opt.sel,
.aism-root .choice.sel{
  background:var(--blue-50) !important;
  border-color:var(--blue-600) !important;
}
.aism-root .qa__q,
.aism-root .qa__q:hover,
.aism-root .qa__q:focus{
  border:0 !important;
  border-color:transparent !important;
}
.aism-root .qa__sign{
  border-color:var(--line) !important;
}
.aism-root .qa.open .qa__sign{
  border-color:var(--blue-600) !important;
}
.aism-seo-faq .qa__q:hover{
  background:var(--bg-soft) !important;
  color:var(--blue-700) !important;
}
body .aism-root .faq .qa .qa__q,
body .aism-root .faq .qa .qa__q:hover,
body .aism-root .faq .qa .qa__q:focus,
body.aism-article-body .faq .qa .qa__q,
body.aism-article-body .faq .qa .qa__q:hover,
body.aism-article-body .faq .qa .qa__q:focus{
  color:var(--ink) !important;
  background:transparent !important;
  border-color:transparent !important;
  outline-color:var(--blue-300) !important;
  box-shadow:none !important;
}
body .aism-root .faq .qa .qa__q:hover,
body .aism-root .faq .qa .qa__q:focus,
body.aism-article-body .faq .qa .qa__q:hover,
body.aism-article-body .faq .qa .qa__q:focus{
  color:var(--blue-700) !important;
  background:var(--blue-50) !important;
}
body .aism-root .faq .qa .qa__q:hover *,
body .aism-root .faq .qa .qa__q:focus *,
body.aism-article-body .faq .qa .qa__q:hover *,
body.aism-article-body .faq .qa .qa__q:focus *{
  color:inherit !important;
  stroke:currentColor !important;
}
body .aism-root .faq .qa .qa__sign,
body.aism-article-body .faq .qa .qa__sign{
  background:var(--blue-50) !important;
  border-color:var(--blue-100) !important;
  color:var(--blue-700) !important;
}
body .aism-root .faq .qa.open .qa__sign,
body.aism-article-body .faq .qa.open .qa__sign{
  background:var(--blue-600) !important;
  border-color:var(--blue-600) !important;
  color:#fff !important;
}
.aism-root .simback,
.aism-root .wback,
.aism-root .simback:hover,
.aism-root .wback:hover,
.aism-root .simback:focus,
.aism-root .wback:focus{
  color:var(--muted) !important;
  border-color:transparent !important;
  background:transparent !important;
}
.aism-root .btn,
.aism-root .btn:hover,
.aism-root .btn:focus,
body.aism-article-body .btn,
body.aism-article-body .btn:hover,
body.aism-article-body .btn:focus{
  text-decoration:none;
}
.aism-root .btn--primary,
.aism-root .btn--primary:hover,
.aism-root .btn--primary:focus,
body.aism-article-body .btn--primary,
body.aism-article-body .btn--primary:hover,
body.aism-article-body .btn--primary:focus{
  background:var(--grad) !important;
  color:#fff !important;
  border-color:transparent !important;
}
.aism-root .btn--ghost,
.aism-root .btn--ghost:hover,
.aism-root .btn--ghost:focus,
body.aism-article-body .btn--ghost,
body.aism-article-body .btn--ghost:hover,
body.aism-article-body .btn--ghost:focus{
  background:#fff !important;
  color:var(--blue-700) !important;
  border-color:var(--blue-300) !important;
}
.aism-root .btn--white,
.aism-root .btn--white:hover,
.aism-root .btn--white:focus,
body.aism-article-body .btn--white,
body.aism-article-body .btn--white:hover,
body.aism-article-body .btn--white:focus,
.aism-root .btn--light,
.aism-root .btn--light:hover,
.aism-root .btn--light:focus,
body.aism-article-body .btn--light,
body.aism-article-body .btn--light:hover,
body.aism-article-body .btn--light:focus{
  background:#fff !important;
  color:var(--blue-900) !important;
  border-color:rgba(255,255,255,.72) !important;
}
.aism-root .btn--light:hover,
body.aism-article-body .btn--light:hover{
  box-shadow:0 16px 34px -20px rgba(37,99,235,.42) !important;
}
