/* ============ DESIGN TOKENS ============ */
:root{
  --purple-50:#F5F3FF;
  --purple-100:#EDE9FE;
  --purple-200:#DDD6FE;
  --purple-300:#C4B5FD;
  --purple-400:#A78BFA;
  --purple-500:#8B5CF6;
  --purple-600:#7C3AED;
  --purple-700:#6D28D9;
  --purple-800:#5B21B6;
  --purple-900:#4C1D95;
  --purple-950:#2E1065;
  --cream:#FAFAF7;
  --cream-2:#F4F2EE;
  --ink:#1A1625;    /* deep indigo-black substitute for black */
  --ink-soft:#3B2E55;
  --line:rgba(45,20,90,0.08);
  --white:#FFFFFF;

  --radius-lg:28px;
  --radius-md:18px;
  --radius-sm:12px;

  --font:'Inter',system-ui,-apple-system,sans-serif;
  --serif:'Instrument Serif',Georgia,serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* Grain overlay */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;transition:all .4s var(--ease);
}
.nav.scrolled{
  padding:12px 0;
  background:rgba(250,250,247,.82);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1240px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.logo{height:18px;width:auto;display:block}
.logo-light{display:none}
.nav.hero-mode .logo-light{display:block}
.nav.hero-mode .logo-dark{display:none}
.nav.hero-mode .nav-links a{color:var(--white)}
.foot-logo{height:22px;width:auto;align-self:flex-start;margin-bottom:6px}

.nav-links{display:flex;gap:32px}
.nav-links a{font-size:14px;font-weight:500;opacity:.85;transition:opacity .2s}
.nav-links a:hover{opacity:1}

/* Language switcher */
.lang-switch{
  display:inline-flex;align-items:center;gap:2px;margin-left:auto;
  padding:3px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.5);
}
.lang-switch button{
  font:inherit;font-size:12px;font-weight:700;letter-spacing:.04em;cursor:pointer;
  padding:5px 11px;border-radius:999px;border:none;background:transparent;
  color:var(--ink-soft);opacity:.7;transition:all .25s var(--ease);
}
.lang-switch button:hover{opacity:1}
.lang-switch button.active{
  background:var(--purple-600);color:#fff;opacity:1;
  box-shadow:0 4px 10px -4px rgba(109,40,217,.6);
}
/* Over the hero (transparent nav) the switcher sits on a dark video */
.nav.hero-mode .lang-switch{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.12)}
.nav.hero-mode .lang-switch button{color:var(--white)}
.nav.hero-mode .lang-switch button.active{background:var(--white);color:var(--purple-800)}
.wiz-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:8px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 22px;border-radius:999px;cursor:pointer;
  border:1px solid transparent;transition:all .3s var(--ease);
  white-space:nowrap;
}
.btn-pill{
  background:linear-gradient(180deg,#2b2b33 0%,#121218 48%,#0a0a0f 100%);
  color:var(--white);padding:10px 18px;font-size:13px;
  border:2px solid rgba(167,139,250,.5);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    inset 0 -1px 0 rgba(0,0,0,.55),
    0 2px 8px rgba(0,0,0,.28);
  animation:btnPillPulse 2.6s ease-in-out infinite;
}
.btn-pill:hover{
  background:linear-gradient(180deg,#3a3a44 0%,#1a1a20 48%,#0f0f14 100%);
  transform:translateY(-1px);
}
@keyframes btnPillPulse{
  0%,100%{
    border-color:rgba(167,139,250,.3);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.14),
      inset 0 -1px 0 rgba(0,0,0,.55),
      0 2px 8px rgba(0,0,0,.28),
      0 0 0 0 rgba(139,92,246,0);
  }
  50%{
    border-color:rgba(196,181,253,.95);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.18),
      inset 0 -1px 0 rgba(0,0,0,.55),
      0 2px 8px rgba(0,0,0,.28),
      0 0 18px 2px rgba(139,92,246,.55);
  }
}
.btn-primary{
  background:linear-gradient(135deg,var(--purple-600),var(--purple-500));
  color:var(--white);
  box-shadow:0 10px 30px -10px rgba(124,58,237,.7),inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(124,58,237,.8)}
.btn-ghost{background:rgba(255,255,255,.12);color:var(--white);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-outline:hover{border-color:var(--purple-600);color:var(--purple-700)}
.arrow{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  color:var(--white);
  padding:120px 28px 100px;
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;
  filter:saturate(1.1) brightness(.72);
  transform:scale(1.02);
  transform-origin:center bottom;
}
.hero-gradient{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 20% 30%,rgba(139,92,246,.45),transparent 55%),
    radial-gradient(ellipse at 80% 70%,rgba(109,40,217,.55),transparent 55%),
    linear-gradient(180deg,rgba(30,16,80,.55) 0%,rgba(46,16,101,.65) 45%,rgba(250,250,247,.0) 80%,rgba(250,250,247,1) 100%);
}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);z-index:1;opacity:.6;pointer-events:none}
.orb-a{width:500px;height:500px;background:var(--purple-500);top:-100px;left:-100px;animation:float 18s ease-in-out infinite}
.orb-b{width:600px;height:600px;background:var(--purple-700);bottom:-200px;right:-150px;animation:float 22s ease-in-out -5s infinite}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(60px,-40px) scale(1.1)}
}

.hero-content{position:relative;z-index:3;max-width:1040px;text-align:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.12);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.22);
  font-size:13px;font-weight:500;letter-spacing:.02em;
  margin-bottom:28px;
}
.eyebrow.dark{background:var(--purple-50);border:1px solid var(--purple-200);color:var(--purple-800)}
.pulse-dot{
  width:6px;height:6px;border-radius:50%;background:var(--purple-300);
  box-shadow:0 0 0 0 rgba(167,139,250,.6);animation:pulse 2s infinite;
}
.eyebrow.dark .pulse-dot{background:var(--purple-600)}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(167,139,250,.6)}
  70%{box-shadow:0 0 0 10px rgba(167,139,250,0)}
  100%{box-shadow:0 0 0 0 rgba(167,139,250,0)}
}

.hero-title{
  font-size:clamp(42px,7vw,96px);
  line-height:1.02;letter-spacing:-.03em;font-weight:700;
  margin-bottom:24px;
}
.hero-title em{font-style:italic;font-family:var(--serif);font-weight:400;color:var(--purple-200)}
.grad-text{
  background:linear-gradient(90deg,#C4B5FD 0%,#DDD6FE 40%,#F5F3FF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.grad-text-light{
  background:linear-gradient(90deg,var(--purple-600),var(--purple-400));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  font-size:clamp(16px,1.4vw,20px);max-width:640px;margin:0 auto 40px;
  opacity:.85;line-height:1.55;
}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.hero-bullets{display:flex;gap:28px;justify-content:center;flex-wrap:wrap;font-size:13px;opacity:.75}

.scroll-hint{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.25em;opacity:.7;text-transform:uppercase;
}
.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.8),transparent);animation:scrollDrop 2s ease-in-out infinite}
@keyframes scrollDrop{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ============ MARQUEE ============ */
.marquee-wrap{padding:80px 0 40px;background:var(--cream);text-align:center}
.marquee-label{font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-soft);opacity:.6;margin-bottom:20px}
.marquee{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee-track{
  display:flex;gap:40px;white-space:nowrap;
  animation:marq 30s linear infinite;
  font-family:var(--serif);font-size:36px;color:var(--ink);opacity:.85;
}
.marquee-track span:nth-child(2n){color:var(--purple-600)}
@keyframes marq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============ REFERANSER ============ */
.refs{position:relative;padding:130px 0;color:var(--white);overflow:hidden}
.refs-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(circle at 15% 0%,var(--purple-700) 0%,transparent 45%),
    radial-gradient(circle at 85% 100%,var(--purple-900) 0%,transparent 50%),
    linear-gradient(160deg,var(--purple-950),var(--purple-900) 55%,var(--purple-800));
}
.refs-bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse at center,#000,transparent 72%);
}
.refs-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;z-index:0;pointer-events:none}
.refs-orb-a{width:480px;height:480px;background:var(--purple-500);top:-140px;left:-100px;animation:float 20s ease-in-out infinite}
.refs-orb-b{width:540px;height:540px;background:var(--purple-600);bottom:-200px;right:-120px;animation:float 24s ease-in-out -6s infinite}
.refs .container{position:relative;z-index:1}

.refs-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  max-width:980px;margin:0 auto;
}
.ref-logo{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:38px 30px;min-height:132px;
  border-radius:var(--radius-md);
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(14px);
  overflow:hidden;
  transition:transform .45s var(--ease),background .45s var(--ease),border-color .45s var(--ease),box-shadow .45s var(--ease);
}
.ref-logo::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at 50% 0%,rgba(196,181,253,.35),transparent 65%);
  opacity:0;transition:opacity .45s var(--ease);pointer-events:none;
}
.ref-logo img{
  position:relative;z-index:1;
  max-width:100%;max-height:48px;width:auto;height:auto;
  transition:transform .45s var(--ease),filter .45s var(--ease);
  filter:brightness(1.12) drop-shadow(0 2px 14px rgba(167,139,250,.25));
}
.ref-logo:hover{
  transform:translateY(-6px);
  background:rgba(255,255,255,.1);
  border-color:rgba(196,181,253,.5);
  box-shadow:0 24px 60px -18px rgba(124,58,237,.55);
}
.ref-logo:hover::before{opacity:1}
.ref-logo:hover img{transform:scale(1.05);filter:brightness(1.25) drop-shadow(0 4px 20px rgba(196,181,253,.5))}

@media(max-width:860px){.refs-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.refs-grid{grid-template-columns:1fr}}

/* ============ LIVE DEMO BAND ============ */
.demo-band{position:relative;padding:120px 0;color:var(--white);overflow:hidden;text-align:center}
.demo-band-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(circle at 18% 8%,var(--purple-600) 0%,transparent 45%),
    radial-gradient(circle at 85% 95%,var(--purple-900) 0%,transparent 50%),
    linear-gradient(150deg,var(--purple-950),var(--purple-900) 55%,var(--purple-800));
}
.demo-band-bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse at center,#000,transparent 70%);
}
.demo-orb{
  position:absolute;width:520px;height:520px;border-radius:50%;
  background:var(--purple-500);filter:blur(110px);opacity:.4;
  top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:0;pointer-events:none;animation:float 22s ease-in-out infinite;
}
.demo-band .container{position:relative;z-index:1}
.demo-band-inner{max-width:640px;margin:0 auto}
.demo-band-inner h2{
  font-size:clamp(32px,4.6vw,58px);line-height:1.06;
  letter-spacing:-.02em;font-weight:700;margin:18px 0 16px;
}
.demo-band-inner p{font-size:17px;opacity:.84;margin:0 auto 32px;line-height:1.6;max-width:540px}
.demo-band-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.demo-band .btn .arrow.ext{transition:transform .3s var(--ease)}
.demo-band .btn:hover .arrow.ext{transform:translate(3px,-3px)}

