/* Hallmark · macrostructure: redesign-in-place · genre: modern-minimal
 * nav: N5 floating-pill · footer: Ft5 statement · features: hairline panel
 * tone: confident / utilitarian · display: Playfair Display · body: Inter
 * anchor hue: blue ~250 · accent: cyan · pre-emit critique: P4 H4 E4 S4 R4 V4
 * contrast: pass (40–41, eyebrow-on-black watch) · nav/footer: pass (42–43)
 */
/* ========== LOCAL WEB SA — Shared Styles ========== */
:root{
  /* Brand Colors */
  --brand-blue:#0000FF;       /* electric blue — brand reference (#0000FF) */
  --brand-blue-deep:#0007A8;
  --brand-blue-mid:#0024F2;
  --accent-cyan:#00E5FF;
  --accent-electric:#0000FF;  /* electric blue (logo / Figma #0000FF) — hero heading accent, feature dots, prices, footer accent */
  --whatsapp-green:#00E676;

  /* Backgrounds — deep navy canvas + cyan accent (production direction) */
  --bg-black:#050D1A;
  --canvas:#050D1A; /* colour the hero artwork/scrim fades into */
  --bg-black-2:#07080F;
  --surface-card:#15161F;
  --surface-card-2:#1B1C28;

  /* Type roles — distinctive display face paired with a refined body face */
  --font-display:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  /* Text */
  --text-grey:#B8B8C0;
  --text-grey-soft:#8A8A93;
  --white:#FFFFFF;

  /* Borders */
  --hairline:rgba(255,255,255,0.06);
  --hairline-strong:rgba(255,255,255,0.12);

  /* ====== SPACING SCALE (8px base) ====== */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-8: 48px;
  --space-10: 64px;
  --space-12: 96px;
  --space-16: 128px;

  /* ====== FLUID TYPOGRAPHY (clamp) ====== */
  --text-xs: clamp(11px, 0.75rem + 0.2vw, 12px);
  --text-sm: clamp(13px, 0.85rem + 0.3vw, 15px);
  --text-base: clamp(15px, 1rem + 0.4vw, 17px);
  --text-lg: clamp(17px, 1.1rem + 0.5vw, 20px);
  --text-xl: clamp(20px, 1.3rem + 0.8vw, 28px);
  --text-2xl: clamp(28px, 1.8rem + 1.2vw, 40px);
  --text-3xl: clamp(36px, 2.3rem + 1.8vw, 56px);
  --text-4xl: clamp(48px, 3rem + 2.5vw, 80px);

  /* ====== CONTAINER WIDTHS ====== */
  --container-sm: 600px;
  --container-md: 940px;
  --container-lg: 1240px;
  --container-xl: 1440px;

  /* ====== TOUCH TARGETS ====== */
  --touch-target-min: 48px;
  --touch-target-comfortable: 56px;

  /* ====== EASING ====== */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg-black);color:var(--white);scroll-behavior:smooth;overflow-x:clip}
body{
  font-family:var(--font-body);
  font-size:var(--text-base);line-height:1.6;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}

/* ====== REDUCED MOTION ====== */
@media (prefers-reduced-motion: reduce){
  html,body{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    transition-duration:0.01ms !important;
  }
  .fade-in{opacity:1;transform:none}
}

/* ====== HIGH CONTRAST ====== */
@media (prefers-contrast: high){
  :root{
    --hairline:rgba(255,255,255,0.3);
    --hairline-strong:rgba(255,255,255,0.5);
  }
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ====== LAYOUT ====== */
/* Fluid containers with safe-area support */
.wrap{
  width:100%;
  max-width:var(--container-lg);
  margin:0 auto;
  padding-inline:max(var(--space-4), env(safe-area-inset-left)) max(var(--space-4), env(safe-area-inset-right));
}
.wrap-narrow{
  width:100%;
  max-width:var(--container-md);
  margin:0 auto;
  padding-inline:max(var(--space-4), env(safe-area-inset-left)) max(var(--space-4), env(safe-area-inset-right));
}

/* Fluid section padding */
section{padding:var(--space-12) 0;position:relative;overflow:hidden}
section.tight{padding:var(--space-8) 0}

@media (min-width: 640px){
  .wrap{padding-inline:var(--space-5)}
  .wrap-narrow{padding-inline:var(--space-5)}
}
@media (min-width: 980px){
  .wrap{padding-inline:var(--space-6)}
  .wrap-narrow{padding-inline:var(--space-6)}
}
@media (min-width: 1280px){
  .wrap{padding-inline:var(--space-6);max-width:var(--container-lg)}
}
@media (min-width: 1536px){
  .wrap{max-width:var(--container-xl)}
}

section.blue{background:linear-gradient(180deg,var(--brand-blue-deep) 0%,var(--brand-blue) 50%,var(--brand-blue-mid) 100%);color:#fff}
section.black{background:var(--bg-black)}

.eyebrow{
  display:inline-block;
  font-size:var(--text-xs);font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent-cyan);
}
section.black .eyebrow{color:#7E90FF} /* brightened for 4.5:1 on the deep #050D1A canvas */
.h1{
  font-family:var(--font-display);
  font-size:var(--text-4xl);font-weight:600;line-height:1.05;letter-spacing:-0.015em;
  margin:0;color:#fff;overflow-wrap:anywhere;min-width:0;
}
.h2{
  font-family:var(--font-display);
  font-size:var(--text-3xl);font-weight:600;letter-spacing:-0.01em;line-height:1.12;
  margin:0;color:#fff;overflow-wrap:anywhere;min-width:0;
}
.h3{font-size:var(--text-xl);font-weight:700;margin:0;color:#fff;letter-spacing:-0.01em}
.lede{color:var(--text-grey);font-size:var(--text-lg);margin:0;line-height:1.6;max-width:60ch}
section.blue .lede{color:rgba(255,255,255,0.85)}
.cyan{color:var(--accent-cyan)}
.center{text-align:center}
.muted{color:var(--text-grey)}

/* Dial back the largest headings on phones so the layout breathes */
@media (max-width:480px){
  .h1{font-size:var(--text-3xl)}
  .h2{font-size:var(--text-2xl)}
}

/* ====== NAV ====== */
/* N5 · Floating pill — detached from the page edges, blur backdrop, soft shadow */
.nav{
  position:fixed;top:var(--space-3);left:50%;transform:translateX(-50%);z-index:100;
  width:calc(100% - var(--space-5));max-width:var(--container-lg);
  display:flex;align-items:center;
  padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4);gap:var(--space-3);
  border-radius:9999px;
  background:rgba(10,11,18,0.55);
  border:1px solid var(--hairline-strong);
  box-shadow:0 10px 34px rgba(0,0,0,0.34);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  transition:background .3s ease,box-shadow .3s ease;
}
.nav.scrolled{background:rgba(8,9,15,0.78);box-shadow:0 12px 40px rgba(0,0,0,0.45)}
.nav.scrolled.on-blue{background:rgba(0,7,168,0.72)}
.brand{
  display:inline-flex;align-items:center;gap:var(--space-2);
  font-weight:800;letter-spacing:0.02em;font-size:var(--text-sm);color:#fff;
}
.brand-mark{
  width:40px;height:40px;border-radius:10px;
  background-image:url('assets/logo.png');
  background-size:cover;background-position:center;
  box-shadow:0 0 0 1px rgba(255,255,255,.18) inset, 0 6px 24px rgba(0,0,255,.4);
  flex-shrink:0;
}
.brand-wordmark{height:22px;width:auto;display:block;flex-shrink:0}
@media (max-width:400px){.brand-wordmark{height:18px}}

.nav-links{
  display:flex;align-items:center;gap:var(--space-1);margin-left:auto;
}
.nav-links a{
  padding:var(--space-2) var(--space-4);border-radius:9999px;
  color:rgba(255,255,255,0.75);
  font-size:var(--text-sm);font-weight:500;
  transition:color .15s,background .15s;
  min-height:var(--touch-target-min);
  display:inline-flex;align-items:center;
}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,0.07)}
.nav-links a.active{color:var(--accent-cyan);background:rgba(0,229,255,0.08)}
.nav-links a:active{transform:scale(0.97)}

.nav-cta{margin-left:var(--space-2)}
.menu-btn{
  display:none;
  width:var(--touch-target-comfortable);height:var(--touch-target-comfortable);
  border-radius:12px;margin-left:auto;
  background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.04));place-items:center;color:#fff;
  border:1px solid rgba(255,255,255,.22);
  -webkit-backdrop-filter:blur(18px) saturate(160%);backdrop-filter:blur(18px) saturate(160%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.30);
  min-width:var(--touch-target-min);
}
.menu-btn:active{transform:scale(0.95)}
.menu-btn svg{width:24px;height:24px}

/* Mobile Menu — premium frosted command sheet */
.mobile-menu{
  /* Sits above the header (z 100) and chat widget (z 200) so it fully covers them */
  position:fixed;inset:0;z-index:300;
  display:none;flex-direction:column;
  background:rgba(5,13,26,.82);
  -webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);
  /* Safe area support for notch/Dynamic Island */
  padding:max(var(--space-5), env(safe-area-inset-top)) max(var(--space-6), env(safe-area-inset-right)) max(var(--space-6), env(safe-area-inset-bottom)) max(var(--space-6), env(safe-area-inset-left));
  /* Allow scrolling on short screens so no item is clipped */
  overflow-y:auto;
  animation:mobileMenuIn .4s cubic-bezier(0.2, 0.7, 0.2, 1);
}
/* atmospheric glow blooms behind the frosted glass */
.mobile-menu::before{
  content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 38% at 86% 6%, rgba(0,229,255,.16), transparent 70%),
    radial-gradient(58% 40% at 10% 94%, rgba(0,0,255,.30), transparent 72%),
    radial-gradient(50% 38% at 74% 100%, rgba(140,98,255,.18), transparent 72%);
}
@keyframes mobileMenuIn{from{opacity:0}to{opacity:1}}
.mobile-menu.open{display:flex}

.mm-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-shrink:0}
.mm-brand{display:inline-flex;align-items:center}
.mm-brand img{height:20px;width:auto;display:block}
.mobile-menu .close{
  display:grid;place-items:center;flex-shrink:0;
  width:var(--touch-target-comfortable);height:var(--touch-target-comfortable);
  border-radius:12px;color:#fff;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  transition:background .15s,border-color .15s,transform .1s;
}
.mobile-menu .close:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.24)}
.mobile-menu .close:active{transform:scale(0.95)}

