/* ============================================================================
   ScheduleInsight — Experience Design System  (assets/experience.css)
   Bold reinvention layer for the marketing site. Dark-first, light-aware.
   Co-exists with theme.js (which sets data-theme + the --mk-* brand tokens
   and supplies the light-theme overrides for the shared token names).
   ----------------------------------------------------------------------------
   Conventions:
     - Token names mirror the legacy set so theme.js light overrides keep working.
     - New primitives are additive; pages opt-in via classes / data-attributes.
     - Everything degrades gracefully without JS and respects reduced-motion.
   ========================================================================== */

:root{
  /* Core surfaces (dark defaults — richer, deeper than the legacy set) */
  --bg:#06070B; --bgSub:#0A0C12; --surface:#0E1018; --surfaceHi:#141722; --card:#11131C;
  --hair:#21242F; --hairSoft:#181B24;

  /* Text */
  --txt:#F1F2F6; --txtMid:#A3A7B5; --txtLow:#71757F; --txtDim:#7C808C;

  /* Brand accent family — indigo kept, extended into a violet→cyan spectrum */
  --accent:#6E7BFF; --accent2:#9B6BFF; --accent3:#37E2C5;
  --accentSub:rgba(110,123,255,0.12); --accentLine:rgba(110,123,255,0.34);
  --glow:rgba(110,123,255,.55);
  /* Filled-button colours — deep enough for WHITE label text to pass WCAG AA in
     both themes (the brand --accent is a midtone, legible for neither black nor white). */
  --btnbg:#5663E6; --btnfg:#FFFFFF;

  /* Signal palette (data viz) */
  --green:#3FD08A; --amber:#E7B14B; --red:#FF6B5E;

  /* Signature gradients */
  --grad-brand:linear-gradient(115deg,#6E7BFF 0%,#9B6BFF 45%,#37E2C5 100%);
  --grad-brand-soft:linear-gradient(115deg,rgba(110,123,255,.16),rgba(55,226,197,.10));
  --grad-text:linear-gradient(100deg,#C9CCFF 0%,#8E9BFF 40%,#5FE7D0 100%);

  /* Type */
  --sans:"Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --display:"Space Grotesk","Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;

  /* Brand mark tokens (also set in theme.js; restated for safety) */
  --mk-tile:#141722; --mk-stroke:#21242F; --mk-barA:#6E7BFF; --mk-barB:#A3A7B5;

  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --maxw:1240px;
}

/* Light theme: extend theme.js overrides with our new tokens */
html[data-theme="light"]{
  --bg:#FFFFFF; --bgSub:#F6F7FB; --surface:#FFFFFF; --surfaceHi:#EEF1F7; --card:#FFFFFF;
  --hair:#E4E7EF; --hairSoft:#EEF1F6;
  --txt:#0E1220; --txtMid:#475069; --txtLow:#646E80; --txtDim:#646E80;
  --accent:#5A52D6; --accent2:#7C4DE0; --accent3:#0FA89A;
  --accentSub:rgba(90,82,214,0.08); --accentLine:rgba(90,82,214,0.28);
  --glow:rgba(90,82,214,.30);
  --btnbg:#4F46E5; --btnfg:#FFFFFF;
  --grad-text:linear-gradient(100deg,#4F49C7 0%,#6B4DE0 45%,#0FA89A 100%);
  --mk-tile:#EEF1F6; --mk-stroke:#E4E7EF; --mk-barA:#534AB7; --mk-barB:#94A3B8;
}

/* ----------------------------------------------------------------- reset */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden;max-width:100%}
body{
  background:var(--bg);color:var(--txt);font-family:var(--sans);line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:rgba(110,123,255,.30);color:#fff}
html[data-theme="light"] ::selection{background:rgba(90,82,214,.18);color:#0E1220}

/* slim themed scrollbar */
*{scrollbar-width:thin;scrollbar-color:var(--hair) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--hair);border-radius:20px;border:3px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:var(--accentLine)}

/* ------------------------------------------------------------ atmosphere */
/* Fixed grain + aurora wash that lives behind all content */
.fx-grain{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}
html[data-theme="light"] .fx-grain{opacity:.25}

.fx-aurora{
  position:fixed;inset:-20% -10% auto -10%;height:80vh;z-index:0;pointer-events:none;
  background:
    radial-gradient(40% 50% at 18% 12%,rgba(110,123,255,.20),transparent 70%),
    radial-gradient(35% 45% at 82% 8%,rgba(55,226,197,.13),transparent 70%),
    radial-gradient(45% 55% at 60% 30%,rgba(155,107,255,.12),transparent 72%);
  filter:blur(20px);opacity:.9;
}
html[data-theme="light"] .fx-aurora{opacity:.5}

/* page content sits above atmosphere */
nav,main,footer,.page-shell{position:relative;z-index:2}

/* scroll progress bar */
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:200;background:var(--grad-brand);box-shadow:0 0 12px var(--glow);transition:width .08s linear}

/* ------------------------------------------------------------------- nav */
.xnav{position:sticky;top:0;z-index:100;transition:background .3s,border-color .3s,backdrop-filter .3s}
.xnav.scrolled{background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--hair)}
.xnav-inner{display:flex;align-items:center;gap:30px;padding:18px 40px;max-width:var(--maxw);margin:0 auto;transition:padding .3s}
.xnav.scrolled .xnav-inner{padding-top:13px;padding-bottom:13px}
.xbrand{display:flex;align-items:center;gap:10px;font-weight:600}
.xbrand .brand-name{font-size:15.5px;letter-spacing:-.01em;font-family:var(--display)}
.xnav-links{display:flex;gap:24px;font-size:13.5px;color:var(--txtMid);margin-left:6px}
.xnav-links a{position:relative;padding:4px 0;transition:color .2s}
.xnav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--grad-brand);transition:width .25s var(--ease-out)}
.xnav-links a:hover{color:var(--txt)}
.xnav-links a:hover::after{width:100%}
.xnav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.xnav-right .login{font-size:13.5px;color:var(--txtMid);transition:color .2s}
.xnav-right .login:hover{color:var(--txt)}
.xnav-toggle{display:none;background:none;border:none;color:var(--txt);cursor:pointer;padding:4px}
.xnav-mobile{display:none;flex-direction:column;padding:8px 24px 18px;border-bottom:1px solid var(--hair);background:var(--bgSub)}
.xnav-mobile a{padding:11px 0;font-size:14.5px;color:var(--txtMid);border-bottom:1px solid var(--hairSoft)}
.xnav-mobile a:last-child{border-bottom:none}
.xnav-mobile.open{display:flex}