/* ============ SECTION HEAD ============ */
.section-head{text-align:center;max-width:780px;margin:0 auto 72px}
.section-head.light{color:var(--white)}
.section-title{
  font-size:clamp(36px,5.5vw,76px);
  line-height:1.04;letter-spacing:-.03em;font-weight:700;
  margin:20px 0;
}
.section-sub{font-size:18px;opacity:.75;max-width:620px;margin:0 auto}

/* ============ SERVICES ============ */
.services{padding:120px 0;background:var(--cream);position:relative}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.svc-card{
  position:relative;
  padding:36px 30px;border-radius:var(--radius-lg);
  background:var(--white);
  border:1px solid var(--line);
  transition:all .45s var(--ease);
  overflow:hidden;
}
.svc-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(139,92,246,.12),transparent 50%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.svc-card:hover::before{opacity:1}
.svc-card:hover{transform:translateY(-6px);border-color:var(--purple-300);box-shadow:0 30px 60px -30px rgba(109,40,217,.35)}
.svc-card.highlight{
  background:linear-gradient(160deg,var(--purple-700),var(--purple-900));
  color:var(--white);border-color:transparent;
}
.svc-card.highlight .svc-icon{background:rgba(255,255,255,.15);color:var(--white)}
.svc-card.highlight .svc-list li::before{color:var(--purple-300)}
.badge{
  position:absolute;top:18px;right:18px;
  background:rgba(255,255,255,.2);color:#fff;
  padding:4px 10px;border-radius:999px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);
}
.svc-icon{
  width:52px;height:52px;border-radius:14px;
  background:var(--purple-50);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;margin-bottom:22px;
}
.svc-icon svg{width:24px;height:24px}
.svc-card h3{font-size:24px;font-weight:700;letter-spacing:-.01em;margin-bottom:10px}
.svc-card p{font-size:14.5px;opacity:.8;margin-bottom:18px;line-height:1.55}
.svc-list{list-style:none;font-size:13.5px}
.svc-list li{padding:6px 0 6px 22px;position:relative;opacity:.85}
.svc-list li::before{content:"✓";position:absolute;left:0;color:var(--purple-600);font-weight:700}
.svc-actions{display:flex;align-items:center;gap:14px;margin-top:24px;flex-wrap:wrap}
.svc-more{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;color:var(--purple-700);letter-spacing:.01em;
}
.svc-card.highlight .svc-more{color:var(--purple-200)}
.svc-card:hover .svc-more .arrow{transform:translateX(4px)}
.svc-demo{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:600;letter-spacing:.01em;
  color:var(--purple-700);
  padding:7px 14px;border-radius:999px;
  background:var(--purple-50);border:1px solid var(--purple-200);
  transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease);
}
.svc-demo .arrow.ext{transition:transform .3s var(--ease)}
.svc-demo:hover{background:var(--purple-100);border-color:var(--purple-300);transform:translateY(-1px)}
.svc-demo:hover .arrow.ext{transform:translate(2px,-2px)}
.svc-demo.disabled{
  color:var(--ink-soft);opacity:.5;
  background:transparent;border-color:var(--line);
  pointer-events:none;
}
.svc-card.highlight .svc-demo{color:#fff;background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35)}
.svc-card.highlight .svc-demo:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.5)}

/* ============ CONTACT ============ */
.depth-band{
  position:relative;overflow:hidden;color:var(--white);
  background:
    radial-gradient(circle at 15% 0%,var(--purple-700) 0%,transparent 45%),
    radial-gradient(circle at 85% 100%,var(--purple-900) 0%,transparent 50%),
    linear-gradient(160deg,var(--purple-950),var(--purple-900) 55%,var(--purple-800));
}
.depth-band::before{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse at center,#000,transparent 75%);
}
.depth-orb{position:absolute;border-radius:50%;filter:blur(95px);opacity:.45;z-index:0;pointer-events:none}
.depth-orb-a{width:460px;height:460px;background:var(--purple-500);top:-120px;left:-90px;animation:float 21s ease-in-out infinite}
.depth-orb-b{width:520px;height:520px;background:var(--purple-600);bottom:-180px;right:-110px;animation:float 25s ease-in-out -7s infinite}
.depth-band .container{position:relative;z-index:1}
.depth-band .visual{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(16px);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.5);
}
.depth-band .visual::after{display:none}
.contact-support{
  display:flex;align-items:center;gap:22px;
  background:linear-gradient(160deg,var(--purple-700),var(--purple-900));color:#fff;
  border-radius:var(--radius-lg);padding:28px 32px;margin-bottom:20px;
  box-shadow:0 30px 70px -30px rgba(76,29,149,.45);
}
.contact-support .contact-avatar{margin:0;flex-shrink:0;background:rgba(255,255,255,.18)}
.contact-support-text{flex:1;min-width:0}
.contact-support-text h4{font-size:19px;font-weight:700;margin-bottom:4px}
.contact-support-text p{font-size:14px;opacity:.82;line-height:1.5}
.contact-support .btn{flex-shrink:0}
@media(max-width:640px){
  .contact-support{flex-direction:column;text-align:center;gap:16px}
  .contact-support .btn{width:100%;justify-content:center}
}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:860px;margin:0 auto}
@media(max-width:860px){.contact-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.contact-grid{grid-template-columns:1fr}}
.contact-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:32px 26px;text-align:center;transition:all .35s var(--ease);
}
.contact-card:hover{transform:translateY(-5px);border-color:var(--purple-300);box-shadow:0 24px 50px -24px rgba(109,40,217,.3)}
.contact-avatar{
  width:62px;height:62px;border-radius:50%;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:#fff;letter-spacing:.02em;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-800));
  overflow:hidden;
}
.contact-avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.contact-card h4{font-size:17px;font-weight:700;margin-bottom:10px}
.contact-email{font-size:14px;font-weight:600;color:var(--purple-700);word-break:break-word}
.contact-email:hover{text-decoration:underline}
.contact-card.highlight{background:linear-gradient(160deg,var(--purple-700),var(--purple-900));color:#fff;border-color:transparent}
.contact-card.highlight .contact-avatar{background:rgba(255,255,255,.18)}
.contact-card.highlight .contact-email{color:var(--purple-200)}

/* ============ SUBPAGE ============ */
.subpage-hero{
  position:relative;padding:180px 0 100px;overflow:hidden;color:var(--white);
  background:linear-gradient(135deg,var(--purple-950),var(--purple-800) 55%,var(--purple-600));
}
.subpage-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 70% 30%,rgba(167,139,250,.4),transparent 60%),radial-gradient(ellipse at 10% 80%,rgba(76,29,149,.6),transparent 60%);
}
.subpage-hero::after{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:60px 60px;mask-image:radial-gradient(circle at center,#000,transparent 75%);
}
.subpage-hero .container{position:relative;z-index:2}
.breadcrumb{font-size:13px;opacity:.7;margin-bottom:18px;display:flex;gap:8px}
.breadcrumb a{opacity:.85;transition:opacity .2s}.breadcrumb a:hover{opacity:1}
.subpage-hero h1{
  font-size:clamp(42px,6vw,80px);line-height:1.04;letter-spacing:-.03em;font-weight:700;
  margin-bottom:24px;max-width:900px;
}
.subpage-hero .lead{font-size:18px;opacity:.85;max-width:620px;margin-bottom:36px;line-height:1.6}
.sub-cta{display:flex;gap:14px;flex-wrap:wrap}

.section-pad{padding:120px 0}
.alt-bg{background:var(--cream-2)}

.two-col{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.two-col.reverse{direction:rtl}.two-col.reverse > *{direction:ltr}
.two-col h2{font-size:clamp(28px,3.5vw,46px);line-height:1.08;letter-spacing:-.02em;margin-bottom:18px}
.two-col p{font-size:16px;opacity:.8;margin-bottom:14px}
.two-col .mini-list{list-style:none;margin-top:18px}
.two-col .mini-list li{padding:8px 0 8px 24px;position:relative;font-size:15px}
.two-col .mini-list li::before{content:"→";position:absolute;left:0;color:var(--purple-600);font-weight:700}

.visual{
  position:relative;border-radius:var(--radius-lg);
  background:linear-gradient(160deg,var(--purple-700),var(--purple-900));
  padding:32px;color:#fff;min-height:340px;
  box-shadow:0 40px 80px -30px rgba(76,29,149,.5);overflow:hidden;
}
.visual::after{
  content:"";position:absolute;inset:-40px;z-index:0;
  background:radial-gradient(circle at 30% 30%,rgba(167,139,250,.35),transparent 60%);
}
.visual > *{position:relative;z-index:1}

.example-chat{display:flex;flex-direction:column;gap:10px}
.msg{padding:12px 16px;border-radius:16px;max-width:85%;font-size:14.5px;line-height:1.5}
.msg.u{background:rgba(255,255,255,.14);align-self:flex-end;border-top-right-radius:4px}
.msg.a{background:#fff;color:var(--ink);align-self:flex-start;border-top-left-radius:4px}
.msg.wide{max-width:100%;width:100%}
.example-chat .demo-products{grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}
.example-chat .prod-meta{margin-bottom:3px}
.msg .who{font-size:11px;opacity:.6;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;font-weight:600}

.use-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:30px}
.use-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:26px;transition:all .35s var(--ease);
}
.use-card:hover{transform:translateY(-4px);border-color:var(--purple-300);box-shadow:0 20px 40px -20px rgba(109,40,217,.25)}
.use-card .emoji{font-size:28px;margin-bottom:12px;display:block}
.use-card h4{font-size:17px;font-weight:600;margin-bottom:6px}
.use-card p{font-size:14px;opacity:.75}
@media(max-width:680px){
  .use-grid.scroll-mobile{
    display:flex;flex-wrap:nowrap;
    overflow-x:auto;scroll-snap-type:x mandatory;
    gap:14px;margin-left:-28px;margin-right:-28px;
    padding:4px 28px 16px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
  }
  .use-grid.scroll-mobile::-webkit-scrollbar{display:none}
  .use-grid.scroll-mobile .use-card{flex:0 0 80%;scroll-snap-align:start}
}

.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;margin-top:40px}
.step{
  padding:28px;border-radius:var(--radius-md);background:var(--white);border:1px solid var(--line);
  position:relative;
}
.step-num{
  font-family:var(--serif);font-style:italic;font-size:44px;color:var(--purple-500);
  line-height:1;margin-bottom:12px;
}
.step h4{font-size:17px;margin-bottom:6px;font-weight:600}
.step p{font-size:14px;opacity:.75}

.faq{max-width:760px;margin:40px auto 0}
.faq details{
  border-bottom:1px solid var(--line);padding:20px 0;
}
.faq summary{
  cursor:pointer;list-style:none;font-size:17px;font-weight:600;
  display:flex;justify-content:space-between;align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--purple-600);font-size:22px;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:10px;opacity:.75;font-size:15px;line-height:1.6}