/* numbered editorial index */
.mm-links{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;justify-content:safe center;counter-reset:mm;padding:var(--space-3) 0}
.mm-links a{
  position:relative;display:flex;align-items:center;gap:var(--space-4);flex-shrink:0;
  padding:clamp(9px,1.7vh,17px) 4px;
  font-size:clamp(21px,5.6vw,33px);font-weight:700;letter-spacing:-0.02em;line-height:1;color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:color .2s,padding-left .25s cubic-bezier(0.2,0.7,0.2,1);
  animation:mmRow .5s both cubic-bezier(0.2,0.7,0.2,1);
}
.mm-links a::before{
  counter-increment:mm;content:counter(mm,decimal-leading-zero);
  font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--accent-cyan);opacity:.7;
  font-variant-numeric:tabular-nums;width:24px;flex-shrink:0;
  transition:opacity .2s,transform .25s;
}
.mm-links a:hover,.mm-links a:active{color:var(--accent-cyan);padding-left:14px}
.mm-links a:hover::before,.mm-links a:active::before{opacity:1;transform:translateY(-2px)}
.mm-links a.active{color:var(--accent-cyan)}
.mm-links a.active::before{opacity:1}
.mm-links a:nth-child(1){animation-delay:.04s}
.mm-links a:nth-child(2){animation-delay:.08s}
.mm-links a:nth-child(3){animation-delay:.12s}
.mm-links a:nth-child(4){animation-delay:.16s}
.mm-links a:nth-child(5){animation-delay:.20s}
.mm-links a:nth-child(6){animation-delay:.24s}
.mm-links a:nth-child(7){animation-delay:.28s}
.mm-links a:nth-child(8){animation-delay:.32s}
@keyframes mmRow{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* bottom actions */
.mm-actions{display:flex;flex-direction:column;gap:var(--space-3);flex-shrink:0;margin-top:var(--space-2);padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.08)}
.mm-chat{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  min-height:var(--touch-target-comfortable);border-radius:8px;
  font-size:var(--text-base);font-weight:700;color:var(--accent-cyan);
  background:linear-gradient(180deg,rgba(0,229,255,.14),rgba(0,229,255,.04));border:1px solid rgba(0,229,255,.35);
  -webkit-backdrop-filter:blur(18px) saturate(160%);backdrop-filter:blur(18px) saturate(160%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.20);
  transition:background .15s,border-color .15s,transform .1s;
}
.mm-chat:hover{background:rgba(0,229,255,.16);border-color:rgba(0,229,255,.6)}
.mm-chat:active{transform:scale(0.98)}
.mm-chat svg{width:20px;height:20px}
.mm-cta{width:100%}
@media (prefers-reduced-motion:reduce){
  .mobile-menu,.mm-links a{animation:none}
  .mm-links a{transition:color .15s}
}

/* Body scroll lock when mobile menu or template modal is open.
   position:fixed is required for iOS Safari, which ignores overflow:hidden
   on the body for touch scrolling (otherwise the page scrolls behind the
   fixed overlay and the preview appears stuck). */
body.nav-open,body.tpl-lock{overflow:hidden;position:fixed;width:100%}

@media (max-width:980px){
  .nav-links,.nav-cta{display:none}
  .menu-btn{display:grid}
  .nav{padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4)}
}

/* ====== BUTTONS ====== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-3);
  border-radius:8px;padding:var(--space-4) var(--space-6);
  font-weight:700;font-size:var(--text-sm);
  transition:transform .15s ease,box-shadow .2s ease,background .2s,color .2s;
  white-space:nowrap;
  min-height:var(--touch-target-min);
  min-width:var(--touch-target-min);
  -webkit-tap-highlight-color:transparent;
}
.btn.sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}
.btn:active{transform:scale(.97)}
.btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(0,229,255,0.4);
}
.btn-white{
  color:#fff;
  /* bright white liquid glass — same frosted treatment as the hero "Get Started" */
  background:linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.42);
  -webkit-backdrop-filter:blur(22px) saturate(180%);backdrop-filter:blur(22px) saturate(180%);
  text-shadow:0 1px 10px rgba(5,13,26,.55);
  box-shadow:0 8px 26px rgba(5,13,26,.32),inset 0 1px 0 rgba(255,255,255,.55),inset 0 -10px 20px rgba(255,255,255,.05);
}
.btn-white:hover{
  color:#fff;
  background:linear-gradient(180deg,rgba(255,255,255,.32),rgba(255,255,255,.12));
  border-color:rgba(255,255,255,.60);
  box-shadow:0 12px 34px rgba(5,13,26,.40),0 0 26px rgba(0,229,255,.16),inset 0 1px 0 rgba(255,255,255,.70),inset 0 -10px 20px rgba(255,255,255,.08);
}
.btn-wa{
  color:#fff;
  background:linear-gradient(180deg,rgba(0,230,118,.20),rgba(5,13,26,.30));
  border:1px solid rgba(0,230,118,.45);
  -webkit-backdrop-filter:blur(22px) saturate(180%);backdrop-filter:blur(22px) saturate(180%);
  box-shadow:0 8px 26px rgba(5,13,26,.34),inset 0 1px 0 rgba(255,255,255,.18),0 0 22px rgba(0,230,118,.18);
}
.btn-wa:hover{
  color:#fff;
  background:linear-gradient(180deg,rgba(0,230,118,.30),rgba(0,230,118,.10));
  border-color:rgba(0,230,118,.8);
  box-shadow:0 12px 34px rgba(0,230,118,.28),0 0 26px rgba(0,230,118,.30);
}
.btn-blue{
  color:#fff;
  /* transparent glass — frosted blue tint over the backdrop, not a solid fill */
  background:linear-gradient(180deg,rgba(60,96,255,.34),rgba(0,0,255,.18));
  border:1px solid rgba(120,150,255,.50);
  -webkit-backdrop-filter:blur(22px) saturate(180%);backdrop-filter:blur(22px) saturate(180%);
  text-shadow:0 1px 8px rgba(0,8,40,.45);
  box-shadow:0 8px 30px rgba(0,0,255,.34),inset 0 1px 0 rgba(255,255,255,.40),inset 0 -10px 20px rgba(0,0,255,.10);
}
.btn-blue:hover{
  color:#fff;
  background:linear-gradient(180deg,rgba(80,116,255,.46),rgba(0,0,255,.26));
  border-color:rgba(150,178,255,.70);
  box-shadow:0 14px 40px rgba(0,0,255,.42),0 0 26px rgba(0,229,255,.20),inset 0 1px 0 rgba(255,255,255,.55),inset 0 -10px 20px rgba(0,0,255,.14);
}
/* Shared focus ring for glass controls that aren't .btn */
.menu-btn:focus-visible,.mm-chat:focus-visible,.share-btn:focus-visible,
.chat-fab:focus-visible,.chat-toggle:focus-visible,.chat-input button:focus-visible,
.suggestion-chip:focus-visible,.chat-suggestions-toggle:focus-visible,
.chat-suggest-toggle:focus-visible,.chat-back:focus-visible,.faq-q:focus-visible{
  outline:2px solid var(--accent-cyan);outline-offset:2px;
}
/* .faq-item clips overflow, so the ring must sit inside the row */
.faq-q:focus-visible{outline-offset:-2px}
/* Legible fills when backdrop-filter isn't supported — glass needs a frosted fallback */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .btn-white,.btn-art-primary,.btn-ghost,.btn-ghost-dark,.plan .btn-tpl,
  .menu-btn,.share-btn,.suggestion-chip,.chat-suggestions-toggle,.chat-suggest-toggle,.chat-back{
    background:rgba(22,30,52,.92);
  }
  .btn-blue,.chat-fab,.chat-toggle,.chat-input button{
    background:linear-gradient(180deg,rgba(60,96,255,.92),rgba(0,0,255,.84));
  }
  .btn-wa,.btn-art-wa{background:rgba(4,46,30,.92)}
  .mm-chat{background:rgba(0,40,46,.92)}
}
.btn-ghost-dark,
.btn-ghost{
  color:#fff;
  /* quiet liquid glass — faint frosted sheet instead of a flat outline */
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.26);
  -webkit-backdrop-filter:blur(18px) saturate(160%);backdrop-filter:blur(18px) saturate(160%);
  box-shadow:0 6px 20px rgba(5,13,26,.25),inset 0 1px 0 rgba(255,255,255,.30);
}
.btn-ghost-dark:hover,
.btn-ghost:hover{
  color:var(--accent-cyan);
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.05));
  border-color:rgba(0,229,255,.55);
  box-shadow:0 8px 26px rgba(5,13,26,.32),0 0 20px rgba(0,229,255,.14),inset 0 1px 0 rgba(255,255,255,.40);
}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn.full{width:100%}

/* Full-width buttons on mobile */
@media (max-width: 480px){
  .btn.full-mobile{width:100%}
  /* Stack hero CTAs left-aligned; they hug their label instead of stretching */
  .hero .ctas{flex-direction:column;flex-wrap:nowrap;align-items:flex-start}
  .hero .ctas .btn{width:auto;max-width:300px}
}

/* ====== HEROES ====== */
.hero{
  position:relative;
  min-height:92dvb; /* dynamic viewport height for mobile address bar */
  min-height:92vh; /* fallback */
  padding:var(--space-12) 0 var(--space-16);
  display:flex;align-items:center;
  text-align:center;
}
.hero.left{text-align:left;align-items:center}
.hero .wrap{position:relative;z-index:5}

/* Mobile-first hero spacing */
@media (max-width: 480px){
  .hero{min-height:85dvb;padding:var(--space-16) 0 var(--space-12)}
  .hero .wrap{padding-top:env(safe-area-inset-top, 0)}
}
@media (min-width: 640px){
  .hero{padding:var(--space-12) 0 var(--space-16)}
}
@media (min-width: 980px){
  .hero{padding:var(--space-12) 0 var(--space-16)}
}

.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(800px 600px at 50% 50%, rgba(0,229,255,0.18), transparent 60%),
    radial-gradient(900px 700px at 0% 100%, rgba(0,7,168,0.35), transparent 60%);
  pointer-events:none;z-index:2;
}
.hero .grid-overlay{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at center, black 25%, transparent 75%);
}
.hero.short{min-height:60dvb;padding:var(--space-12) 0 var(--space-10)}
@media (max-width: 480px){
  .hero.short{min-height:auto;padding:var(--space-10) 0 var(--space-8)}
}
.hero h1.h1{margin:var(--space-4) auto var(--space-5);max-width:18ch}
.hero.left h1.h1{margin-left:0;margin-right:0}
.hero .sub{
  color:rgba(255,255,255,.85);font-size:var(--text-lg);
  max-width:60ch;margin:0 auto var(--space-8);line-height:1.55
}
.hero.left .sub{margin-left:0;margin-right:0;max-width:46ch}
@media (min-width:980px){
  /* anchor the copy to the left ~half; let the artwork breathe on the right */
  .hero.left .sub{max-width:40ch}
}
.hero .ctas{
  display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center;
  width:100%
}
.hero.left .ctas{justify-content:flex-start}
/* Lock the left-anchored hero (home) so heading, paragraph and CTAs
   all begin at one shared left edge on desktop */