/* --------------------------------------------------------------- buttons */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;font-family:var(--sans);border-radius:8px;padding:12px 22px;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--ease-out),box-shadow .25s,filter .2s,border-color .2s;will-change:transform}
/* Solid indigo primary (white label, AA in both themes) + ghost */
.btn-primary{color:var(--btnfg);background:var(--btnbg)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{color:var(--txt);background:var(--surfaceHi);border-color:var(--hair)}
.btn-ghost:hover{border-color:var(--accentLine)}
.btn-sm{padding:8px 15px;font-size:13.5px;border-radius:8px}
.btn:active{transform:scale(.97)}
.btn-accent{font-size:13.5px;font-weight:600;color:var(--btnfg);background:var(--btnbg);padding:8px 15px;border-radius:8px;transition:filter .2s}
.btn-accent:hover{filter:brightness(1.08)}

/* ------------------------------------------------------------ typography */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-family:var(--mono);color:var(--accent);margin-bottom:18px}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--accent);opacity:.6}
.gradtext{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
h1,h2,h3{font-family:var(--display);letter-spacing:-.025em;line-height:1.06}

/* generic section wrapper */
.xsec{max-width:var(--maxw);margin:0 auto;padding:96px 40px}
.xsec-title{font-size:clamp(28px,4vw,42px);font-weight:600;letter-spacing:-.03em;margin-bottom:18px;max-width:18ch}
.xsec-lead{font-size:16px;color:var(--txtMid);max-width:60ch;line-height:1.65}

/* -------------------------------------------------------------- surfaces */
.glass{background:color-mix(in srgb,var(--bgSub) 86%,transparent);border:1px solid var(--hair);border-radius:16px;backdrop-filter:blur(8px)}
.panel{background:var(--bgSub);border:1px solid var(--hair);border-radius:16px}
.lift{transition:transform .35s var(--ease-out),border-color .35s,box-shadow .35s}
.lift:hover{transform:translateY(-4px);border-color:var(--accentLine);box-shadow:0 24px 60px -34px rgba(0,0,0,.7)}
html[data-theme="light"] .lift:hover{box-shadow:0 24px 50px -30px rgba(20,30,80,.20)}

/* gradient hairline border card */
.card-grad{position:relative;border-radius:16px;background:var(--bgSub);border:1px solid var(--hair)}
.card-grad::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad-brand);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s}
.card-grad:hover::before{opacity:.6}

