/* ============================================================
   MadeleineCrush — Shared Design System
   Responsive, fluid, touch-first. Used by all pages.
   ============================================================ */

:root{
  /* color */
  --ink:#0e1116; --ink-2:#3a414d; --muted:#6b7280; --faint:#9aa1ad;
  --bg:#ffffff; --bg-soft:#f6f7f9; --bg-deep:#0c0f15;
  --line:#e7e9ee; --line-soft:#f0f1f4; --line-d:#222833;
  --accent:#5b5bd6; --accent-2:#8a6cf0; --accent-soft:#eef0fe; --mint:#10b981;

  /* layout */
  --nav-h:64px;
  --maxw:1160px;
  --radius:16px;
  --pad-x:clamp(20px, 5vw, 28px);
  --sec-y:clamp(56px, 8vw, 96px);

  /* fluid type */
  --h1:clamp(2.05rem, 1.15rem + 4.3vw, 3.75rem);
  --h2:clamp(1.62rem, 1.15rem + 2.3vw, 2.38rem);
  --h3:clamp(1.12rem, 1.02rem + 0.5vw, 1.30rem);
  --lede:clamp(1.02rem, 0.95rem + 0.55vw, 1.25rem);
  --body:clamp(0.95rem, 0.92rem + 0.18vw, 1.02rem);

  --mono:'SF Mono',ui-monospace,'JetBrains Mono',Menlo,Consolas,monospace;
  --ease:cubic-bezier(.2,.75,.25,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{
  font-size:100%;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--nav-h) + 12px);
  -webkit-text-size-adjust:100%;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
}
body{
  font-family:-apple-system,'Segoe UI',Inter,system-ui,sans-serif;
  color:var(--ink); background:var(--bg);
  font-size:var(--body); line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);width:100%}
section{padding:var(--sec-y) 0}