.hero.left h1.h1,
.hero.left .sub,
.hero.left .ctas{margin-left:0;padding-left:0}
.hero.left .ctas{align-items:flex-start}
/* Hero heading accent: electric blue (#0000FF), cyan stays cyan elsewhere */
.hero .h1 .cyan{
  color:var(--accent-electric);
  text-shadow:0 2px 24px rgba(0,8,26,.5);
}
.hero .badge{
  display:inline-flex;align-items:center;gap:var(--space-2);
  padding:var(--space-2) var(--space-4);border-radius:9999px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;
  backdrop-filter:blur(4px);
}
.hero .badge .pulse{
  width:7px;height:7px;background:var(--accent-cyan);border-radius:50%;
  box-shadow:0 0 10px var(--accent-cyan);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* ====== CARDS ====== */
.card{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:16px;
  padding:var(--space-6);
  transition:transform .2s,border-color .25s;
}
.card:hover{border-color:rgba(255,255,255,.16);transform:translateY(-2px)}
.card:active{transform:translateY(0) scale(0.99)}
.card-icon{
  width:56px;height:56px;border-radius:12px;
  background:var(--brand-blue);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 8px 24px rgba(0,0,255,.3);
  flex-shrink:0;
}
.card-icon.small{width:44px;height:44px;border-radius:10px}
.card-icon svg{width:28px;height:28px}
.card-icon.small svg{width:22px;height:22px}
.card h3{font-size:var(--text-xl);font-weight:700;margin:var(--space-5) 0 var(--space-2);color:#fff;letter-spacing:-0.01em}
.card p{color:var(--text-grey);font-size:var(--text-base);margin:0;line-height:1.6}

/* Feature panel — one hairline-divided surface, icon inline beside heading.
   Replaces the boxed 3-equal-column icon-tile grid. */
.feature-grid{
  display:grid;grid-template-columns:1fr;
  border:1px solid var(--hairline);border-radius:18px;overflow:hidden;
  background:rgba(255,255,255,.012);
}
.feature{
  display:grid;grid-template-columns:auto 1fr;column-gap:var(--space-4);row-gap:var(--space-2);
  align-items:start;padding:var(--space-6);
  border-bottom:1px solid var(--hairline);transition:background .25s;
}
.feature:last-child{border-bottom:none}
.feature:hover{background:var(--surface-card)}
.feature-ico{
  grid-column:1;grid-row:1;
  width:44px;height:44px;border-radius:11px;
  display:grid;place-items:center;color:var(--accent-cyan);
  background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.20);
}
.feature-ico svg{width:22px;height:22px}
.feature h3{grid-column:2;grid-row:1;align-self:center;font-size:var(--text-lg);font-weight:700;margin:0;color:#fff;letter-spacing:-0.01em}
.feature p{grid-column:2;margin:0;color:var(--text-grey);font-size:var(--text-base);line-height:1.6}
@media (min-width:680px){
  .feature-grid{grid-template-columns:1fr 1fr}
  .feature:nth-child(odd){border-right:1px solid var(--hairline)}
  .feature:nth-last-child(-n+2){border-bottom:none}
}

.grid{display:grid;gap:var(--space-4)}
.grid.cols-2{grid-template-columns:1fr}
.grid.cols-3{grid-template-columns:1fr}
.grid.cols-4{grid-template-columns:1fr}
@media (min-width:640px){
  .grid{gap:var(--space-5)}
  .grid.cols-2{grid-template-columns:1fr 1fr}
  .grid.cols-4{grid-template-columns:1fr 1fr}
}
@media (min-width:980px){
  .grid{gap:var(--space-5)}
  .grid.cols-3{grid-template-columns:repeat(3,1fr)}
  .grid.cols-4{grid-template-columns:repeat(4,1fr)}
}
@media (min-width:1280px){
  .grid{grid-template-columns:repeat(4,1fr)}
}

.section-head{margin-bottom:var(--space-10);text-align:center}
.section-head .eyebrow{margin-bottom:var(--space-3)}
.section-head .lede{margin:var(--space-3) auto 0}
.section-head.left{text-align:left}
.section-head.left .lede{margin-left:0}

/* ====== STEPS ====== */
.step-card{padding:var(--space-8) var(--space-6)}
.step-circle{
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #2030FF, var(--brand-blue) 55%, var(--brand-blue-deep) 100%);
  display:grid;place-items:center;
  margin:0 auto var(--space-4);color:#fff;position:relative;
  box-shadow:0 12px 50px rgba(0,0,255,.45),inset 0 0 0 1px rgba(255,255,255,.18);
}
.step-circle svg{width:46px;height:46px}
.step-circle .num{
  position:absolute;top:-6px;right:-6px;
  background:#0A0A0A;border:1px solid rgba(255,255,255,.2);
  border-radius:9999px;padding:5px 11px;
  font-size:var(--text-xs);font-weight:800;color:#fff;letter-spacing:.06em;
}
.step-card h3,.step-card p{text-align:center}
.step-card p{max-width:36ch;margin:var(--space-2) auto 0}

/* ====== PRICING ====== */
.pricing-card{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:18px;
  padding:var(--space-6);
  transition:background .25s,border-color .25s,transform .15s,box-shadow .25s;
  cursor:pointer;position:relative;
  display:flex;flex-direction:column;gap:0;
  min-height:var(--touch-target-min);
}
.pricing-card:hover{border-color:rgba(255,255,255,.16)}
.pricing-card:active{transform:scale(0.99)}
.pricing-card .top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}
.pricing-card .radio{
  width:28px;height:28px;border-radius:50%;
  border:2px solid rgba(255,255,255,.32);
  display:grid;place-items:center;flex:none;
  transition:border-color .2s,background .2s;
}
.pricing-card .radio::after{content:'';width:12px;height:12px;border-radius:50%;background:transparent;transition:background .2s}
.pricing-card .name{font-size:var(--text-xl);font-weight:700;color:#fff;flex:1}
.pricing-card .price{font-size:var(--text-2xl);font-weight:800;letter-spacing:-0.02em;color:var(--accent-electric);line-height:1}
.pricing-card .price small{font-size:var(--text-xs);font-weight:600;color:var(--text-grey);letter-spacing:0;display:block;margin-top:var(--space-1)}
.pricing-card .desc{color:var(--text-grey);font-size:var(--text-base);margin:var(--space-2) 0 0;line-height:1.55}
.pricing-card .popular{
  position:absolute;top:-10px;left:var(--space-4);
  background:#0000FF;color:#fff;
  border-radius:9999px;padding:var(--space-1) var(--space-3);
  font-size:var(--text-xs);font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 6px 20px rgba(0,0,255,.35);
}
/* selected card has a #0000FF background — keep its price legible in white */
.pricing-card.selected .price{color:#fff}
.pricing-card.selected{
  background:var(--brand-blue);
  border-color:transparent;color:#fff;
  box-shadow:0 16px 48px rgba(0,0,255,.45);
}
.pricing-card.selected .desc{color:rgba(255,255,255,.9)}
.pricing-card.selected .radio{border-color:#fff;background:#fff}
.pricing-card.selected .radio::after{background:var(--brand-blue)}
.pricing-card.selected .price small{color:rgba(255,255,255,.75)}
.pricing-card .expand{
  width:100%;margin-top:auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--space-2) var(--space-3);border-radius:10px;
  background:rgba(255,255,255,.06);
  font-size:var(--text-sm);font-weight:600;color:var(--text-grey);
  min-height:var(--touch-target-min);
}
.pricing-card.selected .expand{background:rgba(255,255,255,.18);color:#fff}
.pricing-card .expand svg{width:16px;height:16px;transition:transform .25s}
.pricing-card.open .expand svg{transform:rotate(180deg)}
.pricing-card .includes{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--text-grey);font-size:var(--text-base)}
.pricing-card.selected .includes{color:rgba(255,255,255,.9)}
.pricing-card.open .includes{max-height:520px}
.pricing-card .includes ul{list-style:none;padding:var(--space-3) var(--space-1) var(--space-1);margin:0;display:flex;flex-direction:column;gap:var(--space-2)}
.pricing-card .includes li{display:flex;gap:var(--space-2);align-items:flex-start;font-size:var(--text-base);min-height:var(--touch-target-min)}
.pricing-card .includes li::before{
  content:'';width:18px;height:18px;flex:none;margin-top:var(--space-1);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2300E676' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M3 8.5l3 3 7-7'/></svg>");
  background-size:contain;background-repeat:no-repeat;
}
.pricing-card.selected .includes li::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M3 8.5l3 3 7-7'/></svg>");
}
/* Roomier, less cramped pricing + monthly cards on phones */
@media (max-width:480px){
  .pricing-card{padding:var(--space-5)}
  .pricing-card .top{align-items:flex-start;gap:var(--space-2)}
  .pricing-card .name{font-size:var(--text-lg)}
  .pricing-card .price{font-size:var(--text-xl);text-align:right;white-space:nowrap}
  .plan-card{padding:var(--space-5)}
  .plan-card .name{font-size:var(--text-lg)}
  .plan-card .price{font-size:var(--text-xl)}
}

/* ====== MONTHLY ====== */
.plan-card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:16px;padding:var(--space-6);
  display:flex;align-items:flex-start;gap:var(--space-4);
  transition:opacity .25s;
}
.plan-card .body{flex:1}
.plan-card .head-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);flex-wrap:wrap}
.plan-card .name{font-size:var(--text-xl);font-weight:700;color:#fff}
.plan-card .price{font-size:var(--text-2xl);font-weight:800;color:var(--accent-electric);letter-spacing:-0.02em;margin-top:var(--space-1)}
.plan-card .price small{font-size:var(--text-xs);color:var(--text-grey);font-weight:600}
.plan-card .desc{font-size:var(--text-base);color:var(--text-grey);margin:var(--space-2) 0 0}
.req-badge{
  background:var(--brand-blue);color:#fff;
  border-radius:9999px;padding:var(--space-1) var(--space-2);
  font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  white-space:nowrap;
}
/* Care row: keep the title and switch on one line, switch pinned right */
.care-head{flex-wrap:nowrap;justify-content:space-between;gap:var(--space-3)}
.care-head .name{flex:1;min-width:0}
.toggle{
  width:46px;height:28px;border-radius:9999px;flex:none;cursor:pointer;padding:0;
  position:relative;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  transition:background .25s ease,border-color .25s ease,box-shadow .25s ease;
}
/* invisible 44px hit target — keeps the visual pill slim without losing tap size */
.toggle::after{content:'';position:absolute;inset:-8px;border-radius:inherit}
.toggle:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(0,229,255,.40)}
.toggle.on{
  background:linear-gradient(180deg,#2A3CFF,var(--brand-blue));
  border-color:rgba(120,150,255,.55);
  box-shadow:0 0 16px rgba(0,0,255,.40), inset 0 1px 0 rgba(255,255,255,.25);
}
.toggle-thumb{
  position:absolute;top:50%;left:3px;width:22px;height:22px;border-radius:50%;
  background:#fff;box-shadow:0 2px 6px rgba(0,8,26,.45);
  transform:translateY(-50%);
  transition:transform .25s cubic-bezier(0.2,0.7,0.2,1);
}
.toggle.on .toggle-thumb{transform:translate(18px,-50%)}
@media (prefers-reduced-motion:reduce){.toggle-thumb{transition:none}}
.replaces-note{
  font-size:var(--text-sm);color:var(--text-grey);margin-top:var(--space-3);
  padding:var(--space-2) var(--space-3);border-radius:10px;
  background:rgba(0,0,255,.08);border:1px solid rgba(0,0,255,.22);
}

/* ====== SUMMARY ====== */
.summary{border-radius:16px;overflow:hidden;border:1px solid var(--hairline);background:var(--surface-card)}
.summary-head{
  background:var(--brand-blue);color:#fff;padding:18px 22px;
  font-weight:700;font-size:17px;letter-spacing:-0.01em;
  display:flex;align-items:center;justify-content:space-between;
}
.summary-head svg{width:18px;height:18px}
.summary-list{padding:8px 22px}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--hairline);font-size:15px}
.summary-row:last-child{border-bottom:none}
.summary-row .lbl b{color:#fff;font-weight:600;display:block;font-size:15.5px}
.summary-row .lbl small{display:block;font-size:12px;color:var(--text-grey);margin-top:2px}
.summary-row .val{color:#fff;font-weight:700}
.summary-totals{padding:6px 22px 22px}
.summary-totals .row{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;margin-top:8px;border-radius:10px;
  background:rgba(255,255,255,.04);
  font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--text-grey);
}
.summary-totals .row.year1{
  background:var(--brand-blue);color:#fff;
  box-shadow:0 12px 32px rgba(0,0,255,.35);
}
.summary-totals .row .v{font-size:22px;font-weight:800;letter-spacing:-0.02em;text-transform:none;color:#fff}
.summary-totals .row .v small{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);margin-left:4px;letter-spacing:0;text-transform:none}

/* ====== WORK GRID ====== */
.work-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media (min-width:720px){.work-grid{grid-template-columns:1fr 1fr}}
.work-card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:16px;overflow:hidden;
  transition:transform .25s,border-color .25s;
}
.work-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.18)}
.work-preview{
  aspect-ratio:16/10;position:relative;overflow:hidden;
  background:linear-gradient(135deg, #0A0A14, #16162a);
  border-bottom:1px solid var(--hairline);
  display:grid;place-items:center;
}
.work-preview::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(0,0,255,.4), transparent 50%),
             radial-gradient(circle at 70% 70%, rgba(0,229,255,.25), transparent 50%);
}
.work-preview .url{
  position:relative;z-index:2;
  font-family:monospace;font-size:13px;color:rgba(255,255,255,.7);
  padding:8px 14px;border-radius:9999px;
  background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(8px);
}
.work-meta{padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.work-meta .industry{font-family:monospace;font-size:11px;color:var(--text-grey-soft);letter-spacing:.1em;text-transform:uppercase}
.work-meta h3{font-size:18px;margin-top:4px}

/* ====== BENEFITS COMPARE ====== */
.compare{border:1px solid var(--hairline);border-radius:18px;overflow:hidden;background:var(--surface-card)}
.compare-row{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;align-items:stretch;border-top:1px solid var(--hairline)}
.compare-row:first-child{border-top:none;background:rgba(255,255,255,.03)}
.compare-cell{padding:16px 18px;font-size:14.5px;color:var(--text-grey)}
.compare-cell.head{font-family:Inter;font-weight:700;font-size:14px;color:#fff}
.compare-cell.us{background:rgba(0,0,255,.1);font-weight:600;color:#fff;border-left:1px solid rgba(0,0,255,.3);border-right:1px solid rgba(0,0,255,.3)}
.compare-cell.row-label{font-weight:600;color:#fff}
@media (max-width:780px){
  .compare-row{grid-template-columns:1.4fr 1fr}
  .compare-cell:nth-child(3),.compare-cell:nth-child(4){display:none}
}

/* ====== FAQ ====== */
.faq-cat{
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand-blue);color:#3D52FF;margin:40px 0 14px;
}
.faq-cat:first-of-type{margin-top:0}
.faq-item{
  background:var(--surface-card);border:1px solid var(--hairline);border-radius:16px;
  margin-bottom:10px;overflow:hidden;
}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:22px 24px;text-align:left;
  font-size:16px;font-weight:600;color:#fff;line-height:1.4;
}
.faq-icon{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(180deg,rgba(60,96,255,.44),rgba(0,0,255,.24));
  border:1px solid rgba(120,150,255,.50);
  -webkit-backdrop-filter:blur(12px) saturate(160%);backdrop-filter:blur(12px) saturate(160%);
  display:grid;place-items:center;
  flex:none;transition:transform .25s ease;
}
.faq-icon svg{width:16px;height:16px;color:#fff}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--text-grey);font-size:15px;padding:0 24px}
.faq-item.open .faq-a{max-height:520px;padding-bottom:22px}

/* ====== CONTACT ====== */
.contact-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:880px){.contact-grid{grid-template-columns:repeat(3,1fr)}}
.contact-card{
  position:relative;overflow:hidden;
  padding:32px 28px;border-radius:20px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.015));
  -webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%);
  box-shadow:0 12px 40px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.10);
  transition:transform .3s cubic-bezier(0.2,0.7,0.2,1),border-color .25s,box-shadow .3s;
}
.contact-card:hover{
  transform:translateY(-5px);
  border-color:rgba(0,229,255,.35);
  box-shadow:0 22px 60px rgba(0,0,255,.22), 0 0 0 1px rgba(0,229,255,.12), inset 0 1px 0 rgba(255,255,255,.14);
}
.contact-card.primary{
  background:linear-gradient(160deg, rgba(0,230,118,.18), rgba(5,20,18,.30));
  border-color:rgba(0,230,118,.32);
}
.contact-card.primary:hover{
  border-color:rgba(0,230,118,.55);
  box-shadow:0 22px 60px rgba(0,230,118,.22), inset 0 1px 0 rgba(255,255,255,.16);
}
.contact-card.primary::before{
  content:'';position:absolute;right:-50px;top:-50px;
  width:220px;height:220px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle, rgba(0,230,118,.28), transparent 62%);
}
.contact-card h3{margin:16px 0 8px;font-size:20px;font-weight:700;letter-spacing:-0.01em}
.contact-card p{color:var(--text-grey);font-size:14.5px;margin:0 0 20px;line-height:1.55}
.contact-card.primary p{color:rgba(255,255,255,.82)}
.contact-card .ic{
  width:54px;height:54px;border-radius:15px;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(180deg, rgba(60,96,255,.40), rgba(0,0,255,.18));
  border:1px solid rgba(120,150,255,.45);
  box-shadow:0 8px 22px rgba(0,0,255,.30), inset 0 1px 0 rgba(255,255,255,.30);
}
.contact-card .ic svg{width:26px;height:26px}
.contact-card.primary .ic{
  background:linear-gradient(180deg, rgba(0,230,118,.55), rgba(0,180,90,.30));
  border-color:rgba(0,230,118,.6);
  box-shadow:0 8px 22px rgba(0,230,118,.35), inset 0 1px 0 rgba(255,255,255,.35);
  color:#04140C;
}
/* third card (location) gets a cyan/violet tile for variety */
.contact-grid .contact-card:nth-child(3) .ic{
  background:linear-gradient(180deg, rgba(0,229,255,.40), rgba(140,98,255,.22));
  border-color:rgba(0,229,255,.45);
  box-shadow:0 8px 22px rgba(0,229,255,.28), inset 0 1px 0 rgba(255,255,255,.30);
}