/* ------------------------------------------------------------ animations */
/* Hidden state only applies once JS has flagged html.xanim — so content is
   ALWAYS visible if the script fails, is blocked, or is slow to run. */
html.xanim [data-reveal]{opacity:0;transform:translateY(26px);will-change:transform,opacity}
html.xanim [data-reveal].is-in{opacity:1;transform:none;transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
html.xanim [data-reveal-stagger]>*{opacity:0;transform:translateY(22px)}
/* opacity-only reveal — for headings containing gradient-clipped text, which a
   transform would render transparent. Never apply transform to these. */
html.xanim [data-fade]{opacity:0}
html.xanim [data-fade].is-in{opacity:1;transition:opacity .9s var(--ease-out)}
.spin-slow{animation:spin 28s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.float{animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* marquee */
.marquee{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:48px;width:max-content;animation:scrollx 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* counters / stat */
.statline{display:grid;grid-template-columns:repeat(4,1fr);max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.statline .stat{padding:30px 28px;position:relative}
.statline .stat+.stat{border-left:1px solid var(--hair)}
.stat-big{font-size:30px;font-weight:600;font-family:var(--mono);letter-spacing:-.02em;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat-sub{font-size:12.5px;color:var(--txtMid);margin-top:8px}
@media(max-width:760px){.statline{grid-template-columns:1fr 1fr}.statline .stat:nth-child(3){border-left:none}.statline .stat:nth-child(odd){border-left:none}}

/* ------------------------------------------------------------------ misc */
.chip{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-family:var(--mono);color:var(--txtMid);padding:6px 12px;border:1px solid var(--hair);border-radius:999px;background:var(--bgSub)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.kbd{font-family:var(--mono);font-size:12px;color:var(--accent)}
.brandmark{display:inline-block;vertical-align:middle;flex:none}
.lo{color:var(--txtMid);font-weight:500}
/* Nav brand logo — slightly larger; size is identical in dark + light
   (CSS width overrides the inline SVG width/height attributes). */
.xnav .brandmark{width:30px;height:30px}
.xbrand .brand-name{font-size:17px}
.nav-inner .brandmark{width:28px;height:28px}   /* legal-page navs */
.nav-inner .brand{font-size:15.5px}

/* footer */
.xfoot{position:relative;z-index:2;border-top:1px solid var(--hair);max-width:var(--maxw);margin:0 auto;padding:56px 40px 34px}
.xfoot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:30px}
.xfoot p{font-size:12.5px;color:var(--txtMid);line-height:1.65;max-width:300px}
.xfoot h5{font-size:11px;color:var(--txtDim);letter-spacing:.1em;text-transform:uppercase;font-family:var(--mono);margin-bottom:14px}
.xfoot-col a{display:block;font-size:13px;color:var(--txtMid);margin-bottom:9px;transition:color .2s,transform .2s}
.xfoot-col a:hover{color:var(--txt);transform:translateX(3px)}
.xfoot-bottom{display:flex;align-items:center;gap:12px;margin-top:36px;padding-top:20px;border-top:1px solid var(--hair);font-size:12px;color:var(--txtDim);flex-wrap:wrap}
.xfoot-bottom .right{margin-left:auto}
.xfoot-tm{margin-top:16px;padding-top:14px;border-top:1px solid var(--hair);font-size:11px;line-height:1.65;color:var(--txtDim)}
@media(max-width:880px){.xfoot-grid{grid-template-columns:1fr 1fr}}

/* ------------------------------------------------------ responsive nav */
@media(max-width:920px){
  .xnav-inner{padding:16px 20px;gap:14px}
  .xnav-links{display:none}
  .xnav-toggle{display:inline-flex}
  .xnav-right .login{display:none}
  .xsec{padding:64px 20px}
}

/* ------------------------------------------------- reduced motion guard */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .fx-grain,.fx-aurora{display:none}
  .marquee-track,.spin-slow,.float{animation:none!important}
}
