/* =========================================================================
   Garuda — Aurora design system
   Dark canvas · animated aurora gradients · purple/cyan/pink/emerald accents
   ========================================================================= */
:root{
  --bg:#05060a;
  --bg-soft:#0a0c14;
  --ink:#eef0f8;
  --ink-dim:rgba(238,240,248,.72);
  --ink-faint:rgba(238,240,248,.56);
  --purple:#a855f7;
  --purple-300:#d8b4fe;
  --cyan:#22d3ee;
  --pink:#ec4899;
  --emerald:#34d399;
  --amber:#fbbf24;
  --card:#0b0d15;
  --line:rgba(238,240,248,.09);
  --line-strong:rgba(238,240,248,.16);
  --s2:1rem; --s3:1.5rem; --s4:2.5rem; --s5:4.5rem; --s6:7.5rem;
  --maxw:1160px;
  --maxw-prose:720px;
  /* ---- motion system ---- */
  --ease:cubic-bezier(.22,1,.36,1);      /* primary easing */
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur-micro:.18s;                       /* taps, toggles */
  --dur-hover:.3s;                        /* hover states */
  --dur-reveal:.6s;                       /* section reveals */
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:'Space Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--ink);
  line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:rgba(168,85,247,.4)}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img,svg{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem)}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--purple);color:#fff;
  padding:.7rem 1.2rem;border-radius:0 0 10px 0}
.skip-link:focus{left:0}
/* Visually hidden, but available to assistive tech (e.g. section headings for screen readers). */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- grain ---------- */
body::after{
  content:"";position:fixed;inset:0;z-index:90;pointer-events:none;opacity:.055;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- aurora fields ---------- */
.aurora-field{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.aurora{position:absolute;border-radius:50%;filter:blur(95px);opacity:.55;will-change:transform}
.au-1{width:70vw;height:60vh;min-width:560px;top:-22%;left:-12%;
  background:radial-gradient(ellipse at center,rgba(124,58,237,.75),transparent 65%);
  animation:au-drift1 22s ease-in-out infinite alternate}
.au-2{width:60vw;height:55vh;min-width:500px;top:-8%;right:-18%;
  background:radial-gradient(ellipse at center,rgba(34,211,238,.55),transparent 65%);
  animation:au-drift2 26s ease-in-out infinite alternate}
.au-3{width:55vw;height:50vh;min-width:440px;top:30%;left:18%;
  background:radial-gradient(ellipse at center,rgba(236,72,153,.4),transparent 65%);
  animation:au-drift3 30s ease-in-out infinite alternate}
@keyframes au-drift1{to{transform:translate(12vw,9vh) rotate(18deg) scale(1.15)}}
@keyframes au-drift2{to{transform:translate(-10vw,11vh) rotate(-14deg) scale(1.1)}}
@keyframes au-drift3{to{transform:translate(-8vw,-10vh) rotate(10deg) scale(1.2)}}

/* ---------- gradient text ---------- */
.grad-text{
  background:linear-gradient(90deg,var(--purple),var(--cyan),var(--pink),var(--purple));
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:grad-shift 9s linear infinite;
}
@keyframes grad-shift{to{background-position:300% 0}}
/* Forced-colors / Windows High Contrast: gradient-clipped text would render
   invisible (transparent fill, no painted background) — restore a solid colour. */
@media (forced-colors: active){.grad-text{-webkit-text-fill-color:currentColor;color:CanvasText;background:none;animation:none}}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:inherit;font-weight:600;font-size:.95rem;
  padding:.9rem 1.7rem;border-radius:12px;border:0;cursor:pointer;line-height:1;
  transition:transform var(--dur-hover) var(--ease),box-shadow var(--dur-hover) var(--ease),background var(--dur-hover) var(--ease)}
.btn svg{transition:transform var(--dur-hover) var(--ease)}
.btn-glow{background:linear-gradient(95deg,#7c3aed,#0ea5e9);color:#fff;position:relative;overflow:hidden;
  box-shadow:0 0 26px rgba(124,58,237,.5),0 4px 18px rgba(14,165,233,.3)}
.btn-glow:hover{transform:translateY(-2px);box-shadow:0 0 44px rgba(124,58,237,.75),0 8px 26px rgba(14,165,233,.45)}
/* highlight sweep */
.btn-glow::after{content:"";position:absolute;top:0;left:-75%;width:45%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg);opacity:0}
.btn-glow:hover::after{opacity:1;animation:sheen .85s var(--ease)}
@keyframes sheen{from{left:-75%}to{left:130%}}
.btn-line{background:rgba(238,240,248,.04);color:var(--ink);box-shadow:inset 0 0 0 1px rgba(238,240,248,.18)}
.btn-line:hover{background:rgba(238,240,248,.09);transform:translateY(-2px);
  box-shadow:inset 0 0 0 1px rgba(34,211,238,.55),0 0 22px rgba(34,211,238,.2)}
.btn:hover svg{transform:translateX(3px)}
.btn:active{transform:scale(.97)}
.btn:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--cyan);outline-offset:3px}

/* ---------- gradient border card ---------- */
.gcard{position:relative;isolation:isolate;background:linear-gradient(170deg,rgba(17,19,30,.92),rgba(9,10,17,.92));border-radius:18px}
.gcard::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,rgba(168,85,247,.55),rgba(34,211,238,.18) 40%,rgba(238,240,248,.06) 60%,rgba(236,72,153,.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
  transition:opacity var(--dur-hover) var(--ease);
}
/* cursor-follow spotlight (sits behind card content via z-index:-1) */
.gcard::after{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:-1;opacity:0;pointer-events:none;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(168,85,247,.16),transparent 60%);
  transition:opacity var(--dur-hover) var(--ease);
}
.gcard:hover::after{opacity:1}