/* ====== FORM ====== */
.field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}
.field label{font-size:var(--text-xs);font-weight:700;color:var(--text-grey);letter-spacing:.06em;text-transform:uppercase}
.field input,.field textarea,.field select{
  font-family:inherit;font-size:16px; /* 16px prevents iOS zoom on focus */
  padding:var(--space-3) var(--space-4);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  background:rgba(255,255,255,.04);color:#fff;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  transition:border-color .15s,box-shadow .15s,background .15s;
  min-height:var(--touch-target-min);
  -webkit-appearance:none; /* Remove iOS default styling */
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--accent-cyan);
  background:rgba(255,255,255,.06);
  box-shadow:0 0 0 4px rgba(0,229,255,.16);
}
.field textarea{resize:vertical;min-height:140px}
.field input::placeholder,.field textarea::placeholder{color:var(--text-grey-soft)}

/* Select dropdown arrow */
.field select{padding-right:var(--space-10);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238A8A93' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:20px}

/* ====== BLOG ====== */
.blog-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media (min-width:720px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:16px;overflow:hidden;
  transition:transform .25s,border-color .25s;
  display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.18)}
.blog-cover{
  aspect-ratio:16/10;position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--brand-blue-deep), var(--brand-blue));
}
.blog-cover::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(400px 200px at 70% 30%, rgba(0,229,255,.4), transparent 60%);
}
.blog-cover .tag{
  position:absolute;top:14px;left:14px;z-index:2;
  font-family:monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 12px;border-radius:9999px;
  background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.18);
  color:#fff;backdrop-filter:blur(8px);
}
.blog-body{padding:24px;display:flex;flex-direction:column;gap:8px;flex:1}
.blog-body .date{font-family:monospace;font-size:11.5px;color:var(--text-grey-soft);letter-spacing:.06em}
.blog-body h3{font-size:18px;margin:6px 0 4px;line-height:1.3}
.blog-body p{font-size:14.5px;color:var(--text-grey);margin:0;flex:1}
.blog-body .read{margin-top:14px;font-size:13.5px;font-weight:700;color:var(--accent-cyan);display:inline-flex;gap:6px;align-items:center}

/* clickable card link wrapper */
a.blog-card{text-decoration:none;color:inherit;display:flex;flex-direction:column}
a.blog-card:hover .read{gap:10px}