.code-block{
  background:var(--ink);color:#E9E4FF;border-radius:14px;padding:22px 26px;
  font-family:'SF Mono',Monaco,monospace;font-size:13.5px;line-height:1.7;overflow-x:auto;
}
.code-block .k{color:#C4B5FD}.code-block .s{color:#FDE68A}.code-block .c{color:#64748B;font-style:italic}

@media (max-width:820px){
  .two-col{grid-template-columns:1fr;gap:36px}
  .two-col.reverse{direction:ltr}
  .subpage-hero{padding:140px 0 70px}
  .section-pad{padding:70px 0}
}

/* ============ WIZARD ============ */
.wizard-wrap{
  min-height:100vh;
  background:
    radial-gradient(ellipse at 20% 0%,rgba(139,92,246,.18),transparent 45%),
    radial-gradient(ellipse at 90% 80%,rgba(124,58,237,.15),transparent 45%),
    var(--cream);
  padding:110px 0 80px;position:relative;overflow:hidden;
}
.wizard-inner{max-width:820px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
.wiz-back{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--ink-soft);opacity:.7;margin-bottom:30px;transition:opacity .2s}
.wiz-back:hover{opacity:1}

.wiz-progress{display:flex;align-items:center;gap:10px;margin-bottom:36px}
.wiz-step-dot{
  flex:1;height:4px;border-radius:999px;background:var(--purple-100);
  position:relative;overflow:hidden;
}
.wiz-step-dot::after{
  content:"";position:absolute;inset:0;width:0;
  background:linear-gradient(90deg,var(--purple-500),var(--purple-700));
  transition:width .5s var(--ease);
}
.wiz-step-dot.done::after{width:100%}
.wiz-step-dot.active::after{width:50%}
.wiz-counter{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);opacity:.7;font-weight:600;white-space:nowrap}

.wiz-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:48px;box-shadow:0 40px 100px -40px rgba(109,40,217,.2);
}
.wiz-eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--purple-700);font-weight:700;margin-bottom:12px}
.wiz-title{font-size:clamp(26px,3.5vw,38px);line-height:1.1;letter-spacing:-.02em;font-weight:700;margin-bottom:10px}
.wiz-sub{font-size:16px;opacity:.7;margin-bottom:32px}