/* ---------- nav ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;
  background:transparent;border-bottom:1px solid transparent;
  -webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);
  transition:background .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease),backdrop-filter .4s var(--ease)}
.site-header.scrolled{background:rgba(5,6,10,.62);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);box-shadow:0 8px 30px rgba(0,0,0,.28)}
.nav{max-width:var(--maxw);margin:0 auto;padding:.85rem clamp(1.25rem,4vw,2.5rem);
  display:flex;align-items:center;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.25rem;letter-spacing:-.02em}
.brand-mark{height:32px;width:auto;display:block;flex:none;filter:drop-shadow(0 2px 8px rgba(234,88,12,.28))}
.brand-name{white-space:nowrap}
.site-footer .brand-mark{height:28px}
.nav-links{display:flex;align-items:center;gap:.35rem;margin-left:auto}
.nav-links a{font-size:.92rem;color:var(--ink-dim);padding:.5rem .8rem;border-radius:9px;position:relative;
  transition:color .2s ease}
.nav-links a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.25rem;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--purple),var(--cyan));transform:scaleX(0);transform-origin:left;
  transition:transform .25s ease}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{padding:.62rem 1.25rem;font-size:.88rem}
.menu-cta{display:none;justify-content:center}
.hamburger{display:none;margin-left:auto;width:44px;height:44px;border-radius:10px;border:1px solid var(--line);
  background:rgba(238,240,248,.04);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hamburger span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:880px){
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:rgba(7,8,14,.97);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
    border-bottom:1px solid var(--line);padding:1rem clamp(1.25rem,4vw,2.5rem) 1.5rem;gap:.3rem;
    opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .28s ease,transform .28s ease}
  .nav-links.open{opacity:1;transform:translateY(0);pointer-events:auto}
  .nav-links li{opacity:0;transform:translateY(10px);transition:opacity .32s var(--ease),transform .32s var(--ease)}
  .nav-links.open li{opacity:1;transform:none}
  .nav-links.open li:nth-child(1){transition-delay:.05s}
  .nav-links.open li:nth-child(2){transition-delay:.1s}
  .nav-links.open li:nth-child(3){transition-delay:.15s}
  .nav-links.open li:nth-child(4){transition-delay:.2s}
  .nav-links.open li:nth-child(5){transition-delay:.25s}
  .nav-links.open li:nth-child(6){transition-delay:.3s}
  .nav-links.open li:nth-child(7){transition-delay:.35s}
  .nav-links a{padding:.85rem .5rem;font-size:1.05rem}
  .nav-links a::after{display:none}
  .menu-cta{display:inline-flex;margin-top:.6rem}
  .nav-cta-desk{display:none}
  .hamburger{display:flex}
}

/* ---------- reading progress (blog) ---------- */
.reading-bar{position:fixed;top:0;left:0;height:3px;width:0;z-index:130;
  background:linear-gradient(90deg,var(--purple),var(--cyan),var(--pink));
  box-shadow:0 0 12px rgba(34,211,238,.6);transition:width .1s linear}

/* ---------- hero ---------- */
.hero{position:relative;padding:calc(var(--s6) + 60px) 0 var(--s5);text-align:center}
.hero .wrap{position:relative;z-index:1}
.badge{display:inline-flex;align-items:center;gap:.55rem;font-size:.8rem;font-weight:500;color:var(--ink-dim);
  padding:.5rem 1.1rem;border-radius:999px;background:rgba(238,240,248,.05);
  box-shadow:inset 0 0 0 1px rgba(238,240,248,.12)}
.badge i{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan);
  animation:blink 2.5s ease-in-out infinite}
@keyframes blink{50%{opacity:.4}}
h1{font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.04;letter-spacing:-.035em;font-weight:700;
  margin:1.4rem auto 1.3rem;max-width:18ch}
.hero .lead{font-size:1.15rem;color:var(--ink-dim);max-width:38rem;margin:0 auto var(--s3)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-bottom:var(--s3)}
.trust{font-size:.9rem;color:var(--ink-faint);display:flex;align-items:center;gap:.6rem;justify-content:center}
.trust svg{flex:none}

/* hero floating cards */
.hero-stage{position:relative;max-width:880px;margin:var(--s4) auto 0;min-height:380px;z-index:1}
.ui-card{position:absolute;padding:1.2rem 1.3rem;text-align:left;will-change:transform}
.ui-card h4{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.7rem}
.uc-1{width:min(330px,72vw);left:4%;top:8%;transform:rotate(-5deg);
  box-shadow:0 30px 70px rgba(0,0,0,.6),0 0 50px rgba(168,85,247,.16);animation:hover1 8s ease-in-out infinite}
.uc-2{width:min(300px,68vw);right:5%;top:0;transform:rotate(4deg);
  box-shadow:0 30px 70px rgba(0,0,0,.6),0 0 50px rgba(34,211,238,.15);animation:hover2 9s ease-in-out infinite}
.uc-3{width:min(280px,64vw);left:32%;bottom:2%;transform:rotate(-2deg);z-index:2;
  box-shadow:0 30px 70px rgba(0,0,0,.65),0 0 50px rgba(236,72,153,.16);animation:hover3 10s ease-in-out infinite}