/* ---------- typography ---------- */
h1{font-size:var(--h1);line-height:1.06;letter-spacing:-.02em;font-weight:700}
h2{font-size:var(--h2);line-height:1.12;letter-spacing:-.02em;font-weight:700}
h3{font-size:var(--h3);letter-spacing:-.01em;font-weight:600}
.grad{background:linear-gradient(110deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.label{color:var(--accent);font-family:var(--mono);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:14px;display:block}
.sec-sub{color:var(--muted);max-width:560px;font-size:var(--lede)}
.lede{font-size:var(--lede);color:var(--ink-2)}

/* ---------- buttons (touch-friendly) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:600;font-size:.97rem;font-family:inherit;
  padding:13px 22px;min-height:48px;border-radius:11px;
  border:1px solid transparent;cursor:pointer;transition:transform .18s var(--ease),background .18s,border-color .18s,box-shadow .18s;
  -webkit-tap-highlight-color:transparent;text-align:center;line-height:1.1;
}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-secondary{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-light{background:#fff;color:var(--ink);border-color:#fff}
.btn-ghost-d{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
@media (hover:hover){
  .btn-primary:hover{background:#000;transform:translateY(-2px);box-shadow:0 18px 38px -16px rgba(14,17,22,.6), 0 0 0 1px rgba(255,255,255,.04) inset}
  .btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 16px 34px -18px rgba(91,91,214,.55)}
  .btn-light:hover{transform:translateY(-2px);box-shadow:0 18px 40px -16px rgba(0,0,0,.45)}
  .btn-ghost-d:hover{border-color:#fff;transform:translateY(-2px);box-shadow:0 16px 34px -18px rgba(0,0,0,.5)}
}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}

/* ---------- focus-visible: clear keyboard affordance everywhere ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible,select:focus-visible,
.svc:focus-visible,.pk:focus-visible,.vs-card a:focus-visible{
  outline:none;border-radius:11px;
  box-shadow:0 0 0 3px var(--accent-soft), 0 0 0 1px var(--accent)}
.btn:focus-visible{box-shadow:0 0 0 3px var(--accent-soft), 0 0 0 2px var(--accent)}

/* ---------- nav ---------- */
nav{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
}
nav .wrap{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.brand{display:inline-flex;align-items:center;gap:11px;font-weight:700;font-size:1.06rem;letter-spacing:-.02em;z-index:2;transition:opacity .2s ease}
/* MadeleineCrush MC monogram — dark app-tile chip with electric-purple glow.
   One source, used in every navbar + footer (logo asset: assets/logo-mc.svg). */
.brand .mark{width:32px;height:32px;border-radius:9px;position:relative;flex-shrink:0;
  background-image:url("logo-mc.svg"),linear-gradient(160deg,#1b1b24,#0a0a0e);
  background-size:66%,cover;background-position:center,center;background-repeat:no-repeat,no-repeat;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 6px 18px -8px rgba(138,108,240,.85), inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .26s var(--ease), box-shadow .26s var(--ease)}
.brand .mark::after{content:none}
.brand .mark::before{opacity:.18}
.brand:active .mark{transform:scale(.95)}
@media (hover:hover){
  .brand:hover{opacity:1}
  .brand:hover .mark{transform:scale(1.06);box-shadow:0 10px 26px -8px rgba(138,108,240,1), 0 0 22px -4px rgba(168,120,255,.85), inset 0 1px 0 rgba(255,255,255,.1)}
}
.navlinks{display:flex;align-items:center;gap:clamp(18px,2.4vw,30px)}
.navlinks a{position:relative;color:var(--muted);font-size:.92rem;font-weight:500;transition:color .2s ease}
/* desktop: animated accent underline for hover + current page */
@media (min-width:861px){
  .navlinks a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;border-radius:2px;
    background:linear-gradient(90deg,var(--accent),var(--accent-2));box-shadow:0 0 10px rgba(91,91,214,.7);
    transform:scaleX(0);transform-origin:center;transition:transform .26s var(--ease)}
  @media (hover:hover){.navlinks a:not(.nav-cta):hover{color:var(--ink)} .navlinks a:not(.nav-cta):hover::after{transform:scaleX(.5)}}
  .navlinks a.active:not(.nav-cta){color:var(--ink);font-weight:600}
  .navlinks a.active:not(.nav-cta)::after{transform:scaleX(1)}
}
@media (max-width:860px) and (hover:hover){.navlinks a:hover{color:var(--ink)}}
.nav-cta{padding:9px 18px;min-height:42px;font-size:.9rem}

/* hamburger */
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;border:none;background:transparent;cursor:pointer;z-index:2;
  -webkit-tap-highlight-color:transparent;
}
.hamburger span{display:block;width:22px;height:2px;margin:0 auto;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
nav.open .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
nav.open .hamburger span:nth-child(2){opacity:0}
nav.open .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile-only links (Home, Contact) live in the overlay, not the desktop bar */
@media (min-width:861px){ .nav-m{display:none} }

/* full-screen glass overlay menu (phones + tablets) */
@media (max-width:860px){
  .hamburger{display:flex;position:relative;z-index:160}
  .brand{position:relative;z-index:160}
  nav.open .brand{color:#fff}
  nav.open .hamburger span{background:#fff}

  .navlinks{
    position:fixed;inset:0;height:100dvh;z-index:150;
    flex-direction:column;align-items:center;justify-content:center;gap:4px;
    padding:96px 24px 48px;
    background:rgba(8,11,18,.74);
    backdrop-filter:blur(24px) saturate(150%);-webkit-backdrop-filter:blur(24px) saturate(150%);
    opacity:0;visibility:hidden;transform:scale(1.03);
    transition:opacity .4s var(--ease),transform .5s var(--ease),visibility .4s;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
  }
  nav.open .navlinks{opacity:1;visibility:visible;transform:none}
  .navlinks a{
    color:#f4f6fa;font-size:clamp(1.5rem,7vw,2rem);font-weight:600;letter-spacing:-.02em;
    padding:9px 0;min-height:auto;border:none;
    opacity:0;transform:translateY(12px);
    transition:opacity .45s ease,transform .5s var(--ease),color .18s;
  }
  nav.open .navlinks a{opacity:1;transform:none}
  /* staggered reveal */
  nav.open .navlinks a:nth-child(1){transition-delay:.06s}
  nav.open .navlinks a:nth-child(2){transition-delay:.10s}
  nav.open .navlinks a:nth-child(3){transition-delay:.14s}
  nav.open .navlinks a:nth-child(4){transition-delay:.18s}
  nav.open .navlinks a:nth-child(5){transition-delay:.22s}
  nav.open .navlinks a:nth-child(6){transition-delay:.26s}
  nav.open .navlinks a:nth-child(7){transition-delay:.30s}
  .navlinks a.active{color:var(--accent-2)}
  .navlinks a.nav-cta{
    margin-top:26px;background:#fff;color:#0a0b0e;border:none;border-radius:13px;
    font-size:1.05rem;padding:15px 30px;min-height:54px;width:auto;align-self:center;
    box-shadow:0 18px 40px -18px rgba(0,0,0,.7);
  }
  @media (prefers-reduced-motion:reduce){
    .navlinks,.navlinks a{transition:none}
    nav.open .navlinks a{transform:none}
  }
}

/* ---------- shared page header ---------- */
.pagehead{padding:clamp(64px,9vw,90px) 0 clamp(44px,6vw,60px);text-align:center;background:radial-gradient(ellipse 80% 60% at 50% -10%,var(--accent-soft),transparent 60%)}
.pagehead h1{margin-bottom:18px}
.pagehead p{font-size:var(--lede);color:var(--ink-2);max-width:620px;margin:0 auto}

/* ---------- shared final CTA ---------- */
.final{background:var(--bg-deep);color:#fff;text-align:center;position:relative;overflow:hidden}
.final:before{content:"";position:absolute;top:-180px;left:50%;transform:translateX(-50%);width:min(760px,120vw);height:480px;background:radial-gradient(ellipse,rgba(91,91,214,.30),transparent 62%);filter:blur(10px);pointer-events:none}
.final .inner{position:relative;z-index:2}
.final h2{color:#fff;margin-bottom:14px}
.final p{color:#c4ccd8;font-size:var(--lede);max-width:520px;margin:0 auto 30px}
.final .hero-cta{justify-content:center}

/* ---------- footer ---------- */
footer{background:var(--bg-deep);color:#8b94a3;border-top:1px solid var(--line-d);padding:clamp(40px,6vw,54px) 0 40px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(24px,4vw,40px);margin-bottom:36px}
footer .brand{color:#fff;font-size:1rem;margin-bottom:12px}
footer .brand .mark::after{background:#fff}
footer .about{max-width:320px;font-size:.9rem;line-height:1.6}
footer .fcol h4{color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-family:var(--mono)}
footer .fcol a{display:block;color:#8b94a3;font-size:.9rem;margin-bottom:9px;transition:color .16s;min-height:24px}
@media (hover:hover){footer .fcol a:hover{color:#fff}}
.foot-bottom{border-top:1px solid var(--line-d);padding-top:24px;font-size:.82rem;color:#5b6472}
@media (max-width:680px){
  .foot-grid{grid-template-columns:1fr 1fr}
  footer .fcol:first-child{grid-column:1 / -1}
}
@media (max-width:420px){.foot-grid{grid-template-columns:1fr}}

/* ---------- scroll reveal (opt-in via html.js, motion-safe) ---------- */
html.js :is(.reveal,.cred .c,.svc,.why-c,.step,.pk,.sec-head,.form-card,.info-block,.cmp-table,.incl-block,.pricing-note,.promise,.pr,.stat-b,.estep,.vs-card,.sia-node){
  opacity:0;transform:translateY(20px);
  transition:opacity .6s ease, transform .65s var(--ease);
  will-change:opacity,transform;
}
html.js :is(.reveal,.cred .c,.svc,.why-c,.step,.pk,.sec-head,.form-card,.info-block,.cmp-table,.incl-block,.pricing-note,.promise,.pr,.stat-b,.estep,.vs-card,.sia-node).in{
  opacity:1;transform:none;
}
@media (prefers-reduced-motion: reduce){
  html.js :is(.reveal,.cred .c,.svc,.why-c,.step,.pk,.sec-head,.form-card,.info-block,.cmp-table,.incl-block,.pricing-note,.promise,.pr,.stat-b,.estep,.vs-card,.sia-node){
    opacity:1!important;transform:none!important;transition:none!important;
  }
}

/* utilities */
.center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* ============================================================
   CINEMATIC STAGE SYSTEM
   Swappable <video> (Higgsfield MP4/WebM) layered over an
   elegant CSS/SVG fallback. Fallback shows until real footage
   is added; <video poster> provides the static-image fallback.
   ============================================================ */
.cine{position:absolute;inset:0;overflow:hidden;background:#080b12;z-index:0}
.cine-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.1s ease}
.cine.video-on .cine-vid{opacity:1}
.cine.video-on .cine-fallback{opacity:0}
.cine-fallback{position:absolute;inset:0;transition:opacity .9s ease}
.cine-veil{position:absolute;inset:0;z-index:4;pointer-events:none}
.cine-veil.hero{background:linear-gradient(180deg,rgba(8,11,18,.30) 0%,rgba(8,11,18,.50) 55%,rgba(8,11,18,.84) 100%)}
.cine-veil.center{background:radial-gradient(ellipse 85% 85% at 50% 50%,rgba(8,11,18,.18),rgba(8,11,18,.72))}

/* gradient field + drifting light */
.cine-field{position:absolute;inset:-12%;background:
   radial-gradient(40% 50% at 22% 30%,rgba(91,91,214,.40),transparent 60%),
   radial-gradient(38% 48% at 80% 24%,rgba(138,108,240,.34),transparent 60%),
   radial-gradient(46% 56% at 60% 82%,rgba(16,185,129,.16),transparent 60%),
   #080b12;filter:blur(6px)}
.cine-orb{position:absolute;border-radius:50%;filter:blur(46px);opacity:.5;will-change:transform}
.cine-orb.a{width:42vmax;height:42vmax;left:-8%;top:-14%;background:radial-gradient(circle,rgba(91,91,214,.55),transparent 65%);animation:cineDriftA 26s var(--ease) infinite alternate}
.cine-orb.b{width:36vmax;height:36vmax;right:-6%;top:-8%;background:radial-gradient(circle,rgba(138,108,240,.5),transparent 65%);animation:cineDriftB 33s var(--ease) infinite alternate}
.cine-orb.c{width:30vmax;height:30vmax;left:34%;bottom:-20%;background:radial-gradient(circle,rgba(16,185,129,.32),transparent 65%);animation:cineDriftC 30s var(--ease) infinite alternate}

/* fine engineering grid */
.cine-grid{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:64px 64px;opacity:.5;
  -webkit-mask-image:radial-gradient(ellipse 72% 72% at 50% 42%,#000,transparent 82%);mask-image:radial-gradient(ellipse 72% 72% at 50% 42%,#000,transparent 82%)}

/* data-flow connectors */
.cine-flow{position:absolute;inset:0;width:100%;height:100%}
.cine-flow path{fill:none;stroke:rgba(255,255,255,.16);stroke-width:1.5;stroke-dasharray:6 10;animation:cineDash 3.6s linear infinite}
.cine-flow .node{fill:var(--accent-2)}

/* floating glass UI cards */
.cine-ui{position:absolute;inset:0}
.cine-card{position:absolute;border-radius:14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);box-shadow:0 26px 60px -30px rgba(0,0,0,.75);overflow:hidden;will-change:transform}
.cine-card:before{content:"";position:absolute;top:0;left:-60%;width:55%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.16),transparent);animation:cineSheen 6.5s ease-in-out infinite}
.cine-bar{position:absolute;height:6px;border-radius:4px;background:rgba(255,255,255,.16)}
.cine-bar.accent{background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.cine-spark{position:absolute;left:16px;right:16px;bottom:16px;height:50px;display:flex;align-items:flex-end;gap:6px}
.cine-spark i{flex:1;background:linear-gradient(180deg,var(--accent-2),rgba(91,91,214,.18));border-radius:3px 3px 0 0;transform-origin:bottom;animation:cineGrow 4s ease-in-out infinite alternate}
.cine-spark i:nth-child(2){animation-delay:.35s}.cine-spark i:nth-child(3){animation-delay:.7s}
.cine-spark i:nth-child(4){animation-delay:1.05s}.cine-spark i:nth-child(5){animation-delay:1.4s}
.cine-spark i:nth-child(6){animation-delay:1.75s}
.cine-cardA{width:min(280px,44%);height:148px;left:8%;top:23%;animation:cineFloat1 12s var(--ease) infinite alternate}
.cine-cardB{width:min(216px,38%);height:120px;right:9%;top:17%;animation:cineFloat2 14s var(--ease) infinite alternate}
.cine-cardC{width:min(236px,40%);height:128px;right:13%;bottom:14%;animation:cineFloat3 16s var(--ease) infinite alternate}

/* embedded (non-hero) stage with fixed aspect ratio */
.cine-embed{position:relative;width:100%;border-radius:20px;overflow:hidden;border:1px solid var(--line-d);background:#080b12;aspect-ratio:16/9}
.cine-embed .cine{border-radius:inherit}
.cine-embed.tall{aspect-ratio:9/16;max-width:300px;margin-inline:auto}
.cine-caption{position:absolute;left:0;right:0;bottom:0;z-index:6;padding:clamp(18px,3vw,28px);color:#fff;display:flex;align-items:flex-end;justify-content:space-between;gap:16px}
.cine-caption h3{color:#fff;margin-bottom:4px}
.cine-caption p{color:#c4ccd8;font-size:.9rem;max-width:420px}
.cine-chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#dfe4ec;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:6px 12px;border-radius:30px}
.cine-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint)}

@keyframes cineDriftA{to{transform:translate3d(8%,6%,0) scale(1.1)}}
@keyframes cineDriftB{to{transform:translate3d(-7%,9%,0) scale(1.08)}}
@keyframes cineDriftC{to{transform:translate3d(6%,-8%,0) scale(1.12)}}
@keyframes cineFloat1{to{transform:translate3d(0,-16px,0)}}
@keyframes cineFloat2{to{transform:translate3d(0,18px,0)}}
@keyframes cineFloat3{to{transform:translate3d(0,-14px,0)}}
@keyframes cineSheen{0%,100%{left:-60%}55%{left:120%}}
@keyframes cineGrow{0%{transform:scaleY(.42)}100%{transform:scaleY(1)}}
@keyframes cineDash{to{stroke-dashoffset:-160}}

/* motion-safe: hold a still, composed frame */
@media (prefers-reduced-motion: reduce){
  .cine-orb,.cine-card,.cine-card:before,.cine-spark i,.cine-flow path{animation:none!important}
}
/* mobile: keep it clean + light on the GPU */
@media (max-width:600px){
  .cine-card{display:none}
  .cine-orb{filter:blur(34px)}
  .cine-grid{background-size:46px 46px}
  .cine-caption{flex-direction:column;align-items:flex-start;gap:14px}
  .cine-caption .btn{width:100%}
  .cine-caption p{display:none}
}
/* embedded stages grow a touch taller on narrow screens so content breathes */
@media (max-width:520px){
  .cine-embed{aspect-ratio:4/5}
}

/* ============================================================
   CINEMATIC VISIBILITY LAYER
   Makes every video area read instantly as premium, live media:
   motion border, autoplay-loop badge, looping progress sweep,
   outer glow, hover lift, and a brighter fallback.
   ============================================================ */

/* brighter, more present fallback light */
.cine-orb{opacity:.62}
.cine-field{filter:blur(4px)}

/* embedded stages: glow + animated gradient motion border + hover */
.cine-embed{
  box-shadow:0 34px 90px -42px rgba(91,91,214,.6), 0 0 0 1px rgba(255,255,255,.05);
  transition:transform .32s var(--ease), box-shadow .32s var(--ease);
  isolation:isolate;
}
.cine-embed:before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;z-index:6;pointer-events:none;
  background:linear-gradient(120deg,#5b5bd6,#8a6cf0,#10b981,#5b5bd6);background-size:300% 300%;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:cineBorder 8s ease infinite;opacity:.9;
}
@media (hover:hover){
  .cine-embed:hover{transform:translateY(-4px);box-shadow:0 44px 100px -38px rgba(91,91,214,.78), 0 0 0 1px rgba(255,255,255,.08)}
  .cine-embed:hover .cine-badge{border-color:rgba(255,255,255,.32)}
}

/* "autoplay loop" badge */
.cine-badge{
  position:absolute;top:14px;left:14px;z-index:7;display:inline-flex;align-items:center;gap:7px;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:#e7ebf2;
  background:rgba(8,11,18,.55);border:1px solid rgba(255,255,255,.18);padding:6px 11px;border-radius:30px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.cine-badge .live{width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint);animation:cinePulse 1.8s ease-in-out infinite}

/* looping progress sweep = "this plays" affordance */
.cine-progress{position:absolute;left:0;bottom:0;width:100%;height:3px;z-index:7;background:rgba(255,255,255,.12);overflow:hidden}
.cine-progress i{position:absolute;left:0;top:0;height:100%;width:38%;background:linear-gradient(90deg,transparent,var(--accent),var(--accent-2),transparent);animation:cineSweep 6.5s linear infinite}

/* corner play glyph (decorative, signals media) */
.cine-play{position:absolute;z-index:7;right:14px;top:14px;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(8,11,18,.5);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);color:#fff}
.cine-play:before{content:"";border-style:solid;border-width:7px 0 7px 11px;border-color:transparent transparent transparent #fff;margin-left:3px}
.cine-play .ring{position:absolute;inset:-1px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);animation:cineRing 2.6s ease-out infinite}
.cine-play{transition:transform .25s var(--ease),background .25s,box-shadow .25s}
/* play button pulses + brightens when its media card is hovered */
@media (hover:hover){
  .cine-embed:hover .cine-play,.vs-card:hover .cine-play{transform:scale(1.12);background:rgba(91,91,214,.55);box-shadow:0 0 22px -4px rgba(138,108,240,.8)}
  .cine-embed:hover .cine-play .ring,.vs-card:hover .cine-play .ring{animation-duration:1.5s;border-color:rgba(255,255,255,.6)}
}

@keyframes cineBorder{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes cinePulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.7}}
@keyframes cineSweep{0%{left:-40%}100%{left:100%}}
@keyframes cineRing{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.5);opacity:0}}

/* ---------- hero "alive" indicators ---------- */
.cine-scan{position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(105deg,transparent 42%,rgba(255,255,255,.06) 50%,transparent 58%);background-size:250% 100%;animation:cineScanMove 8s ease-in-out infinite}
@keyframes cineScanMove{0%{background-position:130% 0}100%{background-position:-60% 0}}
.hero-live{position:absolute;right:clamp(16px,4vw,40px);bottom:clamp(18px,4vw,34px);z-index:6;display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:#cdd6e3;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);padding:7px 13px;border-radius:30px;backdrop-filter:blur(8px)}
.hero-live .live{width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint);animation:cinePulse 1.8s ease-in-out infinite}
.hero-cue{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:6;display:flex;flex-direction:column;align-items:center;gap:9px;color:#8b94a3;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase}
.hero-cue .mouse{width:22px;height:34px;border:1.5px solid rgba(255,255,255,.28);border-radius:12px;position:relative}
.hero-cue .mouse:after{content:"";position:absolute;left:50%;top:7px;width:3px;height:6px;border-radius:2px;background:#fff;transform:translateX(-50%);animation:cueScroll 1.8s ease-in-out infinite}
@keyframes cueScroll{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0;transform:translate(-50%,11px)}}

/* ============================================================
   VIDEO 2 — vertical 9:16 phone-frame social ad
   ============================================================ */
.adsec{background:var(--bg-deep);color:#fff;position:relative;overflow:hidden}
.adsec:before{content:"";position:absolute;top:-160px;left:-10%;width:60%;height:520px;background:radial-gradient(ellipse,rgba(91,91,214,.22),transparent 62%);filter:blur(12px);pointer-events:none}
.adwrap{position:relative;z-index:2;display:grid;grid-template-columns:300px 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.adcopy .label{color:var(--accent-2)}
.adcopy h2{text-align:left;color:#fff;margin-bottom:14px}
.adcopy p{color:#c4ccd8;font-size:var(--lede);margin-bottom:24px;max-width:460px}
.adcopy .adlist{list-style:none;margin:0 0 26px}
.adcopy .adlist li{display:flex;gap:10px;align-items:center;padding:7px 0;color:#dfe4ec;font-size:.95rem}
.adcopy .adlist li:before{content:"✓";color:var(--mint);font-weight:800}

.phone{position:relative;width:100%;max-width:300px;margin-inline:auto;aspect-ratio:9/19.3;background:#04060a;border-radius:46px;padding:11px;border:1px solid rgba(255,255,255,.1);
  box-shadow:0 50px 110px -44px rgba(0,0,0,.85), 0 0 0 2px rgba(255,255,255,.05) inset, 0 0 60px -10px rgba(91,91,214,.35)}
.phone-screen{position:relative;width:100%;height:100%;border-radius:36px;overflow:hidden;background:#080b12}
.phone-notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:38%;height:22px;background:#04060a;border-radius:0 0 14px 14px;z-index:9}
.phone-side{position:absolute;right:-2px;top:120px;width:3px;height:54px;border-radius:3px;background:rgba(255,255,255,.12)}
.phone-side.b{top:186px;height:40px}
.phone .cine{position:absolute;inset:0}
/* vertical ad lower-third */
.ad-cap{position:absolute;left:0;right:0;bottom:0;z-index:7;padding:18px 16px 22px;background:linear-gradient(180deg,transparent,rgba(4,6,10,.82))}
.ad-cap .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:#dfe4ec;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:5px 10px;border-radius:30px;margin-bottom:10px}
.ad-cap .chip .live{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 8px var(--mint);animation:cinePulse 1.8s ease-in-out infinite}
.ad-cap h4{color:#fff;font-size:1.05rem;line-height:1.2;letter-spacing:-.01em}
.ad-cap span{display:block;color:#aab4c4;font-size:.78rem;margin-top:4px}
/* before/after micro-scene that crossfades */
.ad-scene{position:absolute;left:14px;right:14px;top:54px;height:120px;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.ad-scene .face{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase}
.ad-scene .before{background:#161922;color:#6b7280;filter:grayscale(1);animation:adBefore 7s ease-in-out infinite}
.ad-scene .after{background:linear-gradient(135deg,rgba(91,91,214,.6),rgba(16,185,129,.4));color:#fff;animation:adAfter 7s ease-in-out infinite}
@keyframes adBefore{0%,38%{opacity:1}50%,100%{opacity:0}}
@keyframes adAfter{0%,38%{opacity:0}50%,100%{opacity:1}}

@media (max-width:860px){
  .adwrap{grid-template-columns:1fr;gap:32px}
  .adcopy{order:2;text-align:center}
  .adcopy h2{text-align:center}
  .adcopy p{margin-inline:auto}
  .adcopy .adlist{display:inline-block;text-align:left}
  .adcopy .hero-cta{justify-content:center}
  .phone{order:1}
}

/* motion-safe: freeze the new indicators into a still, composed state */
@media (prefers-reduced-motion: reduce){
  .cine-embed:before,.cine-badge .live,.cine-progress i,.cine-play .ring,.cine-scan,.hero-live .live,.hero-cue .mouse:after,.ad-scene .before,.ad-scene .after{animation:none!important}
  .ad-scene .before{opacity:0}.ad-scene .after{opacity:1}
}

/* ============================================================
   LIVING CINEMATIC LAYER  (phase: "real media" immersion)
   Makes every .cine stage read as live motion media even before
   real footage exists. All transform/opacity, all motion-safe.
   ============================================================ */

/* drifting aurora wash over every stage (adds cyan + motion + depth) */
.cine::before{content:"";position:absolute;inset:-12%;z-index:3;pointer-events:none;opacity:.42;mix-blend-mode:screen;
  background:
    radial-gradient(40% 50% at 24% 30%,rgba(91,91,214,.40),transparent 60%),
    radial-gradient(36% 46% at 78% 24%,rgba(52,209,196,.24),transparent 60%),
    radial-gradient(46% 56% at 60% 86%,rgba(138,108,240,.28),transparent 60%);
  background-size:160% 160%;animation:mcAurora 24s ease-in-out infinite}
/* slow moving reflection / light sweep across the glass */
.cine::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.05) 47%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.05) 53%,transparent 60%);
  background-size:250% 100%;animation:mcReflect 9s ease-in-out infinite}

/* scrubber playhead on the looping progress bar => "this is playing" */
.cine-progress{height:4px}
.cine-progress::after{content:"";position:absolute;top:50%;left:0;width:9px;height:9px;border-radius:50%;
  background:#fff;box-shadow:0 0 12px var(--accent-2);transform:translate(-50%,-50%);animation:mcPlayhead 6.5s linear infinite;z-index:8}

/* hover = live-preview zoom + lift (reads like scrubbing into a clip) */
.cine-embed .cine-fallback,.cine-embed .cine-vid{transition:transform .6s var(--ease),filter .6s ease}
@media (hover:hover){
  .cine-embed:hover .cine-fallback,.cine-embed:hover .cine-vid{transform:scale(1.045);filter:saturate(1.12) brightness(1.06)}
}

@keyframes mcAurora{0%,100%{background-position:0% 0%}50%{background-position:100% 100%}}
@keyframes mcReflect{0%{background-position:135% 0}55%,100%{background-position:-45% 0}}
@keyframes mcPlayhead{0%{left:0}100%{left:100%}}
@media (prefers-reduced-motion: reduce){
  .cine::before,.cine::after,.cine-progress::after,.final::after{animation:none!important}
  .cine-embed:hover .cine-fallback,.cine-embed:hover .cine-vid{transform:none}
}

/* ============================================================
   AURORA ATMOSPHERE  (dark CTAs + softer light sections)
   ============================================================ */
.final::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.55;
  background:
    radial-gradient(40% 60% at 18% 28%,rgba(91,91,214,.26),transparent 60%),
    radial-gradient(42% 60% at 82% 22%,rgba(52,209,196,.15),transparent 60%),
    radial-gradient(52% 70% at 60% 92%,rgba(138,108,240,.22),transparent 60%);
  background-size:170% 170%;animation:mcAurora 26s ease-in-out infinite}
.final .inner{position:relative;z-index:2}
/* lift the flatness of the soft light bands with a faint top key-light */
.band-soft{background:
  radial-gradient(120% 70% at 50% -20%,rgba(91,91,214,.06),transparent 60%), var(--bg-soft)}

/* ============================================================
   LOGO — dimensional polish
   ============================================================ */
.brand .mark{overflow:hidden}
.brand .mark::before{content:"";position:absolute;inset:0;border-radius:inherit;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.4),transparent 52%);opacity:.55;transition:opacity .26s ease}
@media (hover:hover){
  .brand:hover .mark{box-shadow:0 12px 28px -8px rgba(91,91,214,1), 0 0 22px -6px rgba(138,108,240,.8), inset 0 1px 0 rgba(255,255,255,.5)}
  .brand:hover .mark::before{opacity:.85}
}

/* ============================================================
   MOBILE OVERLAY — aurora depth
   ============================================================ */
@media (max-width:860px){
  .navlinks::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.9;
    background:
      radial-gradient(60% 38% at 50% 16%,rgba(91,91,214,.30),transparent 62%),
      radial-gradient(54% 40% at 74% 82%,rgba(52,209,196,.14),transparent 62%)}
}
@media (max-width:860px) and (prefers-reduced-motion:no-preference){
  /* gentle continuity: nothing heavy, the aurora is static here for focus */
}

/* ============================================================
   LANGUAGE SELECTOR  (injected by app.js)
   ============================================================ */
.lang{position:relative;display:inline-flex}
.lang-btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:.85rem;font-weight:600;
  color:var(--ink-2);background:#fff;border:1px solid var(--line);padding:8px 13px;border-radius:11px;cursor:pointer;
  transition:color .2s var(--ease),border-color .2s,background .2s,box-shadow .2s,transform .2s;min-height:40px}
.lang-btn .fl{font-size:1.05rem;line-height:1}
.lang-btn .chev{width:8px;height:8px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg) translate(-1px,-1px);transition:transform .25s var(--ease)}
.lang.open .lang-btn .chev{transform:rotate(-135deg) translate(1px,1px)}
@media (hover:hover){.lang-btn:hover{color:var(--ink);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);transform:translateY(-1px)}}
.lang.open .lang-btn{color:var(--ink);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.lang-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:182px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:7px;box-shadow:0 30px 60px -26px rgba(14,17,22,.5), 0 0 0 1px rgba(255,255,255,.6) inset;
  opacity:0;visibility:hidden;transform:translateY(-8px) scale(.97);transform-origin:top right;
  transition:opacity .22s ease,transform .26s var(--ease),visibility .22s;z-index:320}
.lang.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-opt{position:relative;display:flex;align-items:center;gap:11px;width:100%;padding:11px 12px;border-radius:10px;font:inherit;font-size:.92rem;
  color:var(--ink-2);background:transparent;border:none;cursor:pointer;text-align:left;transition:background .18s var(--ease),color .18s,padding-left .18s}
.lang-opt .fl{font-size:1.1rem}
.lang-opt .ck{margin-left:auto;color:var(--accent);opacity:0;font-weight:700;transition:opacity .18s}
@media (hover:hover){.lang-opt:hover{background:var(--bg-soft);padding-left:15px}}
/* clear selected-language indication: accent tint + left bar + check */
.lang-opt.active{color:var(--accent);font-weight:600;background:var(--accent-soft)}
.lang-opt.active::before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:3px;background:linear-gradient(180deg,var(--accent),var(--accent-2));box-shadow:0 0 10px rgba(91,91,214,.7)}
.lang-opt.active{padding-left:15px}
.lang-opt.active .ck{opacity:1}
@media (hover:hover){.lang-opt:hover{background:var(--bg-soft)}}
/* desktop: tuck the selector next to the CTA */
@media (min-width:861px){ .lang{margin-left:4px} }
/* mobile: dark-overlay treatment, full-width row */
@media (max-width:860px){
  .lang{margin-top:22px;width:100%;max-width:320px;justify-content:center}
  .lang-btn{width:100%;justify-content:center;color:#cdd6e3;border-color:rgba(255,255,255,.22);font-size:1rem;min-height:50px}
  .lang-menu{left:0;right:0;background:#0e1320;border-color:rgba(255,255,255,.12)}
  .lang-opt{color:#cdd6e3}
  .lang-opt.active{color:var(--accent-2)}
}
/* language switch fade */
.lang-fade{transition:opacity .25s ease}
.lang-fading{opacity:.35}

/* ============================================================
   GLOBAL CONVERSION LAYER — floating consultation CTA
   Elegant, appears after a short scroll, never a popup.
   ============================================================ */
.mc-fab{position:fixed;right:clamp(14px,3vw,22px);bottom:clamp(14px,3vw,22px);z-index:300;
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  font-weight:600;font-size:.92rem;line-height:1;padding:14px 20px;border-radius:30px;text-decoration:none;
  box-shadow:0 18px 42px -16px rgba(91,91,214,.85), 0 0 0 1px rgba(255,255,255,.06) inset;
  opacity:0;transform:translateY(14px);pointer-events:none;
  transition:opacity .4s ease, transform .4s var(--ease), box-shadow .25s}
.mc-fab.in{opacity:1;transform:none;pointer-events:auto}
.mc-fab::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 9px var(--mint)}
@media (hover:hover){.mc-fab:hover{transform:translateY(-2px);box-shadow:0 24px 50px -16px rgba(91,91,214,1), 0 0 0 1px rgba(255,255,255,.1) inset}}
@media (max-width:600px){.mc-fab{font-size:.86rem;padding:12px 17px}}
@media (prefers-reduced-motion:reduce){.mc-fab{transition:none}.mc-fab.in{transform:none}}

/* ============================================================
   SYSTEMS IN ACTION — operational flow choreography
   Lead → AI → CRM → Booking → Dashboard → Automation → Smoother
   A pulse sweeps the path; each node lights in sequence.
   ============================================================ */
.sia{background:var(--bg-deep);color:#fff;position:relative;overflow:hidden}
.sia::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:
    radial-gradient(40% 60% at 16% 24%,rgba(91,91,214,.26),transparent 60%),
    radial-gradient(40% 60% at 84% 22%,rgba(52,209,196,.15),transparent 60%),
    radial-gradient(52% 70% at 60% 92%,rgba(138,108,240,.20),transparent 60%);
  background-size:170% 170%;animation:mcAurora 26s ease-in-out infinite}
.sia .wrap{position:relative;z-index:2}
.sia .label{color:var(--accent-2)}
.sia h2{color:#fff;text-align:center}
.sia .sec-sub{color:#c4ccd8;margin:0 auto}
.sia-flow{position:relative;display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:clamp(34px,5vw,48px);align-items:start}
/* connecting rail with a travelling pulse */
.sia-flow::before{content:"";position:absolute;top:34px;left:6%;right:6%;height:2px;border-radius:2px;
  background:linear-gradient(90deg,rgba(255,255,255,.08),rgba(255,255,255,.18),rgba(255,255,255,.08));z-index:0}
.sia-flow::after{content:"";position:absolute;top:34px;left:6%;width:46px;height:2px;border-radius:2px;z-index:1;
  background:linear-gradient(90deg,transparent,var(--accent-2),var(--mint),transparent);
  filter:drop-shadow(0 0 6px var(--accent-2));animation:siaPulse 7s linear infinite}
.sia-node{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}
.sia-node .dot{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:26px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(6px);
  box-shadow:0 18px 40px -22px rgba(0,0,0,.8);transition:transform .3s var(--ease);
  animation:siaGlow 7s ease-in-out infinite}
.sia-node b{font-size:.82rem;font-weight:600;color:#eef2f7;max-width:120px}
.sia-node span{font-size:.72rem;color:#9aa6b8;max-width:130px;line-height:1.35}
.sia-node:nth-child(1) .dot{animation-delay:0s}
.sia-node:nth-child(2) .dot{animation-delay:1s}
.sia-node:nth-child(3) .dot{animation-delay:2s}
.sia-node:nth-child(4) .dot{animation-delay:3s}
.sia-node:nth-child(5) .dot{animation-delay:4s}
.sia-node:nth-child(6) .dot{animation-delay:5s}
.sia-node:nth-child(7) .dot{animation-delay:6s}
@keyframes siaPulse{0%{left:6%;opacity:0}6%{opacity:1}94%{opacity:1}100%{left:92%;opacity:0}}
@keyframes siaGlow{0%,84%,100%{border-color:rgba(255,255,255,.12);box-shadow:0 18px 40px -22px rgba(0,0,0,.8)}
  9%,16%{border-color:rgba(138,108,240,.7);box-shadow:0 0 26px -2px rgba(138,108,240,.7);transform:translateY(-3px)}}
@media (max-width:820px){
  .sia-flow{grid-template-columns:1fr;gap:8px;max-width:420px;margin-inline:auto}
  .sia-flow::before{top:6%;bottom:6%;left:32px;right:auto;width:2px;height:auto}
  .sia-flow::after{display:none}
  .sia-node{flex-direction:row;text-align:left;gap:14px}
  .sia-node .dot{width:54px;height:54px;font-size:22px;flex-shrink:0}
  .sia-node b,.sia-node span{max-width:none}
  .sia-node .txt{display:flex;flex-direction:column;gap:3px}
}
@media (prefers-reduced-motion:reduce){.sia::after,.sia-flow::after,.sia-node .dot{animation:none}}

/* ============================================================
   SHARED DEPTH HELPERS — cinematic divider + filmic grain
   ============================================================ */
/* a centered gradient separator with a soft glowing node */
.divider{position:relative;height:1px;width:100%;max-width:var(--maxw);margin:clamp(8px,2vw,20px) auto;
  background:linear-gradient(90deg,transparent,var(--line) 30%,var(--line) 70%,transparent)}
.divider::before{content:"";position:absolute;left:50%;top:50%;width:6px;height:6px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--accent);box-shadow:0 0 14px 2px rgba(91,91,214,.6)}
.divider.dark{background:linear-gradient(90deg,transparent,rgba(255,255,255,.14) 30%,rgba(255,255,255,.14) 70%,transparent)}
.divider.dark::before{background:var(--accent-2);box-shadow:0 0 14px 2px rgba(138,108,240,.7)}

/* subtle filmic grain layer (apply on a positioned element via .grain) */
.grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)'/%3E%3C/svg%3E")}

/* extra overlay stagger slots for the injected selector */
@media (max-width:860px){
  .navlinks .lang{opacity:0;transform:translateY(12px);transition:opacity .45s ease,transform .5s var(--ease)}
  nav.open .navlinks .lang{opacity:1;transform:none}
  nav.open .navlinks > *:nth-child(8){transition-delay:.34s}
  nav.open .navlinks > *:nth-child(9){transition-delay:.38s}
}

/* ============================================================
   CINEMATIC DEMO REEL
   A believable looping software walkthrough that cycles through
   four scenes (dashboard → lead routing → AI reply → booking).
   Opacity-timeline driven; GPU-light; reads as a real product demo.
   ============================================================ */
.reel{position:absolute;inset:0;z-index:2;font-family:-apple-system,'Segoe UI',Inter,system-ui,sans-serif}
.reel-scene{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:6%;opacity:0;animation:reelShow 22s ease-in-out infinite}
.reel-scene.s2{animation-delay:5.5s}.reel-scene.s3{animation-delay:11s}.reel-scene.s4{animation-delay:16.5s}
.reel-panel{width:min(80%,580px);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:16px;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 34px 80px -34px rgba(0,0,0,.85);padding:clamp(16px,2.4vw,22px);color:#eef2f7}
.reel-h{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.reel-h .d{width:9px;height:9px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint)}
.reel-h b{font-size:.82rem;font-weight:600;color:#fff}
.reel-h .t{margin-left:auto;font-family:var(--mono);font-size:.6rem;color:#9aa6b8;letter-spacing:.05em}
/* S1 — dashboard */
.reel-kpis{display:flex;gap:9px;margin-bottom:14px}
.reel-kpi{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:9px 11px}
.reel-kpi b{display:block;font-size:1.05rem;color:#fff;letter-spacing:-.02em}
.reel-kpi span{font-size:.56rem;color:#9aa6b8;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}
.reel-bars{display:flex;align-items:flex-end;gap:7px;height:72px}
.reel-bars i{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--accent-2),rgba(91,91,214,.22));transform-origin:bottom;transform:scaleY(.4);animation:reelBar 2.8s ease-in-out infinite alternate}
.reel-bars i:nth-child(2){animation-delay:.3s}.reel-bars i:nth-child(3){animation-delay:.6s}.reel-bars i:nth-child(4){animation-delay:.9s}
.reel-bars i:nth-child(5){animation-delay:1.2s}.reel-bars i:nth-child(6){animation-delay:1.5s}.reel-bars i:nth-child(7){animation-delay:1.8s}
/* S2 — lead routing */
.reel-route{display:flex;align-items:center;gap:0;position:relative}
.reel-chip{flex-shrink:0;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:11px;padding:12px 14px;font-size:.78rem;color:#fff;min-width:120px}
.reel-chip span{display:block;font-size:.56rem;color:#9aa6b8;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.reel-wire{flex:1;height:2px;margin:0 6px;background:linear-gradient(90deg,rgba(255,255,255,.1),rgba(255,255,255,.25),rgba(255,255,255,.1));position:relative;border-radius:2px}
.reel-wire .pkt{position:absolute;top:50%;left:0;width:9px;height:9px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 12px var(--accent-2);transform:translate(-50%,-50%);animation:reelPkt 2.6s ease-in-out infinite}
/* S3 — AI reply */
.reel-chat{display:flex;flex-direction:column;gap:9px}
.reel-msg{max-width:80%;padding:9px 13px;border-radius:13px;font-size:.78rem;opacity:0;animation:reelPop 5.5s ease infinite}
.reel-msg.u{align-self:flex-end;background:rgba(255,255,255,.14);color:#fff}
.reel-msg.a{align-self:flex-start;background:linear-gradient(135deg,rgba(91,91,214,.55),rgba(138,108,240,.4));color:#fff;border:1px solid rgba(255,255,255,.12)}
.reel-msg.a{animation-delay:.6s}
.reel-msg.a2{animation-delay:1.2s}
/* S4 — booking */
.reel-cal{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.reel-cal i{height:30px;border-radius:7px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}
.reel-cal i.book{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;animation:reelBook 5.5s ease infinite}
/* scene progress dots */
.reel-dots{position:absolute;left:clamp(16px,3vw,24px);bottom:clamp(14px,2.4vw,20px);display:flex;gap:7px;z-index:6}
.reel-dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.25);animation:reelDot 22s ease-in-out infinite}
.reel-dots i:nth-child(2){animation-delay:5.5s}.reel-dots i:nth-child(3){animation-delay:11s}.reel-dots i:nth-child(4){animation-delay:16.5s}

@keyframes reelShow{0%{opacity:0;transform:scale(.985)}3%{opacity:1;transform:none}22%{opacity:1;transform:none}26%{opacity:0;transform:scale(1.01)}100%{opacity:0}}
@keyframes reelBar{0%{transform:scaleY(.35)}100%{transform:scaleY(1)}}
@keyframes reelPkt{0%{left:0}55%{left:100%}100%{left:100%}}
@keyframes reelPop{0%{opacity:0;transform:translateY(8px)}6%{opacity:1;transform:none}22%{opacity:1}26%{opacity:0}100%{opacity:0}}
@keyframes reelBook{0%,8%{background:rgba(255,255,255,.06)}14%,26%{background:linear-gradient(135deg,var(--accent),var(--accent-2))}100%{background:rgba(255,255,255,.06)}}
@keyframes reelDot{0%{background:rgba(255,255,255,.25);transform:scale(1)}3%,22%{background:var(--accent-2);transform:scale(1.35)}26%{background:rgba(255,255,255,.25);transform:scale(1)}100%{background:rgba(255,255,255,.25)}}

@media (max-width:600px){
  .reel-panel{width:90%}
  .reel-kpi b{font-size:.92rem}
}
@media (prefers-reduced-motion: reduce){
  .reel-scene{animation:none}
  .reel-scene.s1{opacity:1}
  .reel-bars i,.reel-wire .pkt,.reel-msg,.reel-cal i.book,.reel-dots i{animation:none}
  .reel-bars i{transform:scaleY(.8)}
  .reel-msg{opacity:1}
  .reel-dots i:nth-child(1){background:var(--accent-2)}
}

/* ============================================================
   CINEMATIC INTRO LOADER — glowing MC reveal (once per session)
   Self-dismisses via CSS animation; JS gates session + reduced-motion.
   ============================================================ */
#mc-intro{position:fixed;inset:0;z-index:4000;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 42%,#171327,#06060a 72%);overflow:hidden;
  animation:mcIntroOut .8s ease 2.2s forwards}
#mc-intro.skip{display:none}
#mc-intro .mc-stage{position:relative;width:clamp(104px,24vw,150px);height:clamp(104px,24vw,150px);z-index:2}
#mc-intro .mc-logo{position:absolute;inset:0;background:url("logo-mc.svg") center/contain no-repeat;
  animation:mcIntroPop 1.5s var(--ease) both;filter:drop-shadow(0 0 22px rgba(138,108,240,.6))}
#mc-intro .mc-ring{position:absolute;inset:-22%;border-radius:50%;
  background:radial-gradient(circle,rgba(138,108,240,.32),transparent 62%);filter:blur(8px);
  animation:mcIntroGlow 2.2s ease-in-out infinite}
#mc-intro .mc-sweep{position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(105deg,transparent 42%,rgba(255,255,255,.22) 50%,transparent 58%);
  background-size:260% 100%;animation:mcIntroSweep 2s ease-in-out .5s 1 both;mix-blend-mode:screen}
#mc-intro .mc-specks{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.7;
  background:
    radial-gradient(2px 2px at 30% 38%,rgba(168,120,255,.7),transparent 60%),
    radial-gradient(2px 2px at 68% 30%,rgba(120,180,255,.6),transparent 60%),
    radial-gradient(2px 2px at 60% 70%,rgba(168,120,255,.5),transparent 60%),
    radial-gradient(1.5px 1.5px at 38% 66%,rgba(200,170,255,.6),transparent 60%);
  background-repeat:no-repeat;animation:mcIntroSpecks 2.4s ease-in-out infinite}
#mc-intro .mc-word{position:absolute;left:0;right:0;bottom:18%;text-align:center;color:#cdd6e3;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.42em;text-transform:uppercase;
  opacity:0;animation:mcIntroWord .8s ease .9s forwards;padding-left:.42em}
@keyframes mcIntroPop{0%{opacity:0;transform:scale(.82)}55%{opacity:1}100%{opacity:1;transform:scale(1)}}
@keyframes mcIntroGlow{0%,100%{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}
@keyframes mcIntroSweep{0%{background-position:130% 0}100%{background-position:-50% 0}}
@keyframes mcIntroSpecks{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes mcIntroWord{to{opacity:1}}
@keyframes mcIntroOut{to{opacity:0;visibility:hidden}}
@media (prefers-reduced-motion:reduce){#mc-intro{display:none}}