.wiz-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:32px}
.wiz-option{
  position:relative;padding:22px 20px;border:1.5px solid var(--line);border-radius:16px;
  cursor:pointer;transition:all .25s var(--ease);background:var(--cream);
  display:flex;flex-direction:column;gap:6px;
}
.wiz-option:hover{border-color:var(--purple-400);background:var(--purple-50);transform:translateY(-2px)}
.wiz-option input{position:absolute;opacity:0;pointer-events:none}
.wiz-option input:checked + .wiz-opt-body{color:var(--purple-800)}
.wiz-option:has(input:checked){border-color:var(--purple-600);background:var(--purple-50);box-shadow:0 0 0 4px var(--purple-100)}
.wiz-opt-icon{font-size:26px;margin-bottom:6px}
.wiz-opt-title{font-weight:600;font-size:15.5px}
.wiz-opt-desc{font-size:13px;opacity:.7;line-height:1.5}
.wiz-opt-check{
  position:absolute;top:14px;right:14px;width:20px;height:20px;border-radius:50%;
  border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.wiz-option:has(input:checked) .wiz-opt-check{background:var(--purple-600);border-color:var(--purple-600)}
.wiz-opt-check::after{content:"";width:8px;height:8px;border-radius:50%;background:#fff;opacity:0;transition:opacity .2s}
.wiz-option:has(input:checked) .wiz-opt-check::after{opacity:1}

.wiz-fields{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}
.wiz-field{display:flex;flex-direction:column;gap:6px}
.wiz-field.full{grid-column:span 2}
.wiz-field label{font-size:13px;font-weight:600;color:var(--ink-soft)}
.wiz-field input,.wiz-field select,.wiz-field textarea{
  padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;
  font-family:var(--font);font-size:15px;background:var(--cream);color:var(--ink);
  transition:all .2s;
}
.wiz-field input:focus,.wiz-field select:focus,.wiz-field textarea:focus{
  outline:none;border-color:var(--purple-500);background:#fff;box-shadow:0 0 0 4px var(--purple-100);
}
.wiz-field textarea{min-height:90px;resize:vertical;font-family:var(--font)}
.wiz-field .hint{font-size:12px;opacity:.6}
.wiz-inline-btn{
  background:none;border:none;font-family:var(--font);font-size:12px;font-weight:600;
  color:var(--purple-700);cursor:pointer;margin-left:8px;padding:2px 8px;border-radius:6px;
  transition:background .2s;
}
.wiz-inline-btn:hover{background:var(--purple-100)}
.wiz-inline-btn:disabled{opacity:.5;cursor:wait}

/* Platform detect panel */
.wiz-detect{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .5s var(--ease),opacity .3s;
  margin-top:-8px;margin-bottom:0;
}
.wiz-detect.show{max-height:600px;opacity:1;margin-bottom:28px}
.wiz-detect-head{display:flex;gap:14px;align-items:flex-start;padding:22px 24px 16px;background:linear-gradient(135deg,var(--purple-50),#fff);border:1px solid var(--purple-200);border-radius:16px 16px 0 0;border-bottom:none}
.wiz-detect-icon{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-700));
  color:#fff;display:flex;align-items:center;justify-content:center;
}
.wiz-detect-icon svg{width:20px;height:20px;animation:spin 6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.wiz-detect-title{font-weight:700;font-size:15.5px;margin-bottom:2px}
.wiz-detect-sub{font-size:13px;opacity:.7}
.wiz-detect-row{display:flex;gap:10px;padding:0 24px 18px;background:linear-gradient(135deg,var(--purple-50),#fff);border-left:1px solid var(--purple-200);border-right:1px solid var(--purple-200)}
.wiz-detect-row input{
  flex:1;padding:12px 16px;border:1.5px solid var(--purple-200);border-radius:10px;
  font-family:var(--font);font-size:14.5px;background:#fff;color:var(--ink);transition:all .2s;
}
.wiz-detect-row input:focus{outline:none;border-color:var(--purple-500);box-shadow:0 0 0 4px var(--purple-100)}
.wiz-detect-row .btn{padding:12px 20px;font-size:14px;white-space:nowrap}
.wiz-detect-result:empty{display:none}
.wiz-detect-result{padding:16px 24px 20px;background:linear-gradient(135deg,var(--purple-50),#fff);border:1px solid var(--purple-200);border-top:none;border-radius:0 0 16px 16px}
.wiz-detect-loading{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--purple-800)}
.wiz-spin{width:14px;height:14px;border:2px solid var(--purple-200);border-top-color:var(--purple-600);border-radius:50%;animation:spin .8s linear infinite}
.wiz-detect-hit{display:flex;align-items:center;gap:14px;padding:14px;background:#fff;border-radius:12px;border:1px solid var(--purple-200)}
.wiz-detect-hit-icon{font-size:28px}
.wiz-detect-hit-body{flex:1}
.wiz-detect-hit-title{font-size:15px;margin-bottom:2px}
.wiz-detect-hit-title strong{color:var(--purple-700)}
.wiz-detect-hit-conf{font-size:12px;opacity:.6}
.wiz-detect-use{padding:10px 16px !important;font-size:13px !important}
.wiz-detect-foot{font-size:12px;opacity:.6;margin-top:10px;text-align:center}

.wiz-url-add{display:flex;gap:10px}
.wiz-url-add input{
  flex:1;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;
  font-family:var(--font);font-size:15px;background:var(--cream);color:var(--ink);transition:all .2s;
}
.wiz-url-add input:focus{outline:none;border-color:var(--purple-500);background:#fff;box-shadow:0 0 0 4px var(--purple-100)}
.wiz-url-btn{padding:14px 20px;white-space:nowrap;font-size:14px}
.wiz-url-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.wiz-url-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;background:var(--cream);border:1px solid var(--line);border-radius:10px;
}
.wiz-url-ico{font-size:16px}
.wiz-url-body{flex:1;min-width:0}
.wiz-url-host{font-size:13.5px;font-weight:600;color:var(--purple-700)}
.wiz-url-full{font-size:12px;opacity:.55;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wiz-url-row .rm{color:var(--ink-soft);cursor:pointer;opacity:.5;padding:2px 8px;font-size:13px}
.wiz-url-row .rm:hover{opacity:1;color:#DC2626}

.wiz-dropzone{
  border:2px dashed var(--purple-200);border-radius:16px;padding:36px;text-align:center;
  background:var(--purple-50);transition:all .2s;cursor:pointer;
}
.wiz-dropzone:hover{border-color:var(--purple-500);background:var(--purple-100)}
.wiz-dropzone .drop-icon{font-size:30px;margin-bottom:8px}
.wiz-dropzone h5{font-size:15px;font-weight:600;margin-bottom:4px}
.wiz-dropzone p{font-size:13px;opacity:.7}
.wiz-files{margin-top:14px;display:flex;flex-direction:column;gap:6px}
.wiz-file{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 14px;background:var(--cream);border:1px solid var(--line);border-radius:10px;
  font-size:13.5px;
}
.wiz-file .rm{color:var(--ink-soft);cursor:pointer;opacity:.5;padding:2px 8px}
.wiz-file .rm:hover{opacity:1;color:#DC2626}

.wiz-plans{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:32px}
.wiz-plan{
  position:relative;padding:24px;border:1.5px solid var(--line);border-radius:16px;
  cursor:pointer;transition:all .25s var(--ease);background:var(--cream);
}
.wiz-plan:hover{border-color:var(--purple-400);transform:translateY(-2px)}
.wiz-plan input{position:absolute;opacity:0;pointer-events:none}
.wiz-plan:has(input:checked){border-color:var(--purple-600);background:var(--purple-50);box-shadow:0 0 0 4px var(--purple-100)}
.wiz-plan-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.wiz-plan-name{font-weight:700;font-size:16px}
.wiz-plan-price{font-size:22px;font-weight:700;color:var(--purple-700)}
.wiz-plan-price span{font-size:12px;opacity:.6;font-weight:500}
.wiz-plan ul{list-style:none;font-size:13px;opacity:.8}
.wiz-plan li{padding:3px 0;padding-left:18px;position:relative}
.wiz-plan li::before{content:"✓";position:absolute;left:0;color:var(--purple-600);font-weight:700}
.wiz-plan-tag{position:absolute;top:-10px;right:18px;background:var(--purple-600);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.08em;text-transform:uppercase}

.wiz-nav{display:flex;justify-content:space-between;gap:12px;align-items:center;padding-top:8px;border-top:1px solid var(--line);margin-top:8px;padding-top:28px}
.wiz-err{color:#DC2626;font-size:13px;opacity:0;transition:opacity .2s}
.wiz-err.show{opacity:1}
.wiz-step{display:none;animation:fadeSlide .45s var(--ease)}
.wiz-step.active{display:block}
@keyframes fadeSlide{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Agent personality step */
.wiz-profiles{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:26px}
.wiz-profile{
  position:relative;padding:14px 8px;border:1.5px solid var(--line);border-radius:14px;
  background:var(--cream);cursor:pointer;transition:all .2s var(--ease);
  display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center;
}
.wiz-profile input{position:absolute;opacity:0;pointer-events:none}
.wiz-profile:hover{border-color:var(--purple-300);transform:translateY(-2px)}
.wiz-profile:has(input:checked){border-color:var(--purple-600);background:var(--purple-50);box-shadow:0 0 0 4px var(--purple-100)}
.pf-ava{font-size:28px;line-height:1;margin-bottom:4px}
.pf-n{font-size:13px;font-weight:700}
.pf-r{font-size:11px;opacity:.65}

.wiz-profile-info{
  background:linear-gradient(135deg,var(--purple-50),#fff);
  border:1px solid var(--purple-200);border-radius:14px;
  padding:18px 22px;margin-bottom:24px;
  animation:fadeSlide .35s var(--ease);
}
.pi-head{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}
.pi-head strong{font-size:16px;color:var(--purple-800)}
.pi-role{font-size:12px;color:var(--purple-700);background:var(--purple-100);padding:2px 8px;border-radius:999px;font-weight:600;letter-spacing:.04em}
.pi-desc{font-size:14px;opacity:.8;margin-bottom:10px;line-height:1.5}
.pi-bullets{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:4px}
.pi-bullets li{font-size:13px;padding:3px 0 3px 20px;position:relative;opacity:.85}
.pi-bullets li::before{content:"✓";position:absolute;left:0;color:var(--purple-600);font-weight:700}

/* Advanced settings collapsible */
.wiz-advanced{
  margin-top:8px;border:1px solid var(--line);border-radius:14px;
  background:var(--cream);overflow:hidden;
}
.wiz-advanced summary{
  cursor:pointer;list-style:none;
  display:flex;align-items:center;gap:12px;padding:16px 20px;
  font-size:14px;font-weight:600;transition:background .2s;
}
.wiz-advanced summary::-webkit-details-marker{display:none}
.wiz-advanced summary:hover{background:var(--purple-50)}
.adv-icon{
  width:30px;height:30px;border-radius:8px;background:var(--purple-100);color:var(--purple-700);
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.adv-label{font-weight:700}
.adv-hint{font-size:12px;font-weight:400;opacity:.6;margin-left:4px}
.adv-arrow{margin-left:auto;color:var(--purple-600);transition:transform .3s var(--ease);font-size:14px}
.wiz-advanced[open] .adv-arrow{transform:rotate(180deg)}
.wiz-advanced[open]{background:#fff}
.wiz-advanced > *:not(summary){padding:0 20px 4px}
.wiz-advanced[open] > *:not(summary){animation:fadeSlide .4s var(--ease)}

.wiz-sliders{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;margin-bottom:26px}
.wiz-sliders label{display:grid;grid-template-columns:140px 1fr 36px;align-items:center;gap:12px;font-size:13.5px;font-weight:500}
.wiz-sliders input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;
  background:linear-gradient(90deg,var(--purple-500),var(--purple-300));
  outline:none;cursor:pointer;
}
.wiz-sliders input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--white);border:2px solid var(--purple-600);cursor:pointer;
  box-shadow:0 2px 6px rgba(124,58,237,.4);transition:transform .15s;
}
.wiz-sliders input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.wiz-sliders input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--purple-600);cursor:pointer}
.wiz-sliders output{font-size:12px;font-weight:600;color:var(--purple-700);text-align:right;font-variant-numeric:tabular-nums}

.wiz-prompt-wrap{margin-bottom:20px}
.wiz-prompt{
  background:var(--ink);color:#C4B5FD;padding:18px 22px;border-radius:14px;
  font-family:'SF Mono',Monaco,Consolas,monospace;font-size:12.5px;line-height:1.6;
  white-space:pre-wrap;margin:0;max-height:240px;overflow-y:auto;
  border:1px solid rgba(124,58,237,.3);
}

@media (max-width:720px){
  .wiz-profiles{grid-template-columns:repeat(3,1fr)}
  .wiz-sliders{grid-template-columns:1fr}
  .wiz-sliders label{grid-template-columns:110px 1fr 30px}
}

/* Success step */
.wiz-success{text-align:center}
.wiz-success-icon{
  width:80px;height:80px;border-radius:50%;margin:0 auto 20px;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-700));color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:40px;
  box-shadow:0 20px 40px -15px rgba(124,58,237,.6);
  animation:pop .5s var(--ease);
}
@keyframes pop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
.wiz-apikey{
  font-family:'SF Mono',monospace;font-size:13.5px;
  background:var(--ink);color:#C4B5FD;
  padding:14px 18px;border-radius:12px;
  display:flex;justify-content:space-between;align-items:center;margin:20px 0;
  text-align:left;
}
.wiz-copy{background:rgba(255,255,255,.1);color:#fff;border:none;padding:6px 12px;border-radius:8px;cursor:pointer;font-family:var(--font);font-size:12px}
.wiz-copy:hover{background:rgba(255,255,255,.2)}
.wiz-next-steps{text-align:left;margin-top:28px;background:var(--purple-50);border-radius:16px;padding:24px;border:1px solid var(--purple-200)}
.wiz-next-steps h4{font-size:15px;margin-bottom:14px;color:var(--purple-800)}
.wiz-next-steps ol{list-style:none;counter-reset:s}
.wiz-next-steps li{counter-increment:s;padding:8px 0 8px 36px;position:relative;font-size:14px}
.wiz-next-steps li::before{
  content:counter(s);position:absolute;left:0;top:6px;
  width:24px;height:24px;border-radius:50%;
  background:var(--purple-600);color:#fff;font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}

.wiz-summary{text-align:left;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:20px;margin:20px 0}
.wiz-summary-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px}
.wiz-summary-row span:first-child{opacity:.6}
.wiz-summary-row span:last-child{font-weight:600}

@media (max-width:640px){
  .wiz-card{padding:32px 22px}
  .wiz-fields,.wiz-plans{grid-template-columns:1fr}
  .wiz-field.full{grid-column:span 1}
}

/* ============ PLATFORM ============ */
.platform{position:relative;padding:140px 0;color:var(--white);overflow:hidden}
.platform-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(circle at 20% 20%,var(--purple-600) 0%,transparent 40%),
    radial-gradient(circle at 80% 80%,var(--purple-800) 0%,transparent 50%),
    linear-gradient(135deg,var(--purple-950),var(--purple-800) 60%,var(--purple-700));
}
.platform-bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(circle at center,#000,transparent 70%);
}
.platform .container{position:relative;z-index:1}
.dashboard-wrap{
  position:relative;max-width:1000px;margin:0 auto 80px;
  border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 60px 120px -30px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.05) inset;
  background:rgba(255,255,255,.02);backdrop-filter:blur(20px);
}
.dash-glow{
  position:absolute;inset:-60px;z-index:-1;
  background:radial-gradient(ellipse,rgba(167,139,250,.4),transparent 60%);filter:blur(40px);
}
.dash-img{width:100%;height:100%;display:block;object-fit:cover;object-position:center top}

/* === Dashboard mockup === */
.dash-mock{
  display:grid;grid-template-columns:200px 1fr;
  background:#fff;color:var(--ink);
  font-size:13px;line-height:1.4;min-height:600px;
}
.dash-side{
  background:#FAFAF7;border-right:1px solid var(--line);
  padding:18px 14px;display:flex;flex-direction:column;gap:2px;
}
.dash-logo{display:flex;align-items:center;gap:8px;padding:4px 6px 18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.dash-logo-mark{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-700));
  color:#fff;display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-size:17px;font-weight:500;
}
.dash-logo-text{font-weight:700;font-size:14px;letter-spacing:-.01em;color:var(--ink)}
.dash-nav{display:flex;flex-direction:column;gap:2px;flex:1}
.dash-nav a{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:8px;font-size:12.5px;font-weight:500;
  color:var(--ink-soft);cursor:pointer;transition:all .2s var(--ease);
}
.dash-nav a:hover{background:rgba(109,40,217,.06);color:var(--ink)}
.dash-nav a.active{
  background:linear-gradient(135deg,var(--purple-600),var(--purple-700));
  color:#fff;box-shadow:0 6px 14px -6px rgba(109,40,217,.5);
}
.dash-nav a.active .dash-ico{opacity:1}
.dash-ico{display:inline-grid;place-items:center;width:16px;font-size:13px;opacity:.65}
.dash-badge{
  margin-left:auto;background:var(--purple-100,#EDE9FE);color:var(--purple-700);
  font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;
}
.dash-nav a.active .dash-badge{background:rgba(255,255,255,.2);color:#fff}
.dash-lang{
  margin-top:14px;padding:8px 10px;border-radius:8px;
  background:#fff;border:1px solid var(--line);font-size:12px;
  color:var(--ink-soft);display:flex;align-items:center;gap:6px;
}

.dash-main{padding:22px 26px;display:flex;flex-direction:column;gap:16px;overflow:hidden}
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}
.dash-h1{font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.dash-hello{font-size:12.5px;color:var(--ink-soft);opacity:.7;margin-top:2px}
.dash-range{
  padding:7px 12px;border:1px solid var(--line);border-radius:8px;
  font-size:11.5px;color:var(--ink-soft);background:#fff;white-space:nowrap;
}

.dash-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);padding-bottom:0}
.dash-tabs span{
  padding:7px 14px;font-size:12.5px;font-weight:500;
  color:var(--ink-soft);opacity:.65;cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
}
.dash-tabs span.active{color:var(--purple-700);opacity:1;border-bottom-color:var(--purple-600);font-weight:600}

.dash-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.dash-kpi{
  padding:14px;background:#fff;border:1px solid var(--line);border-radius:12px;
  display:flex;flex-direction:column;gap:4px;
}
.dash-kpi-label{font-size:11px;color:var(--ink-soft);opacity:.7;letter-spacing:.02em}
.dash-kpi-val{font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.dash-kpi-delta{font-size:11px;font-weight:600}
.dash-kpi-delta.up{color:#10B981}
.dash-kpi-delta.down{color:#EF4444}
.dash-kpi{transition:box-shadow .4s var(--ease),background .4s var(--ease)}
.dash-kpi.dash-flash{
  animation:dashFlash 1.2s var(--ease);
}
@keyframes dashFlash{
  0%{box-shadow:0 0 0 0 rgba(139,92,246,0);background:#fff}
  30%{box-shadow:0 0 0 3px rgba(139,92,246,.18);background:rgba(237,233,254,.5)}
  100%{box-shadow:0 0 0 0 rgba(139,92,246,0);background:#fff}
}
.dash-live{
  display:inline-flex;align-items:center;gap:4px;margin-left:6px;
  font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#10B981;opacity:.9;
}
.dash-live-dot{
  width:6px;height:6px;border-radius:50%;background:#10B981;
  animation:dashLivePulse 1.6s ease-in-out infinite;
}
@keyframes dashLivePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.6);opacity:1}
  50%{box-shadow:0 0 0 5px rgba(16,185,129,0);opacity:.8}
}
#dashChartLine,#dashChartFill{transition:d .6s var(--ease)}
#dashChartDot{transition:cx .6s var(--ease),cy .6s var(--ease)}

.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dash-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dash-card{
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;display:flex;flex-direction:column;gap:10px;
}
.dash-card-head{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;font-weight:600;color:var(--ink)}
.dash-card-sub{font-size:10.5px;font-weight:500;color:var(--ink-soft);opacity:.6;letter-spacing:.04em;text-transform:uppercase}

.dash-bars{display:flex;flex-direction:column;gap:7px}
.dash-bar{display:grid;grid-template-columns:120px 1fr 40px;align-items:center;gap:10px;font-size:11.5px}
.dash-bar-lbl{color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-bar-track{height:6px;background:var(--cream);border-radius:999px;overflow:hidden}
.dash-bar-fill{
  height:100%;border-radius:999px;width:0;
  background:linear-gradient(90deg,var(--purple-400,#A78BFA),var(--purple-600));
  transition:width .8s var(--ease);
}
.dash-bar-num{font-weight:600;color:var(--ink);text-align:right;font-variant-numeric:tabular-nums;font-size:11.5px}

.dash-chart{width:100%;height:140px;display:block}
.dash-chart-foot{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-soft);opacity:.5;padding:0 2px}

.dash-tags,.dash-missing{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.dash-tags li{
  display:flex;justify-content:space-between;align-items:center;
  padding:7px 10px;border-radius:8px;background:rgba(16,185,129,.08);
  font-size:12px;color:var(--ink);
}
.dash-tags.alt li{background:rgba(239,68,68,.08)}
.dash-tags li em{font-style:normal;font-weight:700;font-variant-numeric:tabular-nums}
.dash-tags li em{color:#059669}
.dash-tags.alt li em{color:#DC2626}
.dash-missing li{
  padding:7px 10px;border-radius:8px;background:rgba(245,158,11,.08);
  font-size:12px;color:var(--ink);border-left:2px solid #F59E0B;
}

/* Tab panels in the dashboard illustration */
.dash-main .dash-tab-panel{display:flex;flex-direction:column;gap:16px}
.dash-main .dash-tab-panel[hidden]{display:none}

/* Donut (Temaer) */
.dash-donut-wrap{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:center}
.dash-donut{position:relative;width:150px;height:150px}
.dash-donut svg{transform:rotate(-90deg);width:100%;height:100%}
.dash-donut circle{fill:none;stroke-width:18;transition:stroke-dashoffset 1s var(--ease)}
.dash-donut .donut-bg{stroke:var(--cream)}
.dash-donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.dash-donut-center .num{font-size:22px;font-weight:700;letter-spacing:-.01em;line-height:1;color:var(--ink)}
.dash-donut-center .lbl{font-size:10px;color:var(--ink-soft);opacity:.7;letter-spacing:.06em;text-transform:uppercase;margin-top:3px}
.dash-legend{display:flex;flex-direction:column;gap:7px}
.dash-legend-row{display:grid;grid-template-columns:12px 1fr auto auto;gap:8px;align-items:center;font-size:11.5px;color:var(--ink)}
.dash-legend-dot{width:9px;height:9px;border-radius:3px}
.dash-legend-pct{font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink-soft);min-width:34px;text-align:right}
.dash-legend-num{font-size:10.5px;color:var(--ink-soft);opacity:.6;font-variant-numeric:tabular-nums}

/* Trend list (Temaer) */
.dash-trend{display:flex;flex-direction:column;gap:5px}
.dash-trend-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:8px 10px;border-radius:8px;background:var(--cream);font-size:11.5px;color:var(--ink)}
.dash-trend-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-trend-count{font-variant-numeric:tabular-nums;color:var(--ink-soft);font-size:11px}
.dash-trend-pill{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:999px;font-variant-numeric:tabular-nums}
.dash-trend-pill.up{background:rgba(16,185,129,.13);color:#059669}
.dash-trend-pill.down{background:rgba(239,68,68,.12);color:#DC2626}
.dash-trend-pill.flat{background:var(--cream-2,#F1ECE0);color:var(--ink-soft)}

/* Cluster table (Temaer) */
.dash-cluster{display:grid;grid-template-columns:1.4fr 70px 70px 80px;gap:8px;align-items:center;padding:9px 6px;font-size:11.5px;color:var(--ink);border-bottom:1px dashed var(--line)}
.dash-cluster:last-child{border-bottom:0}
.dash-cluster-head{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);opacity:.6}
.dash-cluster-name{display:flex;align-items:center;gap:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-cluster-tag{font-size:9px;font-weight:600;padding:1px 6px;border-radius:999px;background:var(--purple-100,#EDE9FE);color:var(--purple-700);letter-spacing:.04em}
.dash-cluster-tag.new{background:rgba(16,185,129,.13);color:#059669}
.dash-cluster-num{font-variant-numeric:tabular-nums;text-align:right;color:var(--ink-soft)}
.dash-sentiment{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600}
.dash-sentiment.pos{color:#059669}
.dash-sentiment.neg{color:#DC2626}
.dash-sentiment.mid{color:#B45309}

/* Rating distribution (Ytelse) */
.dash-rate{display:flex;flex-direction:column;gap:2px}
.dash-rate-row{display:grid;grid-template-columns:54px 1fr 44px;align-items:center;gap:10px;padding:5px 0;font-size:11.5px}
.dash-rate-stars{color:#F59E0B;letter-spacing:.5px;font-size:11px}
.dash-rate-track{height:8px;background:var(--cream);border-radius:999px;overflow:hidden}
.dash-rate-fill{height:100%;border-radius:999px;width:0;background:linear-gradient(90deg,#F59E0B,#D97706);transition:width 1s var(--ease)}
.dash-rate-row.s5 .dash-rate-fill,.dash-rate-row.s4 .dash-rate-fill{background:linear-gradient(90deg,#10B981,#059669)}
.dash-rate-row.s2 .dash-rate-fill,.dash-rate-row.s1 .dash-rate-fill{background:linear-gradient(90deg,#EF4444,#DC2626)}
.dash-rate-pct{font-weight:600;font-variant-numeric:tabular-nums;text-align:right;color:var(--ink-soft)}

/* Performance cards (Ytelse) */
.dash-perf{display:flex;flex-direction:column;gap:6px}
.dash-perf-card{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:9px 10px;border-radius:8px;background:var(--cream);font-size:11.5px}
.dash-perf-icon{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;background:rgba(16,185,129,.13);color:#059669;font-size:11px}
.dash-perf-icon.down{background:rgba(239,68,68,.12);color:#DC2626}
.dash-perf-body strong{font-weight:600;color:var(--ink)}
.dash-perf-score{font-weight:700;font-variant-numeric:tabular-nums}
.dash-perf-score.up{color:#059669}
.dash-perf-score.down{color:#DC2626}
.dash-src-meta{font-size:10.5px;color:var(--ink-soft);opacity:.7}

/* Source table (Kilder) */
.dash-src-row{display:grid;grid-template-columns:30px 1.8fr 70px 50px 80px 72px;gap:10px;align-items:center;padding:9px 6px;font-size:11.5px;color:var(--ink);border-bottom:1px dashed var(--line)}
.dash-src-row:last-child{border-bottom:0}
.dash-src-head{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);opacity:.6}
.dash-src-ico{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--purple-100,#EDE9FE);color:var(--purple-700);font-size:13px;font-weight:600}
.dash-src-ico.web{background:rgba(59,130,246,.12);color:#1D4ED8}
.dash-src-ico.notion{background:#F3F4F6;color:#374151}
.dash-src-ico.csv{background:rgba(16,185,129,.13);color:#059669}
.dash-src-name{display:flex;flex-direction:column;gap:1px;min-width:0}
.dash-src-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-src-type{font-size:11px;color:var(--ink-soft)}
.dash-src-num{font-variant-numeric:tabular-nums;color:var(--ink-soft);font-size:11px}
.dash-pill{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:999px}
.dash-pill.ok{background:rgba(16,185,129,.13);color:#059669}
.dash-pill.sync{background:rgba(59,130,246,.12);color:#1D4ED8}
.dash-pill.warn{background:rgba(245,158,11,.15);color:#B45309}
.dash-pill.err{background:rgba(239,68,68,.13);color:#DC2626}
.dash-pill-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.dash-pill.sync .dash-pill-dot{animation:dashLivePulse 1.4s ease-in-out infinite}

/* Coverage bars (Kilder) */
.dash-coverage{display:flex;flex-direction:column;gap:9px}
.dash-cov-row{display:grid;grid-template-columns:1fr auto;gap:10px;font-size:11.5px;color:var(--ink)}
.dash-cov-bar{height:6px;background:var(--cream);border-radius:999px;overflow:hidden;margin-top:4px}
.dash-cov-fill{height:100%;border-radius:999px;width:0;background:linear-gradient(90deg,var(--purple-400,#A78BFA),var(--purple-600));transition:width .9s var(--ease)}
.dash-cov-fill.low{background:linear-gradient(90deg,#FBBF24,#F59E0B)}
.dash-cov-fill.crit{background:linear-gradient(90deg,#F87171,#EF4444)}
.dash-cov-pct{font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink-soft);font-size:11px}

@media (max-width:760px){
  .dash-mock{grid-template-columns:1fr;min-height:auto}
  .dash-side{display:none}
  .dash-main{padding:18px}
  .dash-kpis{grid-template-columns:repeat(2,1fr)}
  .dash-grid,.dash-grid-3{grid-template-columns:1fr}
  .dash-donut-wrap{grid-template-columns:1fr;justify-items:center}
  .dash-tabs{overflow-x:auto}
  .dash-src-row{grid-template-columns:26px 1.6fr 50px 60px}
  .dash-src-row span:nth-child(5){display:none}
}
.dashboard-wrap{aspect-ratio:auto}

.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;max-width:1000px;margin:0 auto}
.feat{padding:28px;border-radius:var(--radius-md);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px)}
.feat-num{font-family:var(--serif);font-size:38px;color:var(--purple-300);margin-bottom:8px;font-style:italic}
.feat h4{font-size:18px;margin-bottom:8px;font-weight:600}
.feat p{font-size:14px;opacity:.75}

/* ============ DEMO ============ */
.demo-section{padding:140px 0;background:var(--cream-2);position:relative}
.demo-card{
  max-width:820px;margin:0 auto;
  background:var(--white);border-radius:var(--radius-lg);
  box-shadow:0 40px 80px -30px rgba(76,29,149,.3);
  border:1px solid var(--line);
  overflow:hidden;
}
.demo-bar{
  display:flex;align-items:center;gap:8px;
  padding:14px 18px;background:var(--cream);border-bottom:1px solid var(--line);
}
.dot{width:10px;height:10px;border-radius:50%}
.dot.r{background:#FF5F57}.dot.y{background:#FEBC2E}.dot.g{background:#28C840}
.url{margin-left:18px;font-size:13px;color:var(--ink-soft);opacity:.7}
.demo-body{padding:40px}
.demo-search{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;border:1.5px solid var(--purple-200);border-radius:16px;
  background:var(--purple-50);color:var(--purple-700);
  font-size:17px;font-weight:500;
}
.demo-search svg{width:20px;height:20px;flex-shrink:0}
.typing{color:var(--ink)}
.caret{color:var(--purple-600);animation:blink 1s infinite}
@keyframes blink{50%{opacity:0}}
.demo-result{margin-top:22px;padding:22px;background:var(--cream);border-radius:16px;border:1px solid var(--line)}
.demo-result-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--purple-600);font-weight:600;margin-bottom:10px}
.demo-result p{font-size:16px;margin-bottom:10px;min-height:4.8em;line-height:1.5}
@media (max-width:620px){.demo-result p{min-height:6em}}
.demo-link{color:var(--purple-700);font-weight:600;font-size:14px;display:inline-block;margin-top:4px}

/* Product cards in demo */
.demo-products{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0 14px;
}
.prod-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:all .3s var(--ease);display:flex;flex-direction:column;
}
.prod-card:hover{transform:translateY(-4px);border-color:var(--purple-300);box-shadow:0 16px 32px -16px rgba(109,40,217,.25)}
.prod-img{
  position:relative;aspect-ratio:4/5;overflow:hidden;background:#F3F4F6;
}
.jacket{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.prod-card:hover .jacket{transform:scale(1.04)}
.prod-tag{
  position:absolute;top:8px;left:8px;z-index:2;
  background:#fff;color:var(--purple-700);
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;
}
.prod-tag.sale{background:var(--purple-700);color:#fff}
.prod-info{padding:10px 12px 12px}
.prod-name{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px;line-height:1.25}
.prod-meta{font-size:11px;color:var(--ink-soft);opacity:.65;margin-bottom:4px}
.prod-price{font-size:13px;font-weight:700;color:var(--purple-700)}

@media (max-width:620px){
  .demo-products{grid-template-columns:repeat(2,1fr)}
}

/* Office / location cards in demo */
.demo-offices{
  display:none;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0 14px;
}
.office-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:all .3s var(--ease);display:flex;flex-direction:column;
}
.office-card:hover{transform:translateY(-4px);border-color:var(--purple-300);box-shadow:0 16px 32px -16px rgba(109,40,217,.25)}
.office-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#F3F4F6}
.office-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.office-card:hover .office-img img{transform:scale(1.04)}
.office-status{
  position:absolute;top:8px;left:8px;z-index:2;
  display:inline-flex;align-items:center;gap:5px;
  background:#fff;color:var(--ink);
  font-size:10px;font-weight:700;letter-spacing:.04em;
  padding:3px 9px 3px 7px;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.office-status::before{content:"";width:6px;height:6px;border-radius:50%;background:#22C55E;box-shadow:0 0 0 3px rgba(34,197,94,.18)}
.office-map{
  position:absolute;bottom:8px;right:8px;z-index:2;
  display:inline-flex;align-items:center;gap:4px;
  background:var(--purple-700);color:#fff;
  font-size:10.5px;font-weight:700;
  padding:5px 9px;border-radius:999px;box-shadow:0 6px 16px -6px rgba(76,29,149,.6);
  transform:translateY(4px);opacity:0;transition:all .3s var(--ease);
}
.office-card:hover .office-map{transform:translateY(0);opacity:1}
.office-info{padding:10px 12px 12px}
.office-name{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px;line-height:1.25}
.office-meta{
  font-size:11px;color:var(--ink-soft);opacity:.65;margin-bottom:4px;line-height:1.35;
  min-height:2.7em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.office-hours{font-size:12px;font-weight:700;color:var(--purple-700)}

@media (max-width:620px){
  .demo-offices{grid-template-columns:repeat(2,1fr)}
}

/* ============ TRENING / TRAIN THE AI ============ */
.train{padding:140px 0;background:var(--cream);position:relative}
.train-layout{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center;max-width:1140px;margin:0 auto}

/* Steps */
.train-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.train-step{
  display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;
  padding:20px;border-radius:var(--radius-md);
  background:var(--white);border:1px solid var(--line);
  cursor:pointer;transition:all .35s var(--ease);
}
.train-step:hover{border-color:var(--purple-200)}
.train-step.active{
  border-color:var(--purple-300);
  box-shadow:0 24px 48px -28px rgba(109,40,217,.4);
  background:linear-gradient(180deg,var(--white),var(--purple-50));
}
.train-step-ico{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:var(--purple-100);color:var(--purple-700);font-size:19px;
  transition:all .35s var(--ease);
}
.train-step.active .train-step-ico{
  background:linear-gradient(135deg,var(--purple-600),var(--purple-700));color:#fff;
  box-shadow:0 8px 18px -6px rgba(109,40,217,.55);
}
.train-step-txt h4{font-size:16.5px;font-weight:700;letter-spacing:-.01em;margin-bottom:5px;color:var(--ink)}
.train-step-txt p{font-size:14px;line-height:1.55;color:var(--ink-soft);opacity:.82}
.train-step-txt em{font-style:italic;font-weight:600;color:var(--purple-700);opacity:1}

/* Stage / window */
.train-stage{position:relative}
.train-win{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);
  overflow:hidden;box-shadow:0 40px 80px -40px rgba(76,29,149,.4);
}
.train-win-bar{
  display:flex;align-items:center;gap:7px;
  padding:12px 16px;border-bottom:1px solid var(--line);background:var(--cream);
}
.train-win-bar .dot{width:11px;height:11px;border-radius:50%}
.train-win-bar .dot.r{background:#FF5F57}.train-win-bar .dot.y{background:#FEBC2E}.train-win-bar .dot.g{background:#28C840}
.train-win-title{margin-left:8px;font-size:12px;font-weight:600;color:var(--ink-soft);opacity:.7}
.train-win-body{position:relative;height:340px;padding:22px}

/* Scenes */
.train-scene{
  position:absolute;inset:22px;display:flex;flex-direction:column;gap:14px;
  opacity:0;transform:translateY(10px);pointer-events:none;
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.train-scene.active{opacity:1;transform:none;pointer-events:auto}
@keyframes trainUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.train-scene.play > *{animation:trainUp .5s var(--ease) both}
.train-scene.play > *:nth-child(2){animation-delay:.5s}
.train-scene.play > *:nth-child(3){animation-delay:1s}
.train-scene.play > *:nth-child(4){animation-delay:1.5s}

/* Scene 0 — sync */
.train-url{
  display:flex;align-items:center;gap:10px;position:relative;overflow:hidden;
  padding:11px 14px;border-radius:10px;background:var(--cream);border:1px solid var(--line);
}
.train-url svg{width:16px;height:16px;color:var(--purple-600);flex-shrink:0}
.train-url-text{font-size:13.5px;font-weight:600;color:var(--ink)}
.train-scan{position:absolute;top:0;left:-40%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(139,92,246,.18),transparent)}
.train-scene.play .train-scan{animation:trainScan 1.8s var(--ease) .2s 2}
@keyframes trainScan{from{left:-40%}to{left:120%}}
.train-pages{display:flex;flex-direction:column;gap:8px}
.train-page{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 13px;border-radius:9px;background:var(--white);border:1px solid var(--line);
  font-size:13px;color:var(--ink-soft);
}
.train-page-name{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.train-check{
  width:20px;height:20px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:rgba(16,185,129,.13);color:#059669;font-size:12px;font-weight:700;
}
.train-scene-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.train-badge{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12px;font-weight:600;color:var(--purple-700);
  background:var(--purple-100);padding:6px 12px;border-radius:999px;
}
.train-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--purple-600);animation:dashLivePulse 1.6s ease-in-out infinite}
.train-foot-stat{font-size:12.5px;font-weight:600;color:#059669}

/* Scene 1 — interview */
.train-gap{
  align-self:flex-start;font-size:12px;font-weight:600;color:#B45309;
  background:rgba(245,158,11,.13);padding:6px 12px;border-radius:999px;
}
.train-chat{display:flex;flex-direction:column;gap:10px}
.tmsg{max-width:86%;padding:12px 14px;border-radius:16px;font-size:13.5px;line-height:1.5}
.tmsg-who{display:block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;opacity:.5;margin-bottom:4px}
.tmsg.ai{align-self:flex-start;background:var(--white);border:1px solid var(--line);border-top-left-radius:5px;color:var(--ink)}
.tmsg.u{align-self:flex-end;background:linear-gradient(160deg,var(--purple-100),var(--purple-50));border:1px solid var(--purple-200);border-top-right-radius:5px;color:var(--ink)}
.tmsg.tmsg-confirm{color:#059669;font-weight:600;border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.06)}

/* Scene 2 — learn from misses */
.train-miss{padding:14px 16px;border-radius:12px;background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.2);border-left:3px solid #EF4444}
.train-miss-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.train-miss-tag{font-size:11.5px;font-weight:700;color:#DC2626}
.train-miss-count{font-size:11.5px;font-weight:600;color:var(--ink-soft);opacity:.7;font-variant-numeric:tabular-nums}
.train-miss-q{font-size:15px;font-weight:600;color:var(--ink)}
.train-answer{padding:14px 16px;border-radius:12px;background:var(--cream);border:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.train-answer-label{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--purple-700);opacity:.8}
.train-answer-field{min-height:42px;padding:10px 12px;border-radius:9px;background:var(--white);border:1px solid var(--line);font-size:13.5px;color:var(--ink);line-height:1.5}
.train-caret{display:inline-block;width:1.5px;height:1em;background:var(--purple-600);vertical-align:text-bottom;margin-left:1px;animation:trainBlink 1s step-end infinite}
@keyframes trainBlink{50%{opacity:0}}
.train-answer-btn{
  align-self:flex-start;font:inherit;font-size:13px;font-weight:700;cursor:pointer;
  padding:9px 18px;border-radius:10px;border:none;
  background:linear-gradient(135deg,var(--purple-600),var(--purple-700));color:#fff;
  box-shadow:0 8px 20px -8px rgba(109,40,217,.6);transition:transform .25s var(--ease)}
.train-answer-btn:hover{transform:translateY(-1px)}
.train-cover{margin-top:auto;display:flex;flex-direction:column;gap:7px}
.train-cover-row{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--ink-soft)}
.train-cover-pct{font-variant-numeric:tabular-nums}
.train-cover-from{opacity:.55;text-decoration:line-through}
.train-cover-to{color:#059669}
.train-cover-bar{height:7px;background:var(--cream-2);border-radius:999px;overflow:hidden}
.train-cover-fill{height:100%;width:86%;border-radius:999px;background:linear-gradient(90deg,var(--purple-400),var(--purple-600));transition:width 1.1s var(--ease)}
.train-scene.active .train-cover-fill{width:91%}

@media (max-width:860px){
  .train-layout{grid-template-columns:1fr;gap:28px}
  .train-win-body{height:320px}
}

/* ============ BOOKING DEMO (CHAT PAGE) ============ */
.booking-mock{max-width:760px}
.booking-body{padding:24px;display:flex;flex-direction:column;gap:14px}
.booking-scroll{display:flex;flex-direction:column;gap:14px;max-height:540px;overflow-y:auto;padding-right:6px}
.booking-scroll::-webkit-scrollbar{width:6px}
.booking-scroll::-webkit-scrollbar-thumb{background:var(--purple-200);border-radius:999px}
.bk-msg{max-width:88%;padding:14px 16px;border-radius:18px;font-size:14.5px;line-height:1.5;animation:bkFadeIn .45s var(--ease) both}
.bk-msg.u{align-self:flex-end;background:linear-gradient(160deg,var(--purple-100),var(--purple-50));color:var(--ink);border-top-right-radius:6px;border:1px solid var(--purple-200);max-width:78%}
.bk-msg.a{align-self:flex-start;background:var(--white);color:var(--ink);border-top-left-radius:6px;border:1px solid var(--line);box-shadow:0 4px 18px -10px rgba(76,29,149,.2)}
.bk-who{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;opacity:.55;margin-bottom:6px}
.bk-msg p{margin:0 0 4px}
.bk-hidden{display:none}
@keyframes bkFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

.booking-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.exp-card{
  display:flex;flex-direction:column;
  background:var(--white);border:1.5px solid var(--line);border-radius:14px;overflow:hidden;
  text-align:left;cursor:pointer;font:inherit;color:inherit;padding:0;
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.exp-img{aspect-ratio:4/3;overflow:hidden;background:var(--cream-2);position:relative}
.exp-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.exp-card:hover{transform:translateY(-3px);border-color:var(--purple-300);box-shadow:0 14px 32px -16px rgba(109,40,217,.25)}
.exp-card:hover .exp-img img{transform:scale(1.04)}
.exp-info{padding:10px 12px 12px}
.exp-name{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:2px;line-height:1.25}
.exp-meta{font-size:11px;color:var(--ink-soft);opacity:.65;margin-bottom:4px}
.exp-price{font-size:13px;font-weight:700;color:var(--purple-700)}
.exp-card.exp-selected{
  border-color:var(--purple-500);transform:translateY(-3px);
  box-shadow:0 14px 36px -14px rgba(109,40,217,.45),0 0 0 4px rgba(139,92,246,.18);
}
.exp-card.exp-selected .exp-img::after{
  content:"✓";position:absolute;top:8px;right:8px;
  width:26px;height:26px;border-radius:50%;
  background:var(--purple-600);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;
  box-shadow:0 4px 14px rgba(76,29,149,.45);
  animation:bkPop .35s var(--ease) both;
}
@keyframes bkPop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}

.bk-date{margin-top:10px;background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:12px}
.bk-date-label{font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:10px}
.bk-slots{display:flex;flex-wrap:wrap;gap:8px}
.slot{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:999px;
  background:var(--white);border:1.5px solid var(--line);
  font:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;
  transition:all .25s var(--ease);
}
.slot:hover{border-color:var(--purple-300);color:var(--purple-700)}
.slot-tag{font-size:10px;font-weight:600;color:var(--purple-700);background:var(--purple-100);padding:1px 6px;border-radius:999px}
.slot.slot-selected{
  background:var(--purple-600);color:#fff;border-color:var(--purple-600);
  box-shadow:0 8px 22px -8px rgba(109,40,217,.55);
}
.slot.slot-selected .slot-tag{background:rgba(255,255,255,.22);color:#fff}

.bk-people{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.people{
  min-width:48px;padding:10px 16px;border-radius:12px;
  background:var(--white);border:1.5px solid var(--line);
  font:inherit;font-size:14px;font-weight:700;color:var(--ink);cursor:pointer;
  transition:all .25s var(--ease);
}
.people:hover{border-color:var(--purple-300);color:var(--purple-700)}
.people.people-selected{
  background:var(--purple-600);color:#fff;border-color:var(--purple-600);
  box-shadow:0 8px 22px -8px rgba(109,40,217,.55);
}
.bk-people-hint{margin-top:10px;font-size:12px;color:var(--ink-soft);opacity:.75}

.bk-pay{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.pay{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:14px;
  background:var(--white);border:1.5px solid var(--line);
  font:inherit;font-size:14px;font-weight:700;color:var(--ink);cursor:pointer;
  transition:all .25s var(--ease);
}
.pay:hover{border-color:var(--purple-300)}
.pay-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:6px;
  background:#FF5B24;color:#fff;font-weight:900;font-size:13px;font-family:Arial,sans-serif;
}
.pay.vipps.pay-selected{
  background:#FF5B24;color:#fff;border-color:#FF5B24;
  box-shadow:0 10px 26px -8px rgba(255,91,36,.55);
}
.pay.vipps.pay-selected .pay-mark{background:#fff;color:#FF5B24}
.pay.pay-selected:not(.vipps){
  background:var(--purple-600);color:#fff;border-color:var(--purple-600);
  box-shadow:0 8px 22px -8px rgba(109,40,217,.55);
}

.vipps-pane{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;
  background:linear-gradient(160deg,rgba(255,91,36,.08),rgba(255,91,36,.02));
  border:1px solid rgba(255,91,36,.28);border-radius:14px;
  transition:background .35s var(--ease), border-color .35s var(--ease);
}
.vipps-mark{
  width:42px;height:42px;border-radius:10px;
  background:#FF5B24;color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:20px;font-family:Arial,sans-serif;letter-spacing:-.02em;
  flex-shrink:0;transition:background .35s var(--ease);
}
.vipps-text{flex:1;min-width:0}
.vipps-title{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:2px}
.vipps-sub{font-size:12.5px;color:var(--ink-soft);opacity:.85}
.vipps-spinner{
  width:22px;height:22px;border-radius:50%;
  border:2.5px solid var(--line);border-top-color:#FF5B24;
  animation:vippsSpin .8s linear infinite;flex-shrink:0;
}
.vipps-check{
  display:none;width:32px;height:32px;border-radius:50%;
  background:#10B981;color:#fff;align-items:center;justify-content:center;
  font-size:17px;font-weight:700;flex-shrink:0;
  box-shadow:0 4px 14px -2px rgba(16,185,129,.5);
  animation:bkPop .35s var(--ease) both;
}
.vipps-pane.paid{
  background:linear-gradient(160deg,rgba(16,185,129,.1),rgba(255,91,36,.04));
  border-color:rgba(16,185,129,.35);
}
.vipps-pane.paid .vipps-mark{background:#10B981}
.vipps-pane.paid .vipps-spinner{display:none}
.vipps-pane.paid .vipps-check{display:flex}
@keyframes vippsSpin{to{transform:rotate(360deg)}}

.bk-receipt{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;background:linear-gradient(160deg,rgba(16,185,129,.1),rgba(139,92,246,.06));
  border:1px solid rgba(16,185,129,.28);border-radius:14px;
}
.bk-receipt-check{
  width:38px;height:38px;border-radius:50%;
  background:#10B981;color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;flex-shrink:0;
  box-shadow:0 6px 16px -4px rgba(16,185,129,.5);
}
.bk-receipt-title{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:2px}
.bk-receipt-sub{font-size:12.5px;color:var(--ink-soft);opacity:.85}
.bk-confirm-msg{margin-top:10px;font-size:14px;opacity:.85}

.booking-input{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;background:var(--cream);border:1px solid var(--line);border-radius:14px;
  min-height:52px;position:relative;
}
.bk-typed{font-size:14px;color:var(--ink);white-space:pre}
.bk-placeholder{font-size:14px;color:var(--ink-soft);opacity:.5;position:absolute;left:16px;pointer-events:none}
.bk-caret{display:inline-block;width:2px;height:16px;background:var(--purple-600);animation:bkBlink 1s infinite}
@keyframes bkBlink{50%{opacity:0}}
.bk-spacer{flex:1}
.bk-send{
  width:30px;height:30px;border-radius:9px;
  background:var(--purple-600);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;
  flex-shrink:0;
}

@media(max-width:720px){
  .booking-options{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .booking-options{grid-template-columns:1fr}
  .booking-body{padding:18px}
  .bk-msg{max-width:95%;font-size:14px}
}

/* ============ GPT MODULE MOCKUP ============ */
.gpt-mock{
  max-width:1040px;margin:0 auto 60px;
  background:var(--white);border-radius:var(--radius-lg);
  box-shadow:0 40px 80px -30px rgba(76,29,149,.3);
  border:1px solid var(--line);overflow:hidden;
}
.gpt-mock-body{display:grid;grid-template-columns:260px 1fr;min-height:520px}
.gpt-mock-side{
  background:var(--ink);color:var(--cream);
  padding:18px 14px;display:flex;flex-direction:column;gap:4px;
  border-right:1px solid rgba(255,255,255,.06);
}
.gpt-mock-new{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.08);color:var(--cream);
  border:1px solid rgba(255,255,255,.12);border-radius:10px;
  padding:10px 14px;font-size:13px;font-weight:500;cursor:pointer;
  margin-bottom:14px;transition:all .2s var(--ease);
}
.gpt-mock-new:hover{background:rgba(255,255,255,.14)}
.gpt-mock-section{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  opacity:.45;margin:14px 4px 4px;font-weight:600;
}
.gpt-mock-conv{
  padding:9px 12px;border-radius:8px;font-size:13px;
  opacity:.75;cursor:pointer;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
  transition:all .2s var(--ease);
}
.gpt-mock-conv:hover{background:rgba(255,255,255,.06);opacity:1}
.gpt-mock-conv.active{background:rgba(139,92,246,.22);opacity:1;color:#E9D5FF}
.gpt-mock-side-foot{
  margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:10px;font-size:12px;
}
.gpt-mock-avatar{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-700));
  display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;
}
.gpt-mock-user{font-weight:600;opacity:.95}
.gpt-mock-role{opacity:.5;font-size:11px}

.gpt-mock-main{
  padding:0;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#FAFAF7,#fff);
  position:relative;height:560px;overflow:hidden;
}
.gpt-mock-scroll{
  flex:1;min-height:0;overflow-y:auto;
  padding:28px 32px 4px;
  display:flex;flex-direction:column;gap:14px;
  position:relative;
  scroll-behavior:smooth;
}
.gpt-mock-msg{
  padding:14px 18px;border-radius:16px;
  font-size:14.5px;line-height:1.55;max-width:92%;
}
.gpt-mock-msg.u{
  background:var(--purple-50);color:var(--ink);
  align-self:flex-end;border-top-right-radius:4px;
  border:1px solid var(--purple-200);
}
.gpt-mock-msg.a{
  background:#fff;color:var(--ink);
  align-self:flex-start;border-top-left-radius:4px;
  border:1px solid var(--line);
  box-shadow:0 4px 12px -6px rgba(76,29,149,.12);
}
.gpt-mock-who{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  opacity:.55;margin-bottom:4px;font-weight:600;
}
.gpt-mock-head{
  display:flex;align-items:center;gap:8px;
  margin-bottom:10px;
}
.gpt-mock-logo{
  display:inline-flex;align-items:center;
  padding:4px 10px;border-radius:6px;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-700));
  color:#fff;
  font-size:11px;font-weight:600;letter-spacing:.01em;
  text-transform:uppercase;
}
.gpt-mock-msg.a p{margin:0 0 8px}
.gpt-mock-msg.a ol{margin:4px 0 10px 20px;padding:0;display:flex;flex-direction:column;gap:4px}
.gpt-mock-msg.a li{font-size:14px;line-height:1.5}
.gpt-mock-sources{
  margin-top:12px;padding-top:12px;
  border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
}
.gpt-mock-sources-label{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  opacity:.5;font-weight:600;margin-bottom:2px;
}
.gpt-mock-src{
  display:flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:8px;
  background:var(--cream);font-size:12.5px;color:var(--ink-soft);
  border:1px solid var(--line);
  transition:all .2s var(--ease);cursor:pointer;
}
.gpt-mock-src:hover{background:var(--purple-50);border-color:var(--purple-200);color:var(--purple-700)}
.gpt-mock-src-ic{font-size:13px;opacity:.85}
.gpt-mock-input{
  margin:12px 32px 24px;flex-shrink:0;
  display:flex;align-items:center;gap:6px;
  padding:14px 18px;border-radius:14px;
  background:#fff;border:1.5px solid var(--line);
  font-size:14px;color:var(--ink-soft);
  transition:border-color .2s var(--ease);
  box-shadow:0 4px 12px -8px rgba(76,29,149,.15);
}
.gpt-mock-input:focus-within,.gpt-mock-input.active{border-color:var(--purple-300)}
.gpt-mock-placeholder{opacity:.55}
.gpt-mock-typed{color:var(--ink);white-space:pre}
.gpt-mock-caret{
  display:inline-block;width:2px;height:16px;background:var(--purple-700);
  margin-left:1px;vertical-align:middle;animation:gptCaret 1s steps(1) infinite;
}
@keyframes gptCaret{50%{opacity:0}}
.gpt-mock-spacer{flex:1}
.gpt-mock-send{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:var(--purple-700);color:#fff;
  display:grid;place-items:center;font-size:14px;font-weight:600;
}

/* welcome / landing state */
.gpt-welcome{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:10px;z-index:1;padding:20px;
  transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.gpt-welcome.gpt-fade-out{opacity:0;transform:translateY(-12px);pointer-events:none}
.gpt-welcome-logo{
  display:inline-flex;align-items:center;
  padding:12px 22px;border-radius:14px;
  background:linear-gradient(135deg,var(--purple-500),var(--purple-700));
  color:#fff;
  font-size:15px;font-weight:600;letter-spacing:.01em;
  box-shadow:0 16px 32px -12px rgba(109,40,217,.5);
  margin-bottom:6px;
}
.gpt-welcome-title{font-size:22px;font-weight:600;color:var(--ink);margin:0;letter-spacing:-.01em}
.gpt-welcome-sub{font-size:14px;color:var(--ink-soft);opacity:.7;max-width:380px;margin:0 0 8px;line-height:1.5}
.gpt-welcome-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}
.gpt-welcome-chips span{
  padding:8px 14px;border-radius:999px;
  background:var(--white);border:1px solid var(--line);
  font-size:12.5px;color:var(--ink-soft);
  transition:all .2s var(--ease);cursor:pointer;
}
.gpt-welcome-chips span:hover{border-color:var(--purple-300);color:var(--purple-700);background:var(--purple-50)}

/* fade + reveal */
.gpt-hidden{display:none}
.gpt-mock-msg.u:not(.gpt-hidden),
.gpt-mock-msg.a:not(.gpt-hidden){animation:gptMsgIn .35s var(--ease) both}
@keyframes gptMsgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* thinking dots */
.gpt-typing-dots{display:flex;gap:5px;padding:6px 2px}
.gpt-typing-dots span{
  width:7px;height:7px;border-radius:50%;background:var(--purple-300);
  animation:gptBlink 1.2s infinite;
}
.gpt-typing-dots span:nth-child(2){animation-delay:.2s}
.gpt-typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes gptBlink{0%,80%,100%{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}

.gpt-answer-body{animation:gptMsgIn .4s var(--ease) both}
.gpt-answer-body ul{margin:4px 0 10px 20px;padding:0;display:flex;flex-direction:column;gap:4px}
.gpt-answer-body li{font-size:14px;line-height:1.5}

/* guest avatar */
.gpt-mock-avatar.gpt-guest{background:rgba(255,255,255,.14);color:var(--cream)}

/* make main a positioning context for absolute welcome fade */
.gpt-mock-main{position:relative}

@media (max-width:760px){
  .gpt-mock-body{grid-template-columns:1fr}
  .gpt-mock-side{display:none}
  .gpt-mock-main{height:600px}
  .gpt-mock-scroll{padding:22px 22px 4px}
  .gpt-mock-input{margin:10px 22px 18px}
}

/* ============ PRICING ============ */
.pricing{padding:140px 0;background:var(--cream);position:relative}

/* Billing toggle */
.billing-toggle{
  display:flex;align-items:center;justify-content:center;gap:16px;
  margin:0 auto 44px;
}
.bt-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:15px;font-weight:600;color:var(--ink-soft);opacity:.6;
  transition:opacity .3s var(--ease),color .3s var(--ease);cursor:default;
}
.bt-label.bt-active{opacity:1;color:var(--ink)}
.bt-save{
  font-size:11px;font-weight:700;letter-spacing:.04em;
  color:var(--purple-700);background:var(--purple-100);
  padding:3px 9px;border-radius:999px;
}
.bt-switch{
  position:relative;width:54px;height:30px;flex-shrink:0;
  border:none;border-radius:999px;cursor:pointer;padding:0;
  background:var(--purple-200);transition:background .3s var(--ease);
}
.bt-switch[aria-checked="true"]{background:var(--purple-600)}
.bt-knob{
  position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;
  background:#fff;box-shadow:0 2px 6px rgba(76,29,149,.35);
  transition:transform .3s var(--ease);
}
.bt-switch[aria-checked="true"] .bt-knob{transform:translateX(24px)}

.price-old{
  text-decoration:line-through;opacity:.45;font-weight:600;
  font-size:.62em;margin-right:8px;
  display:none;
}
.billing-yearly .price-old{display:inline}

.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;max-width:1200px;margin:0 auto}
.price-card{
  position:relative;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:36px 28px;
  display:flex;flex-direction:column;transition:all .4s var(--ease);
}
.price-card:hover{transform:translateY(-6px);border-color:var(--purple-300);box-shadow:0 30px 60px -30px rgba(109,40,217,.3)}
.price-card.highlight{
  background:linear-gradient(160deg,var(--purple-700),var(--purple-900));
  color:var(--white);border:none;
}
.price-tag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--purple-400);color:var(--purple-950);
  padding:5px 14px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
}
.price-name{font-size:15px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;opacity:.75}
.price-val{font-size:44px;font-weight:700;letter-spacing:-.02em;margin-bottom:24px;line-height:1}
.price-val .cur{font-size:14px;opacity:.6;font-weight:500;margin-right:4px;vertical-align:top}
.price-val .per{font-size:14px;opacity:.6;font-weight:500}
.price-val .custom{font-size:22px;font-weight:600}
.price-card ul{list-style:none;margin-bottom:28px;flex:1}
.price-card li{padding:8px 0 8px 24px;position:relative;font-size:14px;opacity:.85}
.price-card li::before{content:"✓";position:absolute;left:0;color:var(--purple-500);font-weight:700}
.price-card.highlight li::before{color:var(--purple-300)}
.price-card .btn{width:100%;justify-content:center}

/* ============ CTA ============ */
.cta-section{position:relative;padding:140px 0;overflow:hidden}
.cta-bg{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,var(--purple-50),var(--cream));
}
.cta-orb{
  position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(139,92,246,.35),transparent 70%);
  filter:blur(60px);top:-200px;right:-200px;z-index:0;
  animation:float 20s ease-in-out infinite;
}
.cta-section .container{position:relative;z-index:1}
.cta-box{
  max-width:720px;margin:0 auto;text-align:center;
  padding:60px 40px;border-radius:var(--radius-lg);
  background:var(--white);border:1px solid var(--line);
  box-shadow:0 40px 100px -40px rgba(109,40,217,.3);
}
.cta-box h2{font-size:clamp(30px,4.5vw,52px);line-height:1.05;letter-spacing:-.02em;margin:18px 0 14px}
.cta-box p{opacity:.75;margin-bottom:30px;font-size:16px}
.cta-btn-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.cta-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:left}
.cta-form input{
  padding:14px 18px;border:1px solid var(--line);border-radius:12px;
  font-family:var(--font);font-size:15px;background:var(--cream);
  transition:all .2s;
}
.cta-form input:focus{outline:none;border-color:var(--purple-500);background:#fff;box-shadow:0 0 0 4px var(--purple-100)}
.cta-form input:nth-child(3){grid-column:span 2}
.cta-form button{grid-column:span 2;justify-content:center;margin-top:6px}

/* ============ FOOTER ============ */
.footer{background:var(--ink);color:var(--cream);padding:80px 0 30px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand{display:flex;flex-direction:column;gap:10px}
.foot-brand .brand-mark::after{background:var(--ink)}
.foot-tag{font-size:14px;opacity:.6;margin-top:12px;max-width:240px}
.foot-col{display:flex;flex-direction:column;gap:10px}
.foot-col h5{font-size:12px;letter-spacing:.2em;text-transform:uppercase;opacity:.5;margin-bottom:8px}
.foot-col a,.foot-col span{font-size:14px;opacity:.75;transition:opacity .2s}
.foot-col a:hover{opacity:1;color:var(--purple-300)}
.foot-bottom{display:flex;justify-content:space-between;padding-top:24px;font-size:12px;opacity:.5}

/* ============ REVEAL ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(40px);transition:all .9s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ RESPONSIVE ============ */
@media (max-width:820px){
  .nav-links{display:none}
  .cta-form{grid-template-columns:1fr}
  .cta-form input:nth-child(3){grid-column:span 1}
  .cta-form button{grid-column:span 1}
  .footer-inner{grid-template-columns:1fr 1fr;gap:30px}
  .foot-brand{grid-column:span 2}
  .foot-bottom{flex-direction:column;gap:8px;text-align:center}
  .marquee-track{font-size:26px}
  .platform,.services,.pricing,.demo-section,.cta-section{padding:80px 0}
  .demo-body{padding:24px}
  .cta-box{padding:40px 24px}
}