@keyframes hover1{50%{transform:rotate(-5deg) translateY(-14px)}}
@keyframes hover2{50%{transform:rotate(4deg) translateY(-18px)}}
@keyframes hover3{50%{transform:rotate(-2deg) translateY(-10px)}}
.queue-row{display:flex;align-items:center;gap:.7rem;padding:.5rem 0;border-top:1px solid var(--line);font-size:.85rem}
.queue-row:first-of-type{border-top:0}
.queue-row .av{width:30px;height:30px;border-radius:50%;flex:none;background:linear-gradient(135deg,#7c3aed,#22d3ee)}
.queue-row:nth-child(3) .av{background:linear-gradient(135deg,#ec4899,#7c3aed)}
.queue-row:nth-child(4) .av{background:linear-gradient(135deg,#22d3ee,#10b981)}
.queue-row b{display:block;font-size:.85rem;font-weight:600}
.queue-row span{font-size:.72rem;color:var(--ink-faint)}
.queue-row .chip{margin-left:auto;font-size:.66rem;font-weight:600;padding:.2rem .55rem;border-radius:999px;
  color:#9ef0ff;background:rgba(34,211,238,.12);box-shadow:inset 0 0 0 1px rgba(34,211,238,.35)}
.queue-row .chip.hot{color:#ffc2dd;background:rgba(236,72,153,.13);box-shadow:inset 0 0 0 1px rgba(236,72,153,.4)}
.amb-row{display:flex;align-items:center;gap:.7rem;font-size:.85rem}
.amb-dot{width:10px;height:10px;border-radius:50%;background:#34d399;box-shadow:0 0 0 0 rgba(52,211,153,.55);
  animation:ping 2.2s ease-out infinite;flex:none}
@keyframes ping{70%{box-shadow:0 0 0 11px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
.amb-meta{margin-left:auto;font-size:.72rem;color:var(--ink-faint)}

/* ---------- page hero (inner pages) ---------- */
.page-hero{position:relative;padding:calc(var(--s6) + 30px) 0 var(--s4);text-align:center;overflow:hidden}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.7rem);max-width:20ch}
.page-hero .lead{font-size:1.12rem;color:var(--ink-dim);max-width:40rem;margin:0 auto}
.breadcrumb{display:flex;gap:.5rem;justify-content:center;align-items:center;font-size:.82rem;color:var(--ink-faint);
  margin-bottom:1.4rem;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb .sep{opacity:.5}

/* ---------- stats ---------- */
.stats{position:relative;padding:var(--s4) 0;z-index:1}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border-radius:18px;overflow:hidden;background:var(--line)}
.stat{background:#0a0c14;padding:2rem 1.2rem;text-align:center}
.stat b{display:block;font-size:clamp(1.8rem,3.4vw,2.5rem);font-weight:700;letter-spacing:-.03em}
.stat span{font-size:.84rem;color:var(--ink-faint)}

/* ---------- section heads ---------- */
section{padding:var(--s5) 0;position:relative}
.sec-head{max-width:660px;margin-bottom:var(--s4)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.kicker{display:inline-block;font-size:.76rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:.9rem;padding:.35rem .85rem;border-radius:999px;color:var(--cyan);
  background:rgba(34,211,238,.07);box-shadow:inset 0 0 0 1px rgba(34,211,238,.25)}
.kicker.k-purple{color:var(--purple);background:rgba(168,85,247,.08);box-shadow:inset 0 0 0 1px rgba(168,85,247,.3)}
.kicker.k-pink{color:var(--pink);background:rgba(236,72,153,.08);box-shadow:inset 0 0 0 1px rgba(236,72,153,.3)}
.kicker.k-emerald{color:var(--emerald);background:rgba(52,211,153,.08);box-shadow:inset 0 0 0 1px rgba(52,211,153,.3)}
h2{font-size:clamp(1.9rem,3.8vw,2.8rem);line-height:1.1;letter-spacing:-.03em;font-weight:700}
h3{letter-spacing:-.01em}
.sec-head p{color:var(--ink-dim);margin-top:.9rem;font-size:1.04rem}

/* ---------- features ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.feat{padding:1.8rem;transition:transform .3s ease,box-shadow .3s ease}
.feat:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.55),0 0 44px rgba(124,58,237,.14)}
.icon{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(135deg,rgba(168,85,247,.16),rgba(34,211,238,.12));
  box-shadow:inset 0 0 0 1px rgba(168,85,247,.3)}
.icon.i-cyan{background:linear-gradient(135deg,rgba(34,211,238,.18),rgba(16,185,129,.12));box-shadow:inset 0 0 0 1px rgba(34,211,238,.32)}
.icon.i-pink{background:linear-gradient(135deg,rgba(236,72,153,.18),rgba(168,85,247,.12));box-shadow:inset 0 0 0 1px rgba(236,72,153,.32)}
.icon.i-emerald{background:linear-gradient(135deg,rgba(52,211,153,.18),rgba(34,211,238,.12));box-shadow:inset 0 0 0 1px rgba(52,211,153,.32)}
.icon.i-amber{background:linear-gradient(135deg,rgba(251,191,36,.18),rgba(236,72,153,.1));box-shadow:inset 0 0 0 1px rgba(251,191,36,.32)}
.feat h3{font-size:1.1rem;font-weight:600;margin-bottom:.45rem}
.feat p{font-size:.92rem;color:var(--ink-dim)}
.feat ul.mini{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.feat ul.mini li{font-size:.85rem;color:var(--ink-dim);display:flex;gap:.55rem;align-items:flex-start}
.feat ul.mini li::before{content:"";width:16px;height:16px;flex:none;margin-top:.15rem;border-radius:5px;
  background:linear-gradient(135deg,var(--purple),var(--cyan));
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5l3 3 7-7' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5l3 3 7-7' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat}

/* feature module explorer (features page) */
.explorer{display:grid;grid-template-columns:.9fr 1.1fr;gap:1.4rem;align-items:start}
.explorer-tabs{display:flex;flex-direction:column;gap:.6rem}
.explorer-tab{display:flex;gap:1rem;align-items:center;text-align:left;width:100%;cursor:pointer;
  padding:1.1rem 1.2rem;border-radius:14px;border:0;font-family:inherit;color:var(--ink);
  background:rgba(238,240,248,.03);box-shadow:inset 0 0 0 1px var(--line);transition:all .25s ease}
.explorer-tab .icon{width:42px;height:42px;margin:0;border-radius:11px}
.explorer-tab b{font-size:1rem;font-weight:600;display:block}
.explorer-tab span{font-size:.82rem;color:var(--ink-faint)}
.explorer-tab:hover{background:rgba(238,240,248,.06)}
.explorer-tab.active{background:rgba(168,85,247,.08);box-shadow:inset 0 0 0 1px rgba(168,85,247,.45),0 0 26px rgba(168,85,247,.12)}
.explorer-panel{padding:2rem;min-height:320px}
.explorer-panel .pane{display:none;animation:fade .4s ease}
.explorer-panel .pane.active{display:block}
.explorer-panel h3{font-size:1.4rem;font-weight:700;margin-bottom:.6rem}
.explorer-panel p{color:var(--ink-dim);margin-bottom:1.2rem}
.explorer-panel .pane ul{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.explorer-panel .pane ul li{font-size:.9rem;color:var(--ink-dim);display:flex;gap:.55rem;align-items:flex-start}
.explorer-panel .pane ul li::before{content:"→";color:var(--cyan);font-weight:700}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- intellect / AI rows ---------- */
.intellect{overflow:hidden}
.ai-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--s4);align-items:start;position:relative;z-index:1}
.ai-sticky{position:sticky;top:120px}
.ai-rows{display:flex;flex-direction:column;gap:1rem}
.ai-row{display:grid;grid-template-columns:auto 1fr auto;gap:1.3rem;align-items:center;padding:1.5rem 1.6rem;
  transition:transform .3s ease,box-shadow .3s ease}
.ai-row:hover{transform:translateX(8px);box-shadow:0 18px 50px rgba(0,0,0,.5),0 0 36px rgba(34,211,238,.12)}
.ai-num{font-size:.85rem;font-weight:700;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:none}
.n-1{color:#d8b4fe;background:rgba(168,85,247,.12);box-shadow:inset 0 0 0 1px rgba(168,85,247,.45),0 0 18px rgba(168,85,247,.25)}
.n-2{color:#a5f3fc;background:rgba(34,211,238,.1);box-shadow:inset 0 0 0 1px rgba(34,211,238,.45),0 0 18px rgba(34,211,238,.25)}
.n-3{color:#fbcfe8;background:rgba(236,72,153,.1);box-shadow:inset 0 0 0 1px rgba(236,72,153,.45),0 0 18px rgba(236,72,153,.25)}
.n-4{color:#a7f3d0;background:rgba(52,211,153,.1);box-shadow:inset 0 0 0 1px rgba(52,211,153,.45),0 0 18px rgba(52,211,153,.25)}
.ai-row h3{font-size:1.06rem;font-weight:600;margin-bottom:.25rem}
.ai-row p{font-size:.88rem;color:var(--ink-dim)}
.ai-row svg{width:104px;height:44px;flex:none}
@media (max-width:680px){.ai-row svg{display:none}}

/* AI tabs (garuda-ai page) */
.ai-tabs{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:var(--s4)}
.ai-tab{cursor:pointer;font-family:inherit;color:var(--ink-dim);font-weight:600;font-size:.92rem;
  padding:.7rem 1.3rem;border-radius:999px;border:0;background:rgba(238,240,248,.04);
  box-shadow:inset 0 0 0 1px var(--line);transition:all .25s ease}
.ai-tab:hover{color:var(--ink)}
.ai-tab.active{color:#fff;background:linear-gradient(95deg,#7c3aed,#0ea5e9);box-shadow:0 0 22px rgba(124,58,237,.4)}
.ai-panels{position:relative}
.ai-pane{display:none;animation:fade .45s ease}
.ai-pane.active{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--s4);align-items:center}
.ai-pane .viz{padding:1.6rem;border-radius:18px}
.ai-pane h3{font-size:1.6rem;font-weight:700;margin-bottom:.7rem}
.ai-pane p{color:var(--ink-dim);margin-bottom:1.2rem}
.ai-pane .signal{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600;
  color:var(--emerald);padding:.4rem .9rem;border-radius:999px;background:rgba(52,211,153,.1);
  box-shadow:inset 0 0 0 1px rgba(52,211,153,.3)}
.chart-svg{width:100%;height:auto}
.chart-svg .draw{stroke-dasharray:1;stroke-dashoffset:1;animation:draw 2.4s ease forwards}
.chart-svg .bar{transform:scaleY(0);transform-origin:bottom;animation:grow .9s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes grow{to{transform:scaleY(1)}}
@media (max-width:820px){.ai-pane.active{grid-template-columns:1fr}}

/* ---------- admin portal (browser mock) ---------- */
.browser-mock{max-width:780px;margin:var(--s4) auto 0;border-radius:16px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 60px rgba(168,85,247,.12),inset 0 0 0 1px var(--line-strong)}
.browser-bar{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;background:#0d0f1a;border-bottom:1px solid var(--line)}
.browser-bar .b-dot{width:11px;height:11px;border-radius:50%;flex:none}
.browser-bar .b-url{margin-left:.7rem;font-size:.76rem;color:var(--ink-faint);background:rgba(238,240,248,.05);
  padding:.35rem .9rem;border-radius:8px;flex:1;text-align:center}
.browser-body{padding:1.3rem;display:grid;grid-template-columns:132px 1fr;gap:1.1rem;
  background:linear-gradient(180deg,rgba(168,85,247,.06),rgba(9,10,17,.5))}
.browser-side{display:flex;flex-direction:column;gap:.55rem}
.browser-side .nav-item{height:30px;border-radius:8px;background:rgba(238,240,248,.05);box-shadow:inset 0 0 0 1px var(--line)}
.browser-side .nav-item.active{background:linear-gradient(95deg,rgba(124,58,237,.45),rgba(14,165,233,.32));box-shadow:inset 0 0 0 1px rgba(168,85,247,.55)}
.browser-main{display:grid;grid-template-rows:auto 1fr;gap:.9rem;min-width:0}
.browser-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}
.browser-cards .bc{height:58px;border-radius:10px;background:rgba(238,240,248,.05);box-shadow:inset 0 0 0 1px var(--line)}
.browser-cards .bc:nth-child(1){background:linear-gradient(160deg,rgba(168,85,247,.18),rgba(168,85,247,.02))}
.browser-cards .bc:nth-child(2){background:linear-gradient(160deg,rgba(34,211,238,.16),rgba(34,211,238,.02))}
.browser-cards .bc:nth-child(3){background:linear-gradient(160deg,rgba(236,72,153,.16),rgba(236,72,153,.02))}
.browser-chart{border-radius:10px;background:rgba(238,240,248,.03);box-shadow:inset 0 0 0 1px var(--line);padding:.8rem;min-height:120px}
@media (max-width:560px){.browser-body{grid-template-columns:1fr}.browser-side{flex-direction:row}}

/* ---------- product detail page ---------- */
.prod-jump{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:var(--s3)}
.prod-jump a{font-size:.84rem;color:var(--ink-dim);padding:.5rem 1rem;border-radius:999px;background:rgba(238,240,248,.04);box-shadow:inset 0 0 0 1px var(--line);transition:all .2s ease}
.prod-jump a:hover{color:var(--ink);box-shadow:inset 0 0 0 1px rgba(34,211,238,.5)}
.prod-section{padding:var(--s5) 0;border-top:1px solid var(--line);position:relative;scroll-margin-top:90px}
.prod-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);align-items:center}
.prod-row.flip .prod-visual{order:-1}
.prod-text .eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.76rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.7rem}
.prod-text h2{font-size:clamp(1.5rem,2.8vw,2.1rem);letter-spacing:-.02em}
.prod-text>p{color:var(--ink-dim);margin:.8rem 0 1.2rem;font-size:1.02rem}
.prod-text .best{margin-top:1.2rem;font-size:.86rem;color:var(--ink-faint)}
.prod-text .best b{color:var(--ink-dim)}
.prod-visual .gcard{padding:1.6rem}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:.55rem .9rem}
.checks li{list-style:none;font-size:.9rem;color:var(--ink-dim);display:flex;gap:.55rem;align-items:flex-start}
.checks li::before{content:"";width:16px;height:16px;flex:none;margin-top:.2rem;border-radius:5px;
  background:linear-gradient(135deg,var(--purple),var(--cyan));
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5l3 3 7-7' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5l3 3 7-7' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat}
@media (max-width:820px){.prod-row{grid-template-columns:1fr}.prod-row.flip .prod-visual{order:0}}
@media (max-width:560px){.checks{grid-template-columns:1fr}}

/* ---------- case studies ---------- */
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:var(--s3)}
.cs-card{padding:1.8rem;display:flex;flex-direction:column;gap:1rem;transition:transform .3s ease,box-shadow .3s ease}
.cs-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.55),0 0 40px rgba(168,85,247,.12)}
.cs-tag{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.cs-metric{font-size:2.5rem;font-weight:700;letter-spacing:-.03em;line-height:1}
.cs-card h3{font-size:1rem;font-weight:500;line-height:1.5;color:var(--ink-dim);flex:1}
.cs-link{font-size:.88rem;font-weight:600;display:inline-flex;gap:.4rem;color:var(--cyan);transition:gap .2s ease}
.cs-card:hover .cs-link{gap:.75rem}
.more-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--ink-dim);transition:color .2s ease,gap .2s ease}
.more-link:hover{color:var(--ink);gap:.85rem}

/* case study detail */
.cs-hero{text-align:center;position:relative;overflow:hidden;padding:calc(var(--s6) + 20px) 0 var(--s4)}
.cs-hero .wrap{position:relative;z-index:1}
.cs-bigmetric{font-size:clamp(3.4rem,9vw,6rem);font-weight:700;letter-spacing:-.04em;line-height:1}
.cs-bigmetric-label{color:var(--ink-dim);font-size:1.05rem;margin-top:.4rem}
.results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:18px;overflow:hidden;margin:var(--s4) 0}
.result{background:#0a0c14;padding:1.8rem 1.1rem;text-align:center}
.result b{display:block;font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700;letter-spacing:-.03em}
.result span{font-size:.8rem;color:var(--ink-faint)}
@media (max-width:760px){.results-grid{grid-template-columns:1fr 1fr}}

/* ---------- testimonials ---------- */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.quote{padding:1.9rem;display:flex;flex-direction:column;gap:1.2rem}
.quote .stars{display:flex;gap:3px}
.quote p{font-size:.97rem;color:var(--ink-dim);flex:1}
.quote footer{display:flex;align-items:center;gap:.85rem;border-top:1px solid var(--line);padding-top:1.1rem}
.quote footer i{width:42px;height:42px;border-radius:50%;flex:none;background:linear-gradient(135deg,#7c3aed,#22d3ee)}
.quote:nth-child(2) footer i{background:linear-gradient(135deg,#ec4899,#7c3aed)}
.quote:nth-child(3) footer i{background:linear-gradient(135deg,#22d3ee,#10b981)}
.quote footer b{display:block;font-size:.92rem}
.quote footer span{font-size:.79rem;color:var(--ink-faint)}

/* ---------- blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:var(--s3)}
.post{overflow:hidden;transition:transform .3s ease;display:flex;flex-direction:column}
.post:hover{transform:translateY(-6px)}
.post .thumb{height:148px;border-radius:18px 18px 0 0;position:relative;overflow:hidden}
.th-purple{background:radial-gradient(120% 130% at 20% 110%,rgba(168,85,247,.55),rgba(168,85,247,.06) 60%),#0d0f1a}
.th-cyan{background:radial-gradient(120% 130% at 80% 110%,rgba(34,211,238,.5),rgba(34,211,238,.05) 60%),#0d0f1a}
.th-pink{background:radial-gradient(120% 130% at 50% 120%,rgba(236,72,153,.5),rgba(236,72,153,.05) 60%),#0d0f1a}
.th-emerald{background:radial-gradient(120% 130% at 30% 120%,rgba(52,211,153,.5),rgba(52,211,153,.05) 60%),#0d0f1a}
.post .thumb svg.wave{position:absolute;inset:auto 0 0 0;width:100%;opacity:.85}
.post .thumb .glyph{position:absolute;top:14px;left:16px;opacity:.9}
.post .body{padding:1.4rem 1.5rem 1.6rem;flex:1;display:flex;flex-direction:column}
.post .meta{display:block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.5rem}
.post h3{font-size:1.02rem;font-weight:600;line-height:1.45}
.post .excerpt{font-size:.88rem;color:var(--ink-dim);margin-top:.5rem;flex:1}
.post .read{display:inline-flex;gap:.4rem;margin-top:.9rem;font-size:.86rem;font-weight:600;color:var(--cyan)}

/* blog toolbar */
.blog-toolbar{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-bottom:var(--s4)}
.search-box{position:relative;flex:1;min-width:220px}
.search-box input{width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);
  background:rgba(238,240,248,.04);border:0;box-shadow:inset 0 0 0 1px var(--line);
  border-radius:12px;padding:.85rem 1rem .85rem 2.7rem}
.search-box input::placeholder{color:var(--ink-faint)}
.search-box input:focus{outline:0;box-shadow:inset 0 0 0 1px rgba(34,211,238,.55),0 0 18px rgba(34,211,238,.15)}
.search-box svg{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);opacity:.5}
.chips{display:flex;gap:.5rem;flex-wrap:wrap}
.chip-btn{cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:600;color:var(--ink-dim);
  padding:.55rem 1rem;border-radius:999px;border:0;background:rgba(238,240,248,.04);
  box-shadow:inset 0 0 0 1px var(--line);transition:all .2s ease}
.chip-btn:hover{color:var(--ink)}
.chip-btn.active{color:#fff;background:linear-gradient(95deg,#7c3aed,#0ea5e9);box-shadow:0 0 18px rgba(124,58,237,.35)}
.no-results{text-align:center;color:var(--ink-faint);padding:var(--s4) 0;display:none}

/* featured post */
.featured-post{display:grid;grid-template-columns:1.1fr .9fr;gap:0;overflow:hidden;margin-bottom:var(--s4)}
.featured-post .fp-art{position:relative;min-height:300px;overflow:hidden}
.featured-post .fp-body{padding:2.4rem}
.featured-post .fp-body h2{font-size:clamp(1.5rem,2.6vw,2rem);margin:.6rem 0 .8rem;line-height:1.2}
.featured-post .fp-body p{color:var(--ink-dim);margin-bottom:1.3rem}
.featured-post .tag{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--purple-300)}
@media (max-width:760px){.featured-post{grid-template-columns:1fr}.featured-post .fp-art{min-height:180px}}

/* ---------- article (blog post + legal) ---------- */
.article-layout{display:grid;grid-template-columns:1fr minmax(0,var(--maxw-prose)) 1fr;gap:0;padding-top:var(--s4)}
.article-aside{position:relative}
.article-toc{position:sticky;top:120px;padding-left:1.4rem;font-size:.85rem}
.article-toc h2{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.9rem}
.article-toc a{display:block;color:var(--ink-dim);padding:.3rem 0;border-left:2px solid transparent;padding-left:.8rem;margin-left:-.8rem;transition:all .2s ease}
.article-toc a:hover{color:var(--ink)}
.article-toc a.active{color:var(--cyan);border-left-color:var(--cyan)}
.article-toc a.lvl-3{padding-left:1.6rem;font-size:.8rem}
@media (max-width:1080px){.article-layout{grid-template-columns:1fr}.article-aside{display:none}}

.article-head{text-align:center;max-width:var(--maxw-prose);margin:0 auto var(--s4)}
.article-head .post-cat{font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--purple-300)}
.article-head h1{font-size:clamp(2rem,4.4vw,3.2rem);max-width:24ch;margin:1rem auto}
.article-meta{display:flex;gap:1rem;justify-content:center;align-items:center;color:var(--ink-faint);font-size:.88rem;flex-wrap:wrap}
.article-meta .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#22d3ee)}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.5}

.prose{max-width:var(--maxw-prose);margin:0 auto;font-size:1.06rem;line-height:1.8;color:rgba(238,240,248,.82)}
.prose>*+*{margin-top:1.25rem}
.prose h2{font-size:1.7rem;margin-top:2.6rem;margin-bottom:.2rem;color:var(--ink);scroll-margin-top:100px}
.prose h3{font-size:1.3rem;margin-top:2rem;color:var(--ink);scroll-margin-top:100px}
.prose h2 .anchor,.prose h3 .anchor{opacity:0;margin-right:.4rem;color:var(--cyan);text-decoration:none;font-weight:400;margin-left:-1.2rem;padding-right:.4rem}
.prose h2:hover .anchor,.prose h3:hover .anchor{opacity:.7}
.prose a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(34,211,238,.4)}
.prose a:hover{text-decoration-color:var(--cyan)}
.prose strong{color:var(--ink);font-weight:600}
.prose ul,.prose ol{padding-left:1.3rem;display:flex;flex-direction:column;gap:.55rem}
.prose ul li{list-style:none;position:relative;padding-left:1.2rem}
.prose ul li::before{content:"";position:absolute;left:0;top:.7rem;width:7px;height:7px;border-radius:2px;
  background:linear-gradient(135deg,var(--purple),var(--cyan))}
.prose ol{list-style:decimal}
.prose blockquote{border-left:3px solid var(--purple);padding:.4rem 0 .4rem 1.4rem;color:var(--ink-dim);font-style:italic;
  background:linear-gradient(90deg,rgba(168,85,247,.06),transparent)}
.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:rgba(238,240,248,.08);
  padding:.15rem .4rem;border-radius:6px;color:#a5f3fc}
.prose pre{background:#0a0c14;box-shadow:inset 0 0 0 1px var(--line);border-radius:12px;padding:1.1rem 1.3rem;overflow:auto}
.prose pre code{background:none;padding:0;color:var(--ink-dim)}
.prose hr{border:0;height:1px;background:var(--line);margin:2.2rem 0}
.prose table{width:100%;border-collapse:collapse;font-size:.95rem}
.prose th,.prose td{text-align:left;padding:.7rem .9rem;border-bottom:1px solid var(--line)}
.prose th{color:var(--ink);font-weight:600;background:rgba(238,240,248,.03)}
.prose img{border-radius:14px;width:100%;box-shadow:inset 0 0 0 1px var(--line)}

.article-foot{max-width:var(--maxw-prose);margin:var(--s4) auto 0;border-top:1px solid var(--line);padding-top:var(--s3)}
.share{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-bottom:var(--s3)}
.share span{font-size:.84rem;color:var(--ink-faint);margin-right:.3rem}
.share a,.share button{display:inline-flex;align-items:center;gap:.45rem;cursor:pointer;font-family:inherit;
  font-size:.84rem;font-weight:600;color:var(--ink-dim);padding:.55rem .95rem;border-radius:10px;border:0;
  background:rgba(238,240,248,.04);box-shadow:inset 0 0 0 1px var(--line);transition:all .2s ease}
.share a:hover,.share button:hover{color:var(--ink);box-shadow:inset 0 0 0 1px rgba(34,211,238,.5)}
.author-card{display:flex;gap:1rem;align-items:center;padding:1.5rem;border-radius:16px}
.author-card .avatar{width:54px;height:54px;border-radius:50%;flex:none;background:linear-gradient(135deg,#7c3aed,#22d3ee)}
.author-card b{display:block}
.author-card span{font-size:.86rem;color:var(--ink-faint)}
.tag-row{display:flex;gap:.5rem;flex-wrap:wrap;margin:var(--s3) 0}
.tag-pill{font-size:.78rem;color:var(--ink-dim);padding:.4rem .85rem;border-radius:999px;background:rgba(238,240,248,.04);box-shadow:inset 0 0 0 1px var(--line)}

/* ---------- faq ---------- */
.faq-wrap{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:.85rem}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.3rem 1.5rem;
  background:none;border:0;color:var(--ink);font-family:inherit;font-size:1.04rem;font-weight:600;text-align:left;cursor:pointer;letter-spacing:-.01em}
.faq-q .plus{flex:none;width:28px;height:28px;border-radius:9px;display:grid;place-items:center;position:relative;
  background:rgba(238,240,248,.06);box-shadow:inset 0 0 0 1px rgba(238,240,248,.14);transition:transform .3s ease,box-shadow .3s ease}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--ink);border-radius:2px;transition:transform .3s ease}
.faq-q .plus::before{width:12px;height:2px}
.faq-q .plus::after{width:2px;height:12px}
.faq-q[aria-expanded="true"] .plus{transform:rotate(45deg);box-shadow:inset 0 0 0 1px rgba(34,211,238,.6),0 0 14px rgba(34,211,238,.25)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 1.5rem 1.4rem;color:var(--ink-dim);font-size:.95rem}

/* ---------- contact form ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--s4);align-items:start}
.contact-form{padding:2rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.84rem;font-weight:600;margin-bottom:.45rem;color:var(--ink-dim)}
.field input,.field textarea{width:100%;font-family:inherit;font-size:.97rem;color:var(--ink);
  background:rgba(238,240,248,.04);border:0;box-shadow:inset 0 0 0 1px var(--line);border-radius:12px;padding:.85rem 1rem;transition:box-shadow .2s ease}
.field textarea{min-height:130px;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint)}
.field input:focus,.field textarea:focus{outline:0;box-shadow:inset 0 0 0 1px rgba(34,211,238,.55),0 0 18px rgba(34,211,238,.15)}
.field.invalid input,.field.invalid textarea{box-shadow:inset 0 0 0 1px rgba(244,63,94,.7)}
.field .err{display:none;color:#fda4af;font-size:.78rem;margin-top:.4rem}
.field.invalid .err{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form-status{margin-top:1rem;padding:.95rem 1.1rem;border-radius:12px;font-size:.9rem;display:none}
.form-status.ok{display:block;color:#a7f3d0;background:rgba(52,211,153,.1);box-shadow:inset 0 0 0 1px rgba(52,211,153,.4)}
.form-status.bad{display:block;color:#fda4af;background:rgba(244,63,94,.1);box-shadow:inset 0 0 0 1px rgba(244,63,94,.4)}
.contact-aside .gcard{padding:1.6rem}
.contact-aside h3{font-size:1.05rem;margin-bottom:.4rem}
.contact-aside p{font-size:.92rem;color:var(--ink-dim)}
.info-row{display:flex;gap:.85rem;align-items:flex-start;padding:1rem 0;border-top:1px solid var(--line)}
.info-row:first-of-type{border-top:0}
.info-row .icon{width:40px;height:40px;border-radius:11px;margin:0;flex:none}
.info-row b{display:block;font-size:.95rem}
.info-row a,.info-row span{font-size:.88rem;color:var(--ink-dim)}
.info-row a:hover{color:var(--cyan)}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}}

/* ---------- cta band ---------- */
.cta-sec{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;padding:var(--s6) 0}
.cta-sec .wrap{position:relative;z-index:1}
.cta-sec h2{font-size:clamp(2.1rem,4.6vw,3.4rem);max-width:20ch;margin:0 auto .9rem}
.cta-sec p{color:var(--ink-dim);max-width:34rem;margin:0 auto 2rem;font-size:1.05rem}

/* ---------- logos / steps / pills used across pages ---------- */
.logo-strip{display:flex;flex-wrap:wrap;gap:1.6rem 2.6rem;justify-content:center;align-items:center;opacity:.7}
.logo-strip .lg{font-weight:700;font-size:1.05rem;letter-spacing:-.01em;color:var(--ink-dim)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;counter-reset:step}
.step{padding:1.8rem;position:relative}
.step .num{font-size:.85rem;font-weight:700;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;margin-bottom:1rem;
  color:var(--purple-300);background:rgba(168,85,247,.12);box-shadow:inset 0 0 0 1px rgba(168,85,247,.4)}
.step h3{font-size:1.08rem;font-weight:600;margin-bottom:.4rem}
.step p{font-size:.9rem;color:var(--ink-dim)}
.pill-row{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.pill{font-size:.82rem;color:var(--ink-dim);padding:.5rem 1rem;border-radius:999px;background:rgba(238,240,248,.04);box-shadow:inset 0 0 0 1px var(--line);display:inline-flex;gap:.5rem;align-items:center}

/* ---------- footer ---------- */
.site-footer{padding:var(--s5) 0 var(--s3)}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:2rem;margin-bottom:var(--s4)}
.foot-brand p{color:var(--ink-faint);font-size:.9rem;margin-top:1rem;max-width:18rem}
.foot-col h2{font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint);margin-bottom:1rem;font-weight:600}
.foot-col a{display:block;font-size:.9rem;color:var(--ink-dim);padding:.28rem 0;transition:color .2s ease}
.foot-col a:hover{color:var(--cyan)}
.foot-base{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;padding-top:var(--s3);border-top:1px solid var(--line);font-size:.84rem;color:var(--ink-faint)}

/* ---------- error pages ---------- */
.err-page{text-align:center;padding:calc(var(--s6) + 40px) 0 var(--s6);position:relative;overflow:hidden}
.err-page .wrap{position:relative;z-index:1}
.err-code{font-size:clamp(5rem,18vw,11rem);font-weight:700;letter-spacing:-.05em;line-height:1}

/* ---------- back to top ---------- */
.to-top{position:fixed;right:1.4rem;bottom:1.4rem;z-index:120;width:46px;height:46px;border-radius:14px;cursor:pointer;
  border:0;background:rgba(11,13,21,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  box-shadow:inset 0 0 0 1px var(--line-strong),0 10px 30px rgba(0,0,0,.5);color:var(--ink);
  display:grid;place-items:center;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s ease,transform .3s ease}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{box-shadow:inset 0 0 0 1px rgba(34,211,238,.5),0 10px 30px rgba(0,0,0,.5)}

/* ---------- WhatsApp floating button ---------- */
.wa-fab{position:fixed;left:1.4rem;bottom:1.4rem;z-index:120;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;background:#25d366;color:#fff;
  box-shadow:0 10px 30px rgba(0,0,0,.45),0 0 0 1px rgba(0,0,0,.06);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 14px 38px rgba(0,0,0,.5),0 0 24px rgba(37,211,102,.5)}
.wa-fab:focus-visible{outline:2px solid #25d366;outline-offset:3px}
@media (max-width:560px){.wa-fab{width:50px;height:50px;left:1rem;bottom:1rem}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}.reveal.d5{transition-delay:.5s}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .feat-grid,.apps-grid,.cs-grid,.quote-grid,.blog-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr 1fr}
  .ai-layout,.explorer{grid-template-columns:1fr}
  .ai-sticky{position:static}
  .results-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .feat-grid,.apps-grid,.cs-grid,.quote-grid,.blog-grid,.steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .hero-stage{min-height:0;display:flex;flex-direction:column;gap:1.2rem;align-items:center}
  .ui-card{position:static}
  .uc-1,.uc-2,.uc-3{width:min(330px,86vw)}
}

/* ========================================================================
   PREMIUM MOTION — entrances, spotlights, polish (transform/opacity/filter).
   The hidden state for entrances lives only inside @keyframes, so when motion
   is disabled the resting (visible) state shows with no extra overrides.
   ======================================================================== */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* hero (homepage) staggered entrance: eyebrow -> headline -> lead -> CTAs -> trust -> visual */
.hero .badge{animation:rise var(--dur-reveal) var(--ease) both}
.hero h1{animation:rise .7s var(--ease) .08s both}
.hero .lead{animation:rise .7s var(--ease) .16s both}
.hero .hero-ctas{animation:rise .7s var(--ease) .24s both}
.hero .trust{animation:rise .7s var(--ease) .32s both}
.hero .hero-stage{animation:fade .9s var(--ease) .42s both;transition:transform .5s var(--ease)}

/* inner page hero entrance */
.page-hero .breadcrumb{animation:rise .55s var(--ease) both}
.page-hero .kicker{animation:rise .6s var(--ease) .06s both}
.page-hero h1{animation:rise .7s var(--ease) .14s both}
.page-hero .lead{animation:rise .7s var(--ease) .22s both}
.page-hero .hero-ctas{animation:rise .7s var(--ease) .3s both}

/* blur-to-sharp on section headings */
.sec-head.reveal{filter:blur(8px);transition:opacity var(--dur-reveal) var(--ease),transform var(--dur-reveal) var(--ease),filter var(--dur-reveal) var(--ease)}
.sec-head.reveal.in{filter:blur(0)}

/* blog / case thumbnails — gentle zoom on hover */
.post .thumb .glyph,.post .thumb .wave{transition:transform .5s var(--ease)}
.post:hover .thumb .glyph{transform:scale(1.08) translateY(-2px)}
.post:hover .thumb .wave{transform:scale(1.04)}
.featured-post .fp-art .wave{transition:transform .6s var(--ease)}
.featured-post:hover .fp-art .wave{transform:scale(1.05)}

/* contact form — focus lift + status reveal */
.field input,.field textarea{transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.field input:focus,.field textarea:focus{transform:translateY(-1px)}
.form-status{transform:translateY(6px);opacity:0;transition:opacity .35s var(--ease),transform .35s var(--ease)}
.form-status.ok,.form-status.bad{transform:none;opacity:1}

/* testimonials — graceful swipeable scroll-snap carousel on small screens (no auto-advance) */
@media (max-width:680px){
  .quote-grid{grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:86%;
    overflow-x:auto;scroll-snap-type:x mandatory;gap:1rem;
    margin:0 calc(-1 * clamp(1.25rem,4vw,2.5rem));padding:0 clamp(1.25rem,4vw,2.5rem) .6rem;
    -webkit-overflow-scrolling:touch;scrollbar-width:none}
  .quote-grid::-webkit-scrollbar{display:none}
  .quote-grid .quote{scroll-snap-align:center}
}

/* sticky scroll-pinned storytelling (Product page) */
.scrolly-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s4);align-items:start}
.scrolly-steps{display:flex;flex-direction:column}
.scrolly-step{padding:16vh 0;opacity:.45;transition:opacity .4s var(--ease)}
.scrolly-step:first-child{padding-top:1vh}
.scrolly-step:last-child{padding-bottom:8vh}
.scrolly-step.active{opacity:1}
.scrolly-num{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:11px;font-size:.85rem;font-weight:700;
  margin-bottom:.9rem;color:var(--purple-300);background:rgba(168,85,247,.12);box-shadow:inset 0 0 0 1px rgba(168,85,247,.4)}
.scrolly-step h3{font-size:1.4rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.01em}
.scrolly-step p{color:var(--ink-dim)}
.scrolly-sticky{position:sticky;top:110px}
.scrolly-stage{position:relative;min-height:360px;padding:1.6rem}
.scrolly-panel{position:absolute;inset:1.6rem;opacity:0;transform:translateY(16px) scale(.985);
  transition:opacity .5s var(--ease),transform .5s var(--ease);pointer-events:none}
.scrolly-panel.active{opacity:1;transform:none;pointer-events:auto}
.scrolly-panel h4{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.8rem}
@media (max-width:820px){
  .scrolly-grid{grid-template-columns:1fr;gap:0}
  .scrolly-sticky{display:none}
  .scrolly-step{padding:1.4rem 0;opacity:1;border-top:1px solid var(--line)}
  .scrolly-step:first-child{border-top:0;padding-top:0}
}

/* cross-document View Transitions — soft page-to-page fades (progressive enhancement, Chromium) */
@media (prefers-reduced-motion: no-preference){
  @view-transition{ navigation: auto; }
  ::view-transition-old(root),::view-transition-new(root){ animation-duration:.32s }
}
.site-header{view-transition-name:site-header}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal,.sec-head.reveal{opacity:1;transform:none;filter:none}
  .scrolly-step{opacity:1}
  .grad-text{background-position:0 0}
  .chart-svg .draw{stroke-dashoffset:0}
  .chart-svg .bar{transform:scaleY(1)}
}