/* svg cover fills the cover area */
.blog-cover svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.blog-cover{background:#0A0A0F}
.blog-cover::before{display:none}
.blog-cover .tag{
  background:rgba(10,10,15,.6);
  border:1px solid rgba(255,255,255,.18);
}

/* featured (first) card spans 2 cols on wide */
@media (min-width:1024px){
  .blog-grid{grid-template-columns:repeat(3,1fr);grid-auto-flow:dense}
  a.blog-card.featured{grid-column:span 2;flex-direction:row}
  a.blog-card.featured .blog-cover{flex:1.1;aspect-ratio:auto}
  a.blog-card.featured .blog-body{flex:1;padding:36px;justify-content:center}
  a.blog-card.featured h3{font-size:26px;letter-spacing:-0.01em;line-height:1.18}
  a.blog-card.featured .blog-body p{font-size:15.5px;max-width:42ch}
}

/* ====== BLOG POST ARTICLE ====== */
.post{position:relative}
.post-hero{position:relative;min-height:62vh;min-height:62svh;display:flex;align-items:flex-end;padding:140px 0 60px;overflow:hidden}
.post-cover{position:absolute;inset:0;z-index:0}
.post-cover svg{position:absolute;inset:0;width:100%;height:100%;display:block}
/* Smooth, hero-style fade into the page background — no hard seam where the
   cover meets the article body (both resolve to var(--bg-black)). */
.post-cover::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(5,13,26,.28) 0%,
    rgba(5,13,26,.16) 34%,
    rgba(5,13,26,.50) 72%,
    rgba(5,13,26,.86) 90%,
    var(--bg-black) 100%);
}
.post-hero-inner{position:relative;z-index:2;width:100%}
.post-hero .back-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;letter-spacing:.06em;
  color:rgba(255,255,255,.7);
  padding:8px 14px 8px 10px;border-radius:9999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  transition:background .2s,color .2s;
  margin-bottom:24px;
}
.post-hero .back-link:hover{background:rgba(255,255,255,.12);color:#fff}
.post-hero .back-link svg{width:14px;height:14px}
.post-tag{
  display:inline-block;
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#00B4D8;
  background:rgba(0,180,216,.12);
  border:1px solid rgba(0,180,216,.28);
  padding:6px 12px;border-radius:9999px;
}
.post-title{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(36px,5.4vw,68px);
  font-weight:600;line-height:1.04;letter-spacing:-0.02em;
  color:#fff;margin:18px 0 18px;max-width:18ch;
  text-wrap:balance;
}
.post-meta{
  display:flex;gap:10px;align-items:center;
  color:rgba(255,255,255,.65);
  font-size:13.5px;font-family:monospace;letter-spacing:.06em;
}
.post-meta .sep{opacity:.5}

.post-body{padding:56px 28px 80px}
.post-prose{font-size:19px;line-height:1.75;color:#E2E2E8;font-weight:400}
.post-prose p{margin:0 0 22px}
.post-prose p:first-of-type::first-line{font-weight:600;color:#fff}
.post-prose em{color:#9BE1F2;font-style:italic;font-family:'Playfair Display',Georgia,serif;font-weight:500}
.post-prose strong{color:#fff;font-weight:700}
.post-prose a{color:#00B4D8;text-decoration:underline;text-underline-offset:3px}

.post-prose p:first-of-type:first-letter{
  font-family:'Playfair Display',Georgia,serif;
  float:left;font-weight:600;
  font-size:78px;line-height:.85;
  padding:6px 12px 0 0;
  color:#fff;
}

@media (max-width:680px){
  .post-prose{font-size:17px;line-height:1.7}
  .post-prose p:first-of-type:first-letter{font-size:60px}
}

.post-cta{
  margin:56px 0 36px;
  background:linear-gradient(135deg,rgba(0,0,255,.14) 0%,rgba(0,180,216,.08) 100%);
  border:1px solid rgba(0,0,255,.28);
  border-radius:18px;
  padding:28px 30px;
  display:grid;grid-template-columns:1fr;gap:20px;align-items:center;
}
@media (min-width:780px){.post-cta{grid-template-columns:1.4fr auto}}
.post-cta-actions{display:flex;gap:10px;flex-wrap:wrap}

.share-bar{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:24px 0 8px;border-top:1px solid var(--hairline);
  margin-top:8px;flex-wrap:wrap;
}
.share-label{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-grey-soft);font-weight:700}
.share-buttons{display:flex;gap:8px;flex-wrap:wrap}
.share-btn{
  display:inline-flex;align-items:center;gap:8px;
  width:42px;height:42px;border-radius:8px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.22);
  -webkit-backdrop-filter:blur(18px) saturate(160%);backdrop-filter:blur(18px) saturate(160%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25);
  color:#fff;cursor:pointer;
  justify-content:center;
  transition:background .2s,border-color .2s,transform .15s,color .2s,width .2s;
}
.share-btn:hover{background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.06));border-color:rgba(255,255,255,.34)}
.share-btn:active{transform:scale(.94)}
.share-btn svg{width:18px;height:18px}
.share-btn.copy{width:auto;padding:0 16px;border-radius:8px;font-size:13px;font-weight:600}
.share-btn.copy span{display:inline}
.share-btn.copy.copied{background:rgba(0,230,118,.16);border-color:rgba(0,230,118,.4);color:#52E59A}

.more-head{text-align:left;margin-bottom:28px}

/* ====== FOOTER ====== */
footer{
  background:linear-gradient(180deg,#000B6E 0%,#000838 100%);
  position:relative;overflow:hidden;padding:80px 0 32px;
}
footer .footer-art{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 32%;z-index:1;pointer-events:none}
/* Footer ambient video: only the clip matching the viewport is shown
   (desktop landscape ≥769px, mobile portrait ≤768px) — same as the hero. */
.footer-art-video--mobile{display:none}
.footer-art-video--desktop{display:block}
@media (max-width:768px){
  .footer-art-video--desktop{display:none}
  .footer-art-video--mobile{display:block}
}
footer .footer-art-scrim{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(5,13,26,.58) 0%,
    rgba(5,13,26,.74) 52%,
    rgba(5,13,26,.90) 100%);
}
footer .constellation{position:absolute;inset:0;pointer-events:none;z-index:3;opacity:.6}
footer .wrap{position:relative;z-index:4}
/* Dissolve the footer in from the page canvas at the top — the mirror of the
   hero artwork fading out into the same #0A0A0A black. Sits above the art,
   scrim and constellation but below the content, so text stays crisp. */
footer::after{
  content:'';position:absolute;left:0;right:0;top:0;height:36%;
  z-index:3;pointer-events:none;
  background:linear-gradient(180deg,
    var(--bg-black) 0%,
    var(--bg-black) 6%,
    rgba(10,10,10,.62) 34%,
    transparent 100%);
}
/* Ft5 · Statement footer — a closing line, not a sitemap */
.foot-statement{padding-bottom:var(--space-8);border-bottom:1px solid rgba(255,255,255,.10)}
.foot-brandmark{margin-bottom:var(--space-5)}
.foot-line{
  font-family:var(--font-display);
  font-size:clamp(34px,4vw + 1rem,60px);
  font-weight:600;line-height:1.05;letter-spacing:-0.02em;
  color:#fff;margin:0;max-width:18ch;
}
/* Footer accent ("go online.") in electric blue instead of teal */
.foot-line .cyan{color:var(--accent-electric)}
.foot-tagline{color:rgba(255,255,255,.65);font-size:var(--text-base);line-height:1.6;margin:var(--space-4) 0 0;max-width:48ch}
.foot-cta{margin-top:var(--space-6)}
.foot-meta{
  display:flex;flex-direction:column;gap:var(--space-5);
  padding:var(--space-6) 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.foot-nav{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-5)}
.foot-nav a{color:rgba(255,255,255,.72);font-size:var(--text-sm);transition:color .15s}
.foot-nav a:hover{color:#fff}
.foot-contact{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-5)}
.foot-contact a,.foot-contact span{color:rgba(255,255,255,.55);font-size:var(--text-sm)}
.foot-contact a:hover{color:#fff}
@media (min-width:720px){
  .foot-meta{flex-direction:row;align-items:center;justify-content:space-between}
  .foot-nav{flex:1 1 60%}
}
.socials{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.social{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;color:#fff;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  transition:transform .15s, background .2s;
}
.social:hover{transform:translateY(-2px)}
.social.wa{background:var(--whatsapp-green);color:#0a0a0a;border-color:transparent}
.social.ig{background:linear-gradient(135deg,#feda75,#fa7e1e 30%,#d62976 60%,#962fbf 80%,#4f5bd5);border-color:transparent}
.social.li{background:#0A66C2;border-color:transparent}
.social.fb{background:#3A3B3C;border-color:transparent}
.social.tt{background:#fff;color:#000;border-color:transparent}
.social svg{width:20px;height:20px}
.foot-bottom{padding-top:24px;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:rgba(255,255,255,.55);letter-spacing:.02em}
.foot-bottom .legal-row{display:flex;gap:18px;flex-wrap:wrap}
.foot-bottom a:hover{color:#fff}
@media (min-width:720px){
  .foot-bottom{flex-direction:row;justify-content:space-between;align-items:center}
}

/* ====== LEGAL ====== */
.legal-content{max-width:760px;margin:0 auto}
.legal-content h2{font-size:22px;margin:40px 0 12px;color:#fff;font-weight:700}
.legal-content p,.legal-content ul{color:var(--text-grey);font-size:15.5px}
.legal-content ul{padding-left:1.2em}

/* ====== FADE IN ====== */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
.fade-in.in{opacity:1;transform:none}

/* ====== FINAL CTA BLOCK ====== */
.final-cta{
  background:var(--surface-card);border:1px solid var(--hairline);
  border-radius:18px;padding:48px 32px;text-align:center;
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(600px 200px at 50% 0%, rgba(0,0,255,.15), transparent 70%);
}
.final-cta > *{position:relative}
.final-cta h3{font-size:28px;font-weight:800;letter-spacing:-0.02em;margin:0 0 12px;color:#fff}
.final-cta p{color:var(--text-grey);margin:0 0 24px;max-width:46ch;margin-left:auto;margin-right:auto}

/* ====== STATS ====== */
/* Floating, spinning 3D logo — fills the stats strip (production direction) */
.logo-stage{
  display:flex;justify-content:center;align-items:center;
  perspective:1100px;
  position:relative;z-index:2;
}
.float-logo{
  position:relative;
  width:min(360px,72vw);
  aspect-ratio:594 / 379;
  transform-style:preserve-3d;
  animation:logoSpin 11s linear infinite, logoFloat 4.5s ease-in-out infinite;
  will-change:transform,translate;
}
/* Front + back faces share the same artwork; backface-visibility hides whichever
   face is turned away, so the mirrored half of every rotation is never seen. */
.lf-face{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:contain;
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
  filter:drop-shadow(0 20px 42px rgba(0,0,0,.55)) drop-shadow(0 0 34px rgba(0,229,255,.20));
}
.lf-back{transform:rotateY(180deg)}
@keyframes logoSpin{
  from{transform:rotateY(0deg)}
  to{transform:rotateY(360deg)}
}
@keyframes logoFloat{
  0%,100%{translate:0 0}
  50%{translate:0 -16px}
}
@media (prefers-reduced-motion:reduce){
  .float-logo{animation:none}
}

/* ====== HOME PRICING (PLAN CARDS) ====== */
.plans{display:flex;flex-direction:column;gap:24px}
.plan{
  position:relative;
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:18px;
  padding:32px 32px 30px;
  transition:border-color .25s,transform .2s;
}
.plan:hover{border-color:rgba(255,255,255,.14)}
.plan .plan-tag{
  display:inline-flex;align-items:center;
  background:#0000FF;
  color:#fff;
  border-radius:9999px;
  padding:6px 14px;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:14px;
}
.plan .plan-tag.green{background:rgba(0,230,118,0.14);color:#52E59A}
.plan .plan-title{
  font-size:clamp(22px,2.3vw,28px);font-weight:800;color:#fff;letter-spacing:-0.02em;
  margin:0;
}
.plan .plan-desc{
  color:var(--text-grey);font-size:15px;line-height:1.6;
  margin:14px 0 0;max-width:62ch;
}
.plan .plan-price{
  position:absolute;top:32px;right:32px;text-align:right;
}
.plan .plan-price .amt{font-size:clamp(28px,3vw,38px);font-weight:800;color:var(--accent-electric);letter-spacing:-0.02em;line-height:1}
.plan .plan-price .per{display:block;font-size:13px;color:var(--text-grey);font-weight:500;margin-top:6px}
@media (max-width:480px){
  .plan{padding:24px 22px 26px}
  .plan .plan-price{top:24px;right:22px}
  .plan .plan-price .amt{font-size:26px}
  /* Keep the title clear of the absolutely-positioned price */
  .plan .plan-title{font-size:20px;padding-right:88px}
}
.plan .plan-divider{
  height:1px;background:var(--hairline);margin:24px 0 22px;
}
.plan .plan-features{
  display:grid;grid-template-columns:1fr;gap:12px 28px;
  margin:0;padding:0;list-style:none;
}
@media (min-width:780px){
  .plan .plan-features{grid-template-columns:1fr 1fr}
}
.plan .plan-features li{
  display:flex;align-items:flex-start;gap:11px;
  color:var(--text-grey);font-size:14.5px;line-height:1.5;
}
.plan .plan-features li::before{
  content:'';flex:none;width:16px;height:16px;margin-top:3px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%237E8CFF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 8 7 12 13 4'/></svg>");
  background-size:contain;background-repeat:no-repeat;
}
.plan .plan-cta{
  display:flex;gap:12px;flex-wrap:wrap;margin-top:26px;
}
.plan .btn-tpl{
  color:#fff;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.26);
  -webkit-backdrop-filter:blur(18px) saturate(160%);backdrop-filter:blur(18px) saturate(160%);
  box-shadow:0 6px 20px rgba(5,13,26,.25),inset 0 1px 0 rgba(255,255,255,.30);
  padding:14px 22px;font-size:14px;
}
.plan .btn-tpl:hover{
  color:var(--accent-cyan);
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.05));
  border-color:rgba(0,229,255,.55);
}
.plan .btn-tpl svg{width:18px;height:18px}

/* popular wrapper */
.plan-popular{
  position:relative;
  border-radius:22px;
  padding:0;
  background:#0000FF;
  box-shadow:0 24px 80px -20px rgba(0,0,255,.55),
             0 0 0 1px rgba(0,0,255,.6);
}
.plan-popular .popular-bar{
  display:flex;align-items:center;justify-content:center;
  padding:11px 16px;
  font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  background:#0000FF;color:#fff;
}
.plan-popular .plan{
  margin:0 4px 4px;border-radius:0 0 19px 19px;
  border:none;
  background:#0F0F16;
}

/* coming soon */
.plan.coming{position:relative;overflow:hidden}
.plan.coming .plan-content{filter:blur(4px);opacity:.4;pointer-events:none}
.plan.coming .plan-content > .plan-cta{display:none}
.plan.coming .coming-overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  text-align:center;
}
.plan.coming .coming-lock{
  width:54px;height:54px;border-radius:50%;
  background:var(--brand-blue);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 12px 36px rgba(0,0,255,.5);
}
.plan.coming .coming-lock svg{width:24px;height:24px}
.plan.coming .coming-title{font-size:20px;font-weight:800;color:#fff;margin:0}
.plan.coming .coming-sub{font-size:14px;color:var(--text-grey);margin:0}

.plans-coming{display:grid;grid-template-columns:1fr;gap:24px;margin-top:24px}
@media (min-width:860px){.plans-coming{grid-template-columns:1fr 1fr}}

/* calc CTA card */
.calc-cta{
  margin-top:24px;
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:18px;
  padding:48px 32px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  transition:border-color .25s;
}
.calc-cta:hover{border-color:rgba(255,255,255,.16)}
.calc-cta .calc-ico{
  width:54px;height:54px;border-radius:14px;
  background:#0000FF;
  display:grid;place-items:center;color:#fff;
  border:1px solid rgba(140,160,255,.5);
}
.calc-cta .calc-ico svg{width:26px;height:26px}
.calc-cta h3{font-size:24px;font-weight:800;color:#fff;margin:6px 0 0;letter-spacing:-0.01em}
.calc-cta p{color:var(--text-grey);font-size:15px;max-width:50ch;margin:0 0 8px;line-height:1.55}

.coming-eyebrow{
  display:flex;align-items:center;gap:14px;
  margin:60px 0 28px;
  color:var(--text-grey-soft);
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
}
.coming-eyebrow::before,.coming-eyebrow::after{
  content:'';flex:1;height:1px;background:var(--hairline);
}

/* ====== TEMPLATE GALLERY MODAL ====== */
.tpl-modal{
  position:fixed;inset:0;z-index:200;
  display:none;align-items:center;justify-content:center;
  padding:24px;
  font-family:var(--font-body);
}
.tpl-modal.open{display:flex}
.tpl-backdrop{
  position:absolute;inset:0;
  background:rgba(5,13,26,.78);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  animation:tplFade .25s ease;
}
@keyframes tplFade{from{opacity:0}to{opacity:1}}
@keyframes tplLift{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}

.tpl-shell{
  position:relative;
  width:100%;max-width:1180px;
  height:calc(100vh - 48px);max-height:calc(100vh - 48px);
  display:flex;flex-direction:column;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(0,0,255,0.16), transparent 55%),
    var(--bg-black-2);
  border:1px solid var(--hairline-strong);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 0 1px var(--hairline) inset;
  animation:tplLift .35s cubic-bezier(.2,.7,.2,1);
}
.tpl-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  border-bottom:1px solid var(--hairline);
  flex:none;
}
.tpl-eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-grey);
}
.tpl-eyebrow b{color:var(--accent-cyan);font-weight:700}
.tpl-close{
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;color:#fff;
  background:rgba(255,255,255,.06);
  border:1px solid var(--hairline);
  transition:background .2s,border-color .2s,transform .15s;
}
.tpl-close:hover{background:rgba(255,255,255,.14)}
.tpl-close:active{transform:scale(.94)}
.tpl-close:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}
.tpl-close svg{width:18px;height:18px}

.tpl-stage{
  position:relative;
  flex:1;min-height:0;
  background:var(--bg-black);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  overflow:hidden;
}
.tpl-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid var(--hairline-strong);
  color:#fff;display:grid;place-items:center;z-index:3;
  transition:background .2s,border-color .2s,transform .15s;
}
.tpl-arrow:hover{background:rgba(0,0,255,.28);border-color:var(--accent-cyan)}
.tpl-arrow:active{transform:translateY(-50%) scale(.93)}
.tpl-arrow:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}
.tpl-arrow.prev{left:18px}
.tpl-arrow.next{right:18px}
.tpl-arrow svg{width:20px;height:20px}

.tpl-frame-wrap{
  position:relative;
  width:100%;max-width:980px;
  height:100%;
  border-radius:14px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.tpl-frame{
  position:absolute;inset:0;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
  overflow:hidden; /* the demo page scrolls inside its own iframe */
}
.tpl-frame.active{opacity:1;pointer-events:auto}

.tpl-thumbs{
  display:flex;gap:10px;justify-content:center;
  padding:16px 24px;
  border-top:1px solid var(--hairline);
  flex:none;
}
.tpl-thumb{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:10px;
  border:1px solid var(--hairline);
  background:rgba(255,255,255,.04);
  color:var(--text-grey);
  font-size:12.5px;font-weight:600;white-space:nowrap;
  cursor:pointer;
  transition:border-color .2s,background .2s,color .2s,transform .15s;
}
.tpl-thumb:hover{transform:translateY(-2px);color:#fff;background:rgba(255,255,255,.08)}
.tpl-thumb.active{border-color:var(--accent-cyan);color:#fff;background:rgba(0,0,255,.18)}
.tpl-thumb:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}
.tpl-thumb .dots{display:inline-flex;gap:4px}
.tpl-thumb .dots i{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.25)}

.tpl-foot{
  padding:18px 24px 22px;
  border-top:1px solid var(--hairline);
  display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;
  flex:none;
}
.tpl-meta h4{margin:0;font-family:var(--font-display);font-size:22px;font-weight:600;color:#fff;letter-spacing:-0.01em}
.tpl-meta p{margin:6px 0 0;font-size:13.5px;color:var(--text-grey);line-height:1.5}
.tpl-foot .btn{padding:14px 22px;font-size:14.5px}

@media (max-width:780px){
  .tpl-modal{padding:0}
  .tpl-shell{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0}
  .tpl-head{padding:12px 16px;gap:12px}
  .tpl-eyebrow{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px;letter-spacing:.12em}
  .tpl-stage{padding:12px}
  .tpl-arrow{width:38px;height:38px}
  .tpl-arrow.prev{left:8px}.tpl-arrow.next{right:8px}
  .tpl-thumbs{padding:12px 16px;gap:8px;overflow-x:auto;scrollbar-width:none;justify-content:flex-start}
  .tpl-thumb{flex:none}
  .tpl-foot{grid-template-columns:1fr;gap:14px;padding:14px 16px 18px;text-align:left}
  .tpl-meta h4{font-size:18px}
  .tpl-meta p{font-size:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
}

/* ====== TEMPLATE FRAMES (standalone demo pages in iframes) ====== */
.tpl-frame iframe{
  width:100%;height:100%;border:0;display:block;background:#fff;
  position:absolute;top:0;left:0;
  transform-origin:0 0; /* JS sets width + scale() to "zoom out" the preview */
}
.tpl-frame-wrap{transition:max-width .35s cubic-bezier(.2,.7,.2,1)}
.tpl-frame-wrap.phone{max-width:392px}

/* device toggle (desktop / phone preview width) */
.tpl-device{display:flex;gap:6px}
.tpl-device .dev{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  color:var(--text-grey);background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(14px) saturate(150%);backdrop-filter:blur(14px) saturate(150%);
  transition:background .2s,border-color .2s,color .2s;
}
.tpl-device .dev svg{width:17px;height:17px}
.tpl-device .dev:hover{background:rgba(255,255,255,.12);color:#fff}
.tpl-device .dev.active{background:rgba(0,0,255,.28);border-color:var(--accent-cyan);color:#fff}
.tpl-device .dev:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}

/* modal footer actions */
.tpl-actions{display:flex;gap:10px;flex-wrap:wrap}
.tpl-actions .btn svg{width:15px;height:15px}

@media (max-width:780px){
  .tpl-device{display:none} /* phones already preview at phone width */
  /* stack the actions: .btn is nowrap, so two on one row clip off-screen */
  .tpl-actions{width:100%;flex-direction:column;gap:8px}
  .tpl-actions .btn{flex:none;width:100%;justify-content:center}
}

/* ============ CHAT LAUNCHER (FAB → dedicated chat page) ============ */
.chat-fab{
  position:fixed;bottom:24px;right:24px;z-index:200;
  width:56px;height:56px;border-radius:16px;
  /* blue liquid glass — frosted tint instead of a solid fill */
  background:linear-gradient(180deg,rgba(60,96,255,.38),rgba(0,0,255,.20));
  border:1px solid rgba(120,150,255,.50);
  -webkit-backdrop-filter:blur(18px) saturate(170%);backdrop-filter:blur(18px) saturate(170%);
  box-shadow:0 8px 32px rgba(0,0,255,0.34),inset 0 1px 0 rgba(255,255,255,.40);
  display:grid;place-items:center;color:#fff;
  transition:transform .2s var(--ease-out),box-shadow .2s;
}
.chat-fab:hover{transform:scale(1.06);box-shadow:0 12px 40px rgba(0,0,255,0.45),0 0 22px rgba(0,229,255,.18),inset 0 1px 0 rgba(255,255,255,.55)}
.chat-fab:active{transform:scale(0.98)}
.chat-fab .chat-icon{width:24px;height:24px;display:block}
.chat-fab .chat-badge{display:flex}
@media (max-width:480px){
  .chat-fab{bottom:env(safe-area-inset-bottom, 16px);right:16px;
    width:var(--touch-target-comfortable);height:var(--touch-target-comfortable)}
}

/* ============ CHAT WIDGET ============ */
.chat-widget{
  position:fixed;bottom:24px;right:24px;z-index:200;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
.chat-toggle{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(180deg,rgba(60,96,255,.38),rgba(0,0,255,.20));
  border:1px solid rgba(120,150,255,.50);
  -webkit-backdrop-filter:blur(18px) saturate(170%);backdrop-filter:blur(18px) saturate(170%);
  box-shadow:0 8px 32px rgba(0,0,255,0.34),inset 0 1px 0 rgba(255,255,255,.40);
  display:grid;place-items:center;color:#fff;
  cursor:pointer;
  transition:transform .2s var(--ease-out),box-shadow .2s;
  position:relative;
}
.chat-toggle:hover{transform:scale(1.06);box-shadow:0 12px 40px rgba(0,0,255,0.45),0 0 22px rgba(0,229,255,.18),inset 0 1px 0 rgba(255,255,255,.55)}
.chat-toggle:active{transform:scale(0.98)}
.chat-toggle[data-state="open"] .chat-icon{display:none}
.chat-toggle[data-state="open"] .chat-icon-close{display:block}
.chat-icon{width:24px;height:24px;display:block}
.chat-icon-close{width:24px;height:24px;display:none}
.chat-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:20px;height:20px;border-radius:9999px;
  background:var(--accent-cyan);color:#000;
  font-size:11px;font-weight:700;line-height:20px;text-align:center;padding:0 6px;
  display:none;align-items:center;justify-content:center;
  animation:pulse 2s infinite;
  box-shadow:0 0 0 2px var(--bg-black),0 0 12px var(--accent-cyan);
}

.chat-window{
  position:absolute;bottom:72px;right:0;
  width:380px;max-width:calc(100vw - 48px);
  height:520px;max-height:calc(100vh - 120px);
  background:var(--bg-black-2);
  border:1px solid var(--hairline);
  border-radius:16px;
  box-shadow:0 24px 64px rgba(0,0,0,0.6),0 0 0 1px rgba(255,255,255,0.04) inset;
  display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateY(16px) scale(0.96);
  transition:opacity .2s,visibility .2s,transform .2s var(--ease-out);
  overflow:hidden;
}
.chat-widget[data-state="open"] .chat-window{
  opacity:1;visibility:visible;transform:translateY(0) scale(1);
}
.chat-header{
  display:flex;align-items:center;gap:12px;
  padding:16px 20px;
  background:rgba(255,255,255,0.02);
  border-bottom:1px solid var(--hairline);
}
.chat-avatar{
  width:36px;height:36px;border-radius:10px;overflow:hidden;
  background:var(--surface-card);
  display:grid;place-items:center;flex-shrink:0;
  box-shadow:0 0 0 1px rgba(255,255,255,.12) inset;
}
.chat-avatar img{width:100%;height:100%;object-fit:cover}
.chat-avatar svg{width:20px;height:20px;stroke:#fff}
.chat-title{flex:1;min-width:0}
.chat-title strong{display:block;font-size:15px;font-weight:700;color:#fff;line-height:1.2}
.chat-title span{font-size:11px;color:var(--text-grey-soft);letter-spacing:0.02em}
.chat-minimize{
  width:32px;height:32px;border-radius:8px;
  background:rgba(255,255,255,0.06);border:1px solid var(--hairline);
  color:var(--text-grey);font-size:20px;line-height:1;
  transition:background .15s,color .15s;
}
.chat-minimize:hover{background:rgba(255,255,255,0.12);color:#fff}

.chat-messages{
  flex:1;overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:12px;
  scroll-behavior:smooth;
}
.chat-message{
  display:flex;gap:10px;max-width:85%;
  animation:fadeUp .3s ease;
}
.chat-message.assistant{align-self:flex-start}
.chat-message.user{align-self:flex-end;flex-direction:row-reverse}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.msg-avatar{
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  display:grid;place-items:center;
}
.chat-message.assistant .msg-avatar{
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--accent-cyan) 100%);
}
.chat-message.user .msg-avatar{
  background:rgba(255,255,255,0.08);border:1px solid var(--hairline);
}
.msg-avatar svg{width:16px;height:16px;stroke:#fff}
.msg-bubble{
  padding:12px 16px;border-radius:14px;
  font-size:14px;line-height:1.5;
  max-width:100%;
}
.chat-message.assistant .msg-bubble{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-bottom-left-radius:4px;
  color:#fff;
}
.chat-message.user .msg-bubble{
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--brand-blue-mid) 100%);
  border-bottom-right-radius:4px;
  color:#fff;
  box-shadow:0 4px 16px rgba(0,0,255,0.3);
}
.msg-bubble p{margin:0 0 8px}
.msg-bubble p:last-child{margin:0}
.msg-bubble ul{margin:8px 0 0;padding-left:18px}
.msg-bubble li{margin:4px 0}

.chat-typing{
  display:none;align-items:center;gap:10px;
  padding:0 16px 16px;color:var(--text-grey-soft);
  font-size:13px;
}
.typing-dots{display:flex;gap:3px}
.typing-dots span{
  width:6px;height:6px;border-radius:50%;
  background:var(--accent-cyan);
  animation:typing 1.4s infinite ease-in-out;
}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,80%,100%{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}

.chat-input{
  display:flex;gap:10px;padding:16px;
  background:rgba(255,255,255,0.02);
  border-top:1px solid var(--hairline);
}
.chat-input input{
  flex:1;padding:12px 16px;border-radius:12px;
  background:var(--surface-card);border:1px solid var(--hairline);
  color:#fff;font-size:14px;font-family:inherit;
  outline:none;transition:border .15s,box-shadow .15s;
}
.chat-input input::placeholder{color:var(--text-grey-soft)}
.chat-input input:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px rgba(0,0,255,0.2)}
.chat-input button{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(180deg,rgba(60,96,255,.38),rgba(0,0,255,.20));
  border:1px solid rgba(120,150,255,.50);
  -webkit-backdrop-filter:blur(18px) saturate(170%);backdrop-filter:blur(18px) saturate(170%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.40);
  color:#fff;display:grid;place-items:center;
  transition:transform .15s,box-shadow .15s;
}
.chat-input button:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(0,0,255,0.34),inset 0 1px 0 rgba(255,255,255,.55)}
.chat-input button:active{transform:scale(0.95)}
.chat-input button svg{width:20px;height:20px}

.chat-suggestions{
  display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 16px;
}
.suggestion-chip{
  padding:8px 14px;border-radius:8px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(14px) saturate(150%);backdrop-filter:blur(14px) saturate(150%);
  color:var(--text-grey);font-size:12px;font-weight:500;font-family:inherit;
  cursor:pointer;transition:background .15s,border .15s,color .15s;
  white-space:nowrap;
}
.suggestion-chip:hover{background:linear-gradient(180deg,rgba(60,96,255,.34),rgba(0,0,255,.18));border-color:rgba(120,150,255,.50);color:#fff}

.chat-suggestions-toggle{
  width:32px;height:32px;border-radius:8px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(14px) saturate(150%);backdrop-filter:blur(14px) saturate(150%);
  color:var(--text-grey);display:grid;place-items:center;
  transition:background .15s,color .15s,transform .2s;
  flex-shrink:0;
}
.chat-suggestions-toggle:hover{background:rgba(255,255,255,0.12);color:#fff}
.chat-suggestions-toggle .chevron{width:18px;height:18px;stroke:currentColor;transition:transform .2s}
.chat-suggestions-toggle[aria-expanded="true"] .chevron{transform:rotate(180deg)}

.chat-widget[data-state="open"] .chat-suggestions.collapsed,
.chat-suggestions[style*="display: none"]{
  display:none !important;
}

/* Mobile adjustments */
@media (max-width:480px){
  .chat-widget{bottom:env(safe-area-inset-bottom, 16px);right:16px;left:16px}
  .chat-window{
    width:100%;
    height:calc(100vh - 100px);
    max-height:calc(100vh - 100px);
    bottom:72px;right:0;left:0;
    border-radius:16px 16px 0 0;
    max-width:none;
  }
  .chat-toggle{
    width:var(--touch-target-comfortable);
    height:var(--touch-target-comfortable);
    border-radius:16px;
    position:fixed;
    bottom:env(safe-area-inset-bottom, 16px);
    right:16px;
    left:auto;
  }
  .chat-messages{padding:var(--space-4)}
  .chat-input{padding:var(--space-4)}
  .chat-input input{font-size:16px;padding:var(--space-3) var(--space-4)}
  .chat-input button{width:var(--touch-target-comfortable);height:var(--touch-target-comfortable)}
  .chat-suggestions{padding:0 var(--space-4) var(--space-4)}
  .suggestion-chip{
    padding:var(--space-2) var(--space-3);
    font-size:var(--text-sm);
    min-height:var(--touch-target-min);
  }
}

/* ============ DEDICATED CHAT PAGE ============ */
.chat-page{
  height:100vh;
  height:100dvh;
  display:flex;flex-direction:column;
  padding-top:calc(env(safe-area-inset-top, 0px) + 12px); /* clear the device status bar; nav is hidden on this page */
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(0,0,255,0.18), transparent 55%),
    var(--bg-black-2);
}
.chat-shell{
  width:100%;max-width:760px;margin:0 auto;
  flex:1;min-height:0;
  display:flex;flex-direction:column;
  padding:0 var(--space-4);
}
.chat-page-head{
  display:flex;align-items:center;gap:12px;
  padding:12px 2px;border-bottom:1px solid var(--hairline);
}
.chat-page-head .chat-status{display:flex;align-items:center;gap:6px}
.chat-online-dot{width:7px;height:7px;border-radius:50%;background:var(--whatsapp-green);box-shadow:0 0 8px var(--whatsapp-green)}
.chat-back{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(14px) saturate(150%);backdrop-filter:blur(14px) saturate(150%);
  color:var(--text-grey);display:grid;place-items:center;
  transition:background .15s,color .15s;
}
.chat-back:hover{background:rgba(255,255,255,0.12);color:#fff}
.chat-back svg{width:20px;height:20px}
.chat-page .chat-messages{flex:1;min-height:0;padding:20px 2px}
.chat-page .chat-typing{padding:0 2px 8px}
.chat-page .chat-suggestions{padding:0 2px 10px}
/* [hidden] must win over the .chat-suggestions display:flex so it can collapse */
.chat-suggestions[hidden]{display:none}
/* Collapsible "Quick questions" toggle — keeps the conversation visible by default */
.chat-suggest-toggle{
  align-self:center;
  display:inline-flex;align-items:center;gap:8px;
  margin:0 auto 8px;padding:8px 16px;border-radius:8px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(14px) saturate(150%);backdrop-filter:blur(14px) saturate(150%);
  color:var(--text-grey);font-size:13px;font-weight:600;font-family:inherit;
  cursor:pointer;transition:background .15s,color .15s;
  min-height:var(--touch-target-min);
}
.chat-suggest-toggle:hover{background:rgba(255,255,255,.08);color:#fff}
.chat-suggest-toggle .chevron{width:16px;height:16px;transition:transform .2s}
.chat-suggest-toggle[aria-expanded="true"] .chevron{transform:rotate(180deg)}
.chat-page .chat-input{
  background:transparent;border-top:1px solid var(--hairline);
  padding:12px 0 calc(14px + env(safe-area-inset-bottom));
}
/* Preserve line breaks from the assistant's plain-text replies */
.chat-page .msg-bubble{white-space:pre-line}

/* ============ ROOMY CHAT LAYOUT (dedicated page only) ============
   Calm, roomy reading layout: the assistant talks in plain text (no bubble),
   the visitor gets a soft bubble, and replies stream in with a caret. Colours
   stay on the Local Web brand (electric blue + cyan). */
.chat-page .chat-messages{gap:22px;padding:24px 2px;scroll-behavior:smooth}
.chat-page .chat-message{max-width:100%;gap:12px;align-items:flex-start}

/* Assistant: small brand avatar + plain flowing text, no bubble */
.chat-page .chat-message.assistant .msg-avatar{
  width:30px;height:30px;border-radius:8px;margin-top:2px;
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--accent-cyan) 100%);
  box-shadow:0 2px 10px rgba(0,0,255,.25);
}
.chat-page .chat-message.assistant .msg-bubble{
  background:transparent;border:0;padding:2px 0;border-radius:0;
  color:#ECECEF;font-size:15.5px;line-height:1.75;
}
/* Visitor: a soft right-aligned bubble */
.chat-page .chat-message.user{max-width:80%}
.chat-page .chat-message.user .msg-avatar{display:none}
.chat-page .chat-message.user .msg-bubble{
  background:linear-gradient(135deg,var(--brand-blue) 0%,var(--brand-blue-mid) 100%);
  border:0;
  border-radius:18px;border-bottom-right-radius:6px;
  padding:11px 16px;color:#fff;font-size:15px;line-height:1.6;
  box-shadow:0 4px 16px rgba(0,0,255,.28);
}

/* Blinking caret shown while Michael is "typing" a reply */
.msg-caret{
  display:inline-block;width:2px;height:1.05em;
  margin-left:2px;vertical-align:-2px;border-radius:1px;
  background:var(--accent-cyan);
  animation:caretBlink 1s steps(1) infinite;
}
@keyframes caretBlink{0%,50%{opacity:1}50.01%,100%{opacity:0}}
@media (prefers-reduced-motion: reduce){.msg-caret{animation:none}}

.chat-page .chat-input input{
  border-radius:16px;font-size:16px;padding:13px 18px;
  background:rgba(255,255,255,.04);
}
.chat-page .chat-input input:disabled{opacity:.55;cursor:not-allowed}

/* Tablet adjustments */
@media (min-width: 481px) and (max-width: 768px){
  .chat-window{width:400px;max-width:calc(100vw - 48px)}
}

/* ==========================================================================
   ART HERO — full-bleed cherry-blossom × cyberpunk artwork backdrop
   Palette pulled from the artwork: coral/blossom pink -> electric cyan/purple
   ========================================================================== */
.hero.has-art{
  background:var(--canvas);
  text-align:center;
  overflow:hidden;
}
/* artwork sits behind everything; the shared ::before glow is not needed */
.hero.has-art::before{display:none}

.hero-art{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-art img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 35%;
  /* gentle, very slow ken-burns drift for life without distraction */
  animation:artDrift 38s ease-in-out infinite alternate;
  will-change:transform;
  /* Dissolve the photo into the black section below — the pixels fade to
     transparent so the page canvas shows through (removes the hard seam). */
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 50%, rgba(0,0,0,.6) 76%, rgba(0,0,0,.18) 92%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 0%, #000 50%, rgba(0,0,0,.6) 76%, rgba(0,0,0,.18) 92%, transparent 100%);
}
@keyframes artDrift{
  from{transform:scale(1.04) translate3d(0,0,0)}
  to{transform:scale(1.12) translate3d(-1.5%,-1.5%,0)}
}

/* Hero videos: ambient art that autoplays muted + loops. Desktop gets the
   landscape clip, phones get the portrait clip; only the matching one is
   shown (and loaded — see the data-src loader in index.html). */
.hero-art-video{
  width:100%;height:100%;
  object-fit:cover;object-position:center 35%;
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 50%, rgba(0,0,0,.6) 76%, rgba(0,0,0,.18) 92%, transparent 100%);
  mask-image:linear-gradient(180deg, #000 0%, #000 50%, rgba(0,0,0,.6) 76%, rgba(0,0,0,.18) 92%, transparent 100%);
}
/* default (desktop): landscape clip visible, portrait clip hidden */
.hero-art-video--mobile{display:none}
.hero-art-video--desktop{display:block}

/* Legibility scrim: darken top (under nav), keep the art's glow mid,
   fade hard into the black section that follows. Plus a soft vignette. */
.hero-art-scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,
      rgba(0,8,26,.62) 0%,
      rgba(0,8,26,.22) 30%,
      rgba(0,8,26,.30) 60%,
      rgba(0,8,26,.78) 88%,
      var(--canvas) 100%),
    radial-gradient(125% 85% at 50% 42%, transparent 34%, rgba(0,8,26,.55) 100%);
}

/* Left-anchored hero: darken the left where the copy sits, let the art breathe right */
.hero.has-art.left{text-align:left}
.hero.has-art.left .hero-art-scrim{
  background:
    linear-gradient(90deg,
      rgba(0,8,26,.84) 0%,
      rgba(0,8,26,.60) 36%,
      rgba(0,8,26,.24) 66%,
      rgba(0,8,26,.05) 100%),
    linear-gradient(180deg,
      transparent 55%,
      rgba(0,8,26,.55) 84%,
      var(--canvas) 100%);
}

/* Make copy crisp over the bright artwork */
.hero.has-art .h1{text-shadow:0 2px 30px rgba(0,8,26,.65),0 1px 4px rgba(0,8,26,.5)}
.hero.has-art .sub{
  color:rgba(255,255,255,.92);
  text-shadow:0 1px 18px rgba(0,8,26,.7);
}
.hero.has-art .eyebrow{text-shadow:0 1px 14px rgba(0,8,26,.7)}
.hero.has-art .badge{
  background:rgba(0,8,26,.32);
  border-color:rgba(255,255,255,.30);
}

/* Stronger scrim on phones (busier vertical art) */
@media (max-width:768px){
  /* phones: show the portrait clip, hide the landscape one */
  .hero-art-video--desktop{display:none}
  .hero-art-video--mobile{display:block}
  .hero-art img,
  .hero-art-video{
    object-position:center 28%;
    /* phones: start the dissolve a little higher so it clears the copy */
    -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 44%, rgba(0,0,0,.55) 72%, rgba(0,0,0,.15) 90%, transparent 100%);
    mask-image:linear-gradient(180deg, #000 0%, #000 44%, rgba(0,0,0,.55) 72%, rgba(0,0,0,.15) 90%, transparent 100%);
  }
  .hero-art-scrim,
  .hero.has-art.left .hero-art-scrim{
    background:
      linear-gradient(180deg,
        rgba(0,8,26,.66) 0%,
        rgba(0,8,26,.34) 26%,
        rgba(0,8,26,.46) 62%,
        rgba(0,8,26,.86) 90%,
        var(--canvas) 100%);
  }
}

/* ---- Art-aligned glass buttons ---- */
.btn-art-primary{
  position:relative;color:#fff;letter-spacing:.01em;
  /* Apple-style liquid-glass primary: bright frosted glass, no fill colour */
  background:linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.42);
  -webkit-backdrop-filter:blur(22px) saturate(180%);backdrop-filter:blur(22px) saturate(180%);
  text-shadow:0 1px 10px rgba(5,13,26,.55);
  box-shadow:
    0 8px 30px rgba(5,13,26,.42),
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -10px 20px rgba(255,255,255,.05);
}
.btn-art-primary svg{transition:transform .25s ease}
.btn-art-primary:hover{
  color:#fff;
  transform:translateY(-3px);
  background:linear-gradient(180deg,rgba(255,255,255,.32),rgba(255,255,255,.12));
  border-color:rgba(255,255,255,.60);
  box-shadow:
    0 14px 46px rgba(5,13,26,.50),
    0 0 26px rgba(0,229,255,.20),
    inset 0 1px 0 rgba(255,255,255,.70),
    inset 0 -10px 20px rgba(255,255,255,.08);
}
.btn-art-primary:hover svg{transform:translateX(4px)}

.btn-art-wa{
  color:#fff;
  /* green-tinted liquid glass so the WhatsApp colour lives in the glass itself */
  background:linear-gradient(180deg,rgba(0,230,118,.16),rgba(5,13,26,.26));
  border:1.5px solid rgba(0,230,118,.42);
  -webkit-backdrop-filter:blur(22px) saturate(180%);backdrop-filter:blur(22px) saturate(180%);
  box-shadow:0 8px 28px rgba(5,13,26,.35),inset 0 1px 0 rgba(255,255,255,.20),0 0 18px rgba(0,230,118,.14);
}
.btn-art-wa svg{color:var(--whatsapp-green);filter:drop-shadow(0 0 6px rgba(0,230,118,.6))}
.btn-art-wa:hover{
  color:#fff;
  transform:translateY(-3px);
  border-color:rgba(0,230,118,.85);
  background:rgba(0,230,118,.10);
  box-shadow:0 12px 38px rgba(0,230,118,.30),0 0 26px rgba(0,230,118,.30);
}

/* Hero CTAs: compact rectangles anchored to the left edge of the copy.
   Shared min-width keeps both buttons exactly the same size. */
.btn-art-primary,
.btn-art-wa{
  border-radius:8px;
  padding:var(--space-3) var(--space-5);
  font-size:var(--text-sm);
  min-width:180px;
}

/* ==========================================================================
   FOOTER — soft blurred blend of the hero palette
   ========================================================================== */
footer::before{
  content:'';position:absolute;inset:-15%;z-index:0;pointer-events:none;
  background:
    radial-gradient(38% 42% at 12% 18%, rgba(255,110,138,.30), transparent 70%),
    radial-gradient(42% 44% at 86% 26%, rgba(0,240,255,.24), transparent 72%),
    radial-gradient(48% 50% at 62% 92%, rgba(140,98,255,.30), transparent 72%),
    radial-gradient(40% 40% at 30% 80%, rgba(0,128,255,.20), transparent 72%);
  filter:blur(70px);
  opacity:.85;
  animation:footBlend 24s ease-in-out infinite alternate;
  will-change:transform,opacity;
}
@keyframes footBlend{
  from{transform:translate3d(-2%,-1%,0) scale(1)}
  to{transform:translate3d(2%,2%,0) scale(1.08)}
}
/* layering: blobs(0) < photo(1) < scrim(2) < constellation(3) < content(4) */
footer .constellation{z-index:3}
footer .wrap{z-index:4}

@media (prefers-reduced-motion:reduce){
  .hero-art img,footer::before{animation:none !important}
}

/* ==========================================================================
   SECONDARY-PAGE HEROES — unified art-palette ambient backdrop
   (About, Pricing, Contact, FAQ, Benefits, Our Work, Blog, etc.)
   These don't have their own artwork yet, so they share a soft blurred blend
   of the cherry-blossom × cyberpunk palette over the near-black canvas.
   Drop in a <picture class="hero-art"> later to give any page real art.
   ========================================================================== */
.hero.blue{
  background:var(--canvas);
  color:#fff;
}
/* Replace the default cyan radial glow with the warm→cool art blend */
.hero.blue::before{
  z-index:0;
  background:
    radial-gradient(52% 62% at 14% 18%, rgba(255,110,138,.26), transparent 70%),
    radial-gradient(56% 66% at 88% 28%, rgba(0,240,255,.22), transparent 72%),
    radial-gradient(62% 72% at 72% 104%, rgba(140,98,255,.28), transparent 72%),
    radial-gradient(50% 60% at 28% 98%, rgba(0,128,255,.18), transparent 72%);
  filter:blur(44px);
  animation:artBlend 26s ease-in-out infinite alternate;
  will-change:transform;
}
/* keep the grid texture sparkling above the blend */
.hero.blue .grid-overlay{z-index:2;opacity:.55}
/* the cyan grid lines read better tinted toward the palette */
.hero.blue .grid-overlay{
  background-image:
    linear-gradient(rgba(0,240,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,240,255,0.05) 1px, transparent 1px);
}

@keyframes artBlend{
  from{transform:translate3d(-2%,-1%,0) scale(1.02)}
  to{transform:translate3d(2%,2%,0) scale(1.12)}
}
@media (prefers-reduced-motion:reduce){
  .hero.blue::before{animation:none !important}
}

/* ==========================================================================
   UNIFIED GLASS SURFACES — frosted cards across the site
   Translucent panels with backdrop-blur, a top specular highlight and a soft
   shadow, so every card reads as the same premium glass material. Selected /
   popular states keep their own (higher-specificity) backgrounds.
   ========================================================================== */
.card,
.pricing-card,
.plan,
.plan-card,
.work-card,
.blog-card,
.faq-item,
.calc-cta,
.summary,
.compare{
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.10);
  -webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 10px 34px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.10);
}
.card:hover,
.pricing-card:hover,
.plan:hover,
.work-card:hover,
.blog-card:hover,
.calc-cta:hover{
  border-color:rgba(0,229,255,.30);
  box-shadow:0 18px 50px rgba(0,0,255,.18), 0 0 0 1px rgba(0,229,255,.10), inset 0 1px 0 rgba(255,255,255,.14);
}
