/* ══════════════════════════════════════════════════════════════
   GUROB BRAND SYSTEM — v3 shared stylesheet
   Single source of truth. Linked by every page.
   Fonts: Cormorant Garamond · Playfair Display · Cinzel · EB Garamond · Josefin Sans
═══════════════════════════════════════════════════════════════ */

/* ──────── TOKENS ──────── */
:root{
  /* Backgrounds */
  --void:       #09090F;
  --surface:    #0F0C1A;
  --surface-2:  #0A0814;
  --nebula:     #1E1A2E;
  --border:     #1E1A2E;

  /* Brand */
  --violet-dark:#2D1A6E;
  --royal-dark: #3B1F6E;
  --violet-core:#5B21B6;
  --purple:     #7C3AED;
  --lavender:   #A78BFA;
  --lilac:      #C4B5FD;
  --ghost:      #EDE9FE;

  /* Text */
  --star-white: #F0EEFF;
  --fg:         #F0EEFF;
  --moon-mist:  #A89EC0;
  --moon:       #A89EC0;
  --ash:        #8F8A9E;   /* was #6B7280 — lifted for readable captions on void */
  --dust:       #7B7090;   /* was #4B4060 — lifted; stays muted but passes AA */

  /* Gradients */
  --g-brand:    linear-gradient(135deg,#C4B5FD 0%,#7C3AED 55%,#4C1D95 100%);
  --g-cta:      linear-gradient(135deg,#7C3AED,#5B21B6);
  --g-flare:    linear-gradient(135deg,#EDE9FE,#C4B5FD,#A78BFA,#7C3AED);
  --g-haze:     linear-gradient(180deg,#1E1A2E 0%,#09090F 100%);

  /* Shadow (purple-tinted, never black) */
  --shadow-sm:  0 2px 6px rgba(124,58,237,0.06);
  --shadow-md:  0 12px 32px rgba(124,58,237,0.12), 0 2px 6px rgba(9,9,15,0.4);
  --shadow-lg:  0 28px 80px rgba(124,58,237,0.18), 0 8px 24px rgba(9,9,15,0.5);

  /* Motion */
  --ease:       cubic-bezier(0.32, 0.72, 0, 1);
  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);

  /* Radii */
  --radius-sm:  8px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-xl:  28px;

  /* Containers */
  --max:        1200px;
  --max-narrow: 880px;
  --max-read:   68ch;
}

/* ──────── RESET + BASE ──────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--void);
  color:var(--star-white);
  font-family:'EB Garamond',Georgia,serif;
  font-size:17px;
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:rgba(124,58,237,0.32);color:var(--ghost);}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:var(--void);}
::-webkit-scrollbar-thumb{background:var(--violet-dark);border-radius:2px;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;background:none;border:none;cursor:pointer;color:inherit;}
input{font-family:inherit;}

/* ──────── SUBTLE GRAIN (optional, per-page) ──────── */
.grain{
  position:fixed;inset:0;z-index:80;pointer-events:none;opacity:0.025;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}

/* ──────── TYPOGRAPHY ROLES (reusable classes) ──────── */
.display{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-weight:300;line-height:1.02;letter-spacing:-0.015em;
  color:var(--fg);
}
.display--xl{font-size:clamp(56px,8vw,104px);}
.display--lg{font-size:clamp(44px,6.2vw,76px);}
.display--md{font-size:clamp(34px,4.6vw,60px);}
.display--gradient{
  background:var(--g-brand);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.heading{
  font-family:'Playfair Display',Georgia,serif;
  font-weight:400;line-height:1.2;letter-spacing:-0.01em;color:var(--fg);
}
.heading--lg{font-size:clamp(32px,4vw,44px);}
.heading--md{font-size:clamp(28px,3.6vw,40px);}
.heading em{color:var(--lavender);font-style:italic;}

.subhead{
  font-family:'Playfair Display',Georgia,serif;
  font-weight:700;line-height:1.25;letter-spacing:-0.01em;color:var(--fg);
  font-size:clamp(20px,2.2vw,24px);
}
.subhead em{color:var(--lavender);font-style:italic;}

.lede{
  font-family:'EB Garamond',Georgia,serif;font-weight:400;
  font-size:clamp(18px,1.4vw,20px);line-height:1.75;color:var(--moon);letter-spacing:-0.005em;
  max-width:var(--max-read);
}
.body{
  font-family:'EB Garamond',Georgia,serif;font-weight:400;
  font-size:17px;line-height:1.8;color:var(--moon);letter-spacing:-0.005em;
  max-width:var(--max-read);
}
.body strong{color:var(--fg);font-weight:500;}
.body em{color:var(--lavender);font-style:italic;}

.quote{
  font-family:'EB Garamond',Georgia,serif;font-weight:400;font-style:italic;
  font-size:clamp(20px,2.4vw,28px);line-height:1.55;color:var(--lilac);
  padding-left:22px;border-left:2px solid var(--purple);letter-spacing:-0.005em;
}
.quote cite{
  display:block;font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--dust);
  margin-top:16px;font-style:normal;
}

.meta{
  font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:11px;letter-spacing:0.12em;color:var(--ash);line-height:1.7;
}
.meta--upper{text-transform:uppercase;letter-spacing:0.2em;}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Cinzel',serif;font-weight:500;
  font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--lilac);
}
.eyebrow--pill{
  padding:7px 16px;border-radius:100px;
  background:rgba(124,58,237,0.06);border:1px solid rgba(124,58,237,0.18);
}
.eyebrow--purple{color:var(--purple);}
.eyebrow .dot{
  width:5px;height:5px;border-radius:50%;background:var(--purple);
  box-shadow:0 0 8px rgba(124,58,237,0.6);
}

/* ──────── CONTAINER ──────── */
.container{max-width:var(--max);margin:0 auto;padding:0 32px;position:relative;z-index:5;}
.container--narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 32px;position:relative;z-index:5;}
@media (max-width:768px){.container,.container--narrow{padding:0 24px;}}

/* ──────── SECTION DIVIDER ──────── */
.section-divider{border:none;border-top:1px solid var(--border);margin:0;position:relative;z-index:5;}

/* Legacy section-label (kept for page-specific content — same role as .eyebrow) */
.section-label{
  display:inline-block;font-family:'Cinzel',serif;font-weight:500;
  font-size:11px;letter-spacing:0.32em;text-transform:uppercase;color:var(--purple);
  margin-bottom:18px;
}

/* ──────── NAV PILL (floating) ──────── */
nav{
  position:fixed!important;top:24px;left:50%;transform:translateX(-50%);
  z-index:200!important;
  display:flex;align-items:center;gap:4px;
  background:rgba(15,12,26,0.78);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04),0 12px 32px rgba(9,9,15,0.55);
  padding:6px;border-radius:100px;
}
.nav-item{
  position:relative;padding:8px 20px;border-radius:100px;
  font-family:'Josefin Sans',sans-serif;font-size:12px;font-weight:400;letter-spacing:0.08em;
  color:var(--moon-mist);transition:color 0.3s var(--ease),background 0.3s var(--ease);
  text-decoration:none;white-space:nowrap;
}
.nav-item:hover{color:var(--star-white);background:rgba(255,255,255,0.04);}
.nav-item.active,.nav-item.is-active{color:var(--star-white);background:rgba(124,58,237,0.15);}
.nav-item.active::before,.nav-item.is-active::before{
  content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%);
  width:32px;height:3px;background:var(--purple);border-radius:0 0 4px 4px;
  box-shadow:0 0 12px var(--purple),0 0 24px rgba(124,58,237,0.4);
}
.nav-cta{
  margin-left:8px;padding:8px 20px;background:var(--purple);color:#fff;
  border-radius:100px;font-family:'Josefin Sans',sans-serif;
  font-size:11px;font-weight:400;letter-spacing:0.12em;text-transform:uppercase;
  transition:background 0.3s var(--ease),transform 0.2s var(--ease),box-shadow 0.3s var(--ease);
  text-decoration:none;
}
.nav-cta:hover{background:var(--violet-core);transform:translateY(-1px);box-shadow:0 8px 20px rgba(124,58,237,0.4);}

/* Nav brand (floating top-left wordmark) */
#nav-brand{
  position:fixed;top:28px;left:36px;z-index:201;
  font-family:'Cormorant Garamond',Georgia,serif;font-weight:400;
  font-size:22px;letter-spacing:0.1em;text-transform:uppercase;
  background:linear-gradient(135deg,#f0eeff,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  display:flex;align-items:center;gap:8px;
  text-decoration:none;opacity:0.85;transition:opacity 0.3s var(--ease);
}
#nav-brand:hover{opacity:1;}

/* Nav phone (floating top-right call CTA) */
#nav-phone{
  position:fixed;top:28px;right:88px;z-index:201;
  display:flex;align-items:center;gap:9px;
  background:rgba(124,58,237,0.14);border:1px solid rgba(124,58,237,0.45);
  backdrop-filter:blur(16px);
  border-radius:100px;padding:8px 18px 8px 12px;
  font-family:'Josefin Sans',sans-serif;font-size:12px;font-weight:400;letter-spacing:0.06em;
  color:var(--star-white);text-decoration:none;
  box-shadow:0 0 16px rgba(124,58,237,0.18);
  transition:border-color 0.3s var(--ease),background 0.3s var(--ease),transform 0.2s var(--ease),box-shadow 0.3s var(--ease);
}
#nav-phone:hover{
  border-color:rgba(167,139,250,0.7);background:rgba(124,58,237,0.25);
  transform:translateY(-1px);box-shadow:0 8px 28px rgba(124,58,237,0.35);
}
#nav-phone .phone-icon-wrap{
  width:26px;height:26px;border-radius:50%;
  background:var(--g-cta);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 0 10px rgba(124,58,237,0.5);
}
#nav-phone svg{width:13px;height:13px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}

@media (max-width:900px){
  #nav-brand{display:none;}
  #nav-phone{display:none;}
}

/* ──────── MOBILE NAV — hamburger + full-screen overlay ──────── */
.nav-toggle,.nav-mobile-logo{display:none;}

@media (max-width:768px){
  /* hide the desktop pill — replaced by hamburger overlay */
  nav{display:none!important;}

  /* mini wordmark, top-left */
  .nav-mobile-logo{
    position:fixed;top:18px;left:22px;z-index:260;
    display:inline-flex;align-items:center;
    font-family:'Cormorant Garamond',Georgia,serif;font-weight:400;
    font-size:19px;letter-spacing:0.14em;text-transform:uppercase;
    background:linear-gradient(135deg,#f0eeff,#a78bfa);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    text-decoration:none;opacity:0.95;
  }

  /* hamburger button, top-right */
  .nav-toggle{
    position:fixed;top:14px;right:16px;z-index:280;
    display:inline-flex;align-items:center;justify-content:center;
    width:44px;height:44px;border-radius:100px;padding:0;
    background:rgba(15,12,26,0.82);border:1px solid var(--border);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    box-shadow:0 8px 20px rgba(9,9,15,0.55);
    cursor:pointer;color:var(--star-white);
    transition:background 0.3s var(--ease),border-color 0.3s var(--ease),transform 0.2s var(--ease);
  }
  .nav-toggle:hover{background:rgba(124,58,237,0.16);border-color:rgba(167,139,250,0.45);}
  .nav-toggle:active{transform:scale(0.96);}
  .nav-toggle-bars{position:relative;width:18px;height:12px;display:block;}
  .nav-toggle-bars span{
    position:absolute;left:0;right:0;height:1.5px;
    background:currentColor;border-radius:2px;transform-origin:center;
    transition:top 0.3s var(--ease),transform 0.4s var(--ease),opacity 0.2s var(--ease);
  }
  .nav-toggle-bars span:first-child{top:2px;}
  .nav-toggle-bars span:last-child{top:8px;}

  /* OPEN STATE */
  body.nav-menu-open{overflow:hidden;}
  body.nav-menu-open .nav-toggle{
    background:rgba(124,58,237,0.24);border-color:rgba(167,139,250,0.6);
  }
  body.nav-menu-open .nav-toggle-bars span:first-child{top:5px;transform:rotate(45deg);}
  body.nav-menu-open .nav-toggle-bars span:last-child{top:5px;transform:rotate(-45deg);}

  /* overlay nav */
  body.nav-menu-open nav{
    display:flex!important;
    position:fixed!important;inset:0;top:0;left:0;transform:none;
    width:100%;height:100dvh;
    flex-direction:column;align-items:flex-start;justify-content:center;
    padding:96px 32px 56px;gap:2px;
    background:
      radial-gradient(circle at 82% 18%,rgba(124,58,237,0.28),transparent 58%),
      radial-gradient(circle at 12% 88%,rgba(196,181,253,0.14),transparent 62%),
      rgba(9,9,15,0.97);
    backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    border:0;border-radius:0;box-shadow:none;
    z-index:250;
    animation:navOverlayIn 0.45s var(--ease) both;
  }
  @keyframes navOverlayIn{from{opacity:0;}to{opacity:1;}}

  body.nav-menu-open nav .nav-item{
    width:100%;
    font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;
    font-size:clamp(34px,9vw,56px);line-height:1.08;letter-spacing:-0.01em;
    text-transform:none;color:var(--star-white);
    padding:10px 0;background:transparent;border-radius:0;white-space:normal;
    opacity:0;transform:translateY(22px);
    animation:navItemIn 0.55s var(--ease) forwards;
  }
  body.nav-menu-open nav .nav-item:hover{background:transparent;color:var(--lilac);}
  body.nav-menu-open nav .nav-item::before{display:none;}
  body.nav-menu-open nav .nav-item.active,
  body.nav-menu-open nav .nav-item.is-active{
    background:transparent;color:var(--lavender);font-style:italic;
  }
  body.nav-menu-open nav .nav-item:nth-child(1){animation-delay:0.10s;}
  body.nav-menu-open nav .nav-item:nth-child(2){animation-delay:0.16s;}
  body.nav-menu-open nav .nav-item:nth-child(3){animation-delay:0.22s;}
  body.nav-menu-open nav .nav-item:nth-child(4){animation-delay:0.28s;}
  body.nav-menu-open nav .nav-item:nth-child(5){animation-delay:0.34s;}
  body.nav-menu-open nav .nav-cta{
    margin:28px 0 0;padding:14px 26px;
    font-family:'Josefin Sans',sans-serif;font-size:12px;letter-spacing:0.14em;
    opacity:0;transform:translateY(22px);
    animation:navItemIn 0.55s var(--ease) 0.42s forwards;
  }
  @keyframes navItemIn{to{opacity:1;transform:translateY(0);}}

  /* hide mobile call bar while menu is open */
  body.nav-menu-open #mobile-call-bar{opacity:0;pointer-events:none;}
}

@media (prefers-reduced-motion:reduce){
  body.nav-menu-open nav,
  body.nav-menu-open nav .nav-item,
  body.nav-menu-open nav .nav-cta{animation:none;opacity:1;transform:none;}
}

/* Mobile floating call bar (optional, can be included per-page) */
#mobile-call-bar{display:none;}
@media (max-width:900px){
  #mobile-call-bar{
    display:flex;position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
    z-index:500;align-items:center;gap:10px;
    background:rgba(15,12,26,0.88);border:1px solid rgba(124,58,237,0.35);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-radius:100px;padding:10px 20px 10px 14px;
    text-decoration:none;color:var(--star-white);
    font-family:'Josefin Sans',sans-serif;font-size:13px;font-weight:400;letter-spacing:0.06em;
    box-shadow:0 8px 32px rgba(0,0,0,0.4),0 0 0 1px rgba(124,58,237,0.15);
    transition:border-color 0.3s var(--ease),box-shadow 0.3s var(--ease),transform 0.2s var(--ease);
    animation:mobileBarIn 0.6s 1.2s var(--ease-out) both;
  }
  #mobile-call-bar:active{transform:translateX(-50%) scale(0.97);}
  @keyframes mobileBarIn{from{opacity:0;transform:translateX(-50%) translateY(20px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}
  #mobile-call-bar .call-icon-wrap{
    width:32px;height:32px;border-radius:50%;background:var(--g-cta);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    box-shadow:0 0 12px rgba(124,58,237,0.5);
  }
  #mobile-call-bar .call-icon-wrap svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
  #mobile-call-bar .call-label{display:flex;flex-direction:column;line-height:1.2;}
  #mobile-call-bar .call-hint{font-size:10px;color:var(--purple);text-transform:uppercase;letter-spacing:0.2em;font-weight:400;}
  #mobile-call-bar .call-number{font-size:13px;color:var(--star-white);font-weight:500;letter-spacing:0.04em;}
}

/* ──────── BUTTONS ──────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--g-cta);color:#fff;border:none;border-radius:100px;
  padding:15px 32px;
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:400;
  letter-spacing:0.18em;text-transform:uppercase;
  transition:transform 0.4s var(--ease),box-shadow 0.4s var(--ease),background 0.3s var(--ease);
  text-decoration:none;position:relative;overflow:hidden;cursor:pointer;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(196,181,253,0.2),transparent);
  opacity:0;transition:opacity 0.3s var(--ease);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-primary:hover::before{opacity:1;}
.btn-primary:active{transform:translateY(0) scale(0.98);}
.btn-primary:focus-visible{outline:2px solid var(--lavender);outline-offset:3px;}

.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--lavender);
  border:1px solid rgba(167,139,250,0.3);border-radius:100px;
  padding:14px 32px;
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:300;
  letter-spacing:0.18em;text-transform:uppercase;
  transition:border-color 0.3s var(--ease),background 0.3s var(--ease),color 0.3s var(--ease),transform 0.3s var(--ease);
  text-decoration:none;cursor:pointer;
}
.btn-outline:hover{border-color:var(--lavender);background:rgba(167,139,250,0.08);transform:translateY(-1px);}
.btn-outline:focus-visible{outline:2px solid var(--lavender);outline-offset:3px;}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--moon-mist);
  border:1px solid var(--border);border-radius:100px;
  padding:14px 28px;
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:300;
  letter-spacing:0.16em;text-transform:uppercase;
  transition:color 0.3s var(--ease),border-color 0.3s var(--ease);
  text-decoration:none;cursor:pointer;
}
.btn-ghost:hover{color:var(--ghost);border-color:var(--royal-dark);}
.btn-ghost:focus-visible{outline:2px solid var(--lavender);outline-offset:3px;}

/* ──────── EMAIL CAPTURE ──────── */
.email-capture{
  display:flex;align-items:center;max-width:540px;margin:0 auto;
  background:rgba(15,12,26,0.7);border:1px solid rgba(124,58,237,0.3);
  border-radius:100px;padding:6px 6px 6px 22px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:border-color 0.3s var(--ease),box-shadow 0.3s var(--ease);
}
.email-capture:focus-within{
  border-color:var(--purple);
  box-shadow:0 0 0 3px rgba(124,58,237,0.12),0 8px 32px rgba(124,58,237,0.12);
}
.email-capture input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--star-white);font-family:'EB Garamond',Georgia,serif;
  font-size:16px;padding:10px 8px 10px 0;letter-spacing:0;
}
.email-capture input::placeholder{color:var(--ash);}
.email-submit{
  background:var(--g-cta);color:#fff;border:none;border-radius:100px;
  padding:13px 28px;
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:400;
  letter-spacing:0.16em;text-transform:uppercase;
  cursor:pointer;transition:transform 0.3s var(--ease),box-shadow 0.3s var(--ease);
  white-space:nowrap;
}
.email-submit:hover{transform:scale(1.03);box-shadow:0 8px 24px rgba(124,58,237,0.4);}

/* ──────── FOOTER ──────── */
footer{
  background:var(--surface);border-top:1px solid var(--border);
  padding:64px 24px 40px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px;
  max-width:var(--max);margin-left:auto;margin-right:auto;
}
.footer-brand-name{
  font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;
  font-size:32px;letter-spacing:0.04em;text-transform:uppercase;
  margin-bottom:14px;line-height:1;
  background:linear-gradient(135deg,#f0eeff,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.footer-tagline{
  font-family:'EB Garamond',Georgia,serif;font-size:16px;
  color:var(--ash);line-height:1.7;max-width:280px;margin-bottom:22px;letter-spacing:-0.003em;
}
.charity-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:300;
  letter-spacing:0.08em;color:var(--ash);
  background:rgba(124,58,237,0.07);border:1px solid rgba(124,58,237,0.18);
  padding:7px 16px;border-radius:100px;
}
.charity-dot{width:6px;height:6px;border-radius:50%;background:var(--purple);animation:charityPulse 2.5s ease infinite;}
@keyframes charityPulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(0.85);}}

.footer-col h4{
  font-family:'Cinzel',serif;font-weight:500;
  font-size:11px;letter-spacing:0.3em;text-transform:uppercase;color:var(--star-white);
  margin-bottom:18px;
}
.footer-col a{
  display:block;font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:13px;letter-spacing:0.04em;color:var(--ash);
  text-decoration:none;margin-bottom:12px;
  transition:color 0.3s var(--ease),transform 0.3s var(--ease);
}
.footer-col a:hover{color:var(--lavender);transform:translateX(2px);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:32px;border-top:1px solid var(--border);
  flex-wrap:wrap;gap:16px;
  max-width:var(--max);margin:0 auto;
}
.footer-copy{
  font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:11px;letter-spacing:0.08em;color:var(--dust);
}

@media (max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px;}
}
@media (max-width:540px){
  .footer-grid{grid-template-columns:1fr;}
}

/* ──────── REVEAL — fade-up + blur-to-sharp (Apple-tier) ──────── */
.reveal{
  opacity:0;
  transform:translate3d(0,28px,0) scale(0.985);
  filter:blur(6px);
  transition:
    opacity 0.9s var(--ease),
    transform 0.9s var(--ease),
    filter 0.7s var(--ease);
  will-change:transform,opacity,filter;
}
.reveal.visible,.reveal.is-visible{
  opacity:1;
  transform:translate3d(0,0,0) scale(1);
  filter:blur(0);
}
.reveal-delay-1{transition-delay:0.08s;}
.reveal-delay-2{transition-delay:0.16s;}
.reveal-delay-3{transition-delay:0.24s;}
.reveal-delay-4{transition-delay:0.32s;}

/* ──────── CARD TILT — supports 3D rotation from JS ──────── */
.service-card,.case-study,.testi-card,.problem-card,.logo-pill,[data-tilt]{
  transform-style:preserve-3d;
  transition:transform 0.5s var(--ease),border-color 0.3s var(--ease),box-shadow 0.4s var(--ease);
  will-change:transform;
}
/* Service card gets a cursor-tracked gradient spotlight (JS sets --mx/--my) */
.service-card{position:relative;}
.service-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(124,58,237,0.14),transparent 55%);
  opacity:0;transition:opacity 0.4s var(--ease);
}
.service-card:hover::before{opacity:1;}

/* ──────── MAGNETIC BUTTON — supports translate from JS ──────── */
.btn-primary,.btn-outline,.btn-ghost,.email-submit,.nav-cta,[data-magnetic]{
  will-change:transform;
  transition:transform 0.5s var(--ease),background 0.3s var(--ease),border-color 0.3s var(--ease),box-shadow 0.4s var(--ease),color 0.3s var(--ease);
}
/* When magnetic is active, CSS hover translate should not fight JS translate */
.btn-primary:hover{box-shadow:var(--shadow-md);}
.btn-outline:hover{background:rgba(167,139,250,0.08);border-color:var(--lavender);}

/* ──────── CURSOR GLOW — radial spotlight tracking cursor ──────── */
[data-glow]{position:relative;overflow:hidden;}
[data-glow].has-glow::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(600px circle at var(--glow-x,50%) var(--glow-y,50%),rgba(124,58,237,0.12),transparent 45%);
  opacity:0;transition:opacity 0.6s var(--ease);
}
[data-glow].glow-active::after{opacity:1;}
[data-glow] > *{position:relative;z-index:2;}

/* ──────── STAT NUMBER REVEAL — clip-path mask (Apple signature) ──────── */
.stat-num{display:inline-block;}
.stat-item.reveal .stat-num{
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.1s var(--ease) 0.15s;
}
.stat-item.reveal.visible .stat-num,.stat-item.reveal.is-visible .stat-num{
  clip-path:inset(0 0 0 0);
}

/* ──────── HOVER LIFT UTILITIES ──────── */
.lift-sm:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.lift-md:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.lift-lg:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}

/* ══════════════════════════════════════════════════════════════
   DOTTED SURFACE — service-page hero wave grid.
   Auto-initialised by brand.js when a <canvas class="hero-dot-canvas">
   sits inside a .page-hero element.
══════════════════════════════════════════════════════════════ */
.page-hero .hero-dot-canvas{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  z-index:1;
  pointer-events:none;
  opacity:0;
  transition:opacity 1.6s var(--ease);
}
.page-hero .hero-dot-canvas.is-ready{opacity:0.72;}
/* Lift the hero grid above the canvas */
.page-hero .hero-grid{position:relative;z-index:2;}
@media (max-width:767px){.page-hero .hero-dot-canvas.is-ready{opacity:0.55;}}
@media (prefers-reduced-motion:reduce){.page-hero .hero-dot-canvas{display:none;}}

/* ══════════════════════════════════════════════════════════════
   BACKGROUND PATHS — editorial hero flow lines.
   Two SVGs of 36 layered curves, drawn-then-erased
   with offset/opacity drift. Purple-only, low-intensity.
   Auto-populated by brand.js when a <div class="hero-paths">
   sits inside a .page-hero element.
══════════════════════════════════════════════════════════════ */
.page-hero{position:relative;}
.page-hero .hero-paths{
  position:absolute;inset:0;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
  opacity:0;
  transition:opacity 1.8s var(--ease);
}
.page-hero .hero-paths.is-ready{opacity:0.55;}
/* Center vignette — darkens behind the text so headline stays legible */
.page-hero .hero-paths::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 55% at 50% 50%,rgba(9,9,15,0.82) 0%,rgba(9,9,15,0.55) 40%,transparent 75%);
  pointer-events:none;
}
.page-hero .hero-paths svg{
  position:absolute;inset:0;
  width:100%;height:100%;
  color:var(--lavender);
}
.page-hero .hero-paths svg path{
  fill:none;
  stroke:currentColor;
  stroke-linecap:round;
  animation:hero-path-flow linear infinite;
}
@keyframes hero-path-flow{
  0%   {stroke-dashoffset:1.35;}
  100% {stroke-dashoffset:-0.35;}
}
/* Ensure hero content floats above the paths */
.page-hero > *:not(.hero-paths):not(.hero-dot-canvas){position:relative;z-index:2;}
@media (max-width:900px){.page-hero .hero-paths.is-ready{opacity:0.38;}}
@media (prefers-reduced-motion:reduce){
  .page-hero .hero-paths svg path{animation:none;stroke-dashoffset:0;}
}

/* ══════════════════════════════════════════════════════════════
   LEAD MAGNET — lives inside service-page #problem section.
   Two-column layout: problem pullquote (left) + solution card (right).
   Solution card = 3D book mockup + eyebrow + Playfair title +
   Cormorant sub + inline form + privacy line.
   Activated by brand.js initLeadMagnet() which reads data-source.
══════════════════════════════════════════════════════════════ */

/* The problem section's outer grid — problem (left) + solution card (right) */
.problem-layout{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr minmax(420px,500px);gap:88px;align-items:center;
}
.problem-col{position:relative;}

/* The lead magnet card itself */
.lead-magnet-card{
  padding:44px 40px 40px;
  background:var(--surface);
  border:1px solid var(--border);border-radius:6px;
  text-align:center;position:relative;
  background-image:radial-gradient(ellipse at 50% 0%,rgba(124,58,237,0.10),transparent 55%);
  box-shadow:0 32px 64px rgba(9,9,15,0.5),0 0 80px rgba(124,58,237,0.08);
}
.lead-magnet-card::before{
  content:'';position:absolute;top:0;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(167,139,250,0.55),transparent);
}

/* 3D BOOK MOCKUP — sits above the form inside the card */
.book-wrap{
  position:relative;perspective:1200px;
  margin:0 auto 28px;width:fit-content;
}
.book-glow{
  position:absolute;inset:-32px;
  background:radial-gradient(ellipse at 50% 60%,rgba(124,58,237,0.35),transparent 65%);
  filter:blur(24px);pointer-events:none;z-index:-1;
}
.book-3d{
  width:170px;height:230px;position:relative;
  transform-style:preserve-3d;
  animation:book-float 7s ease-in-out infinite;
  transition:transform 0.6s var(--ease);
}
.book-3d:hover{animation-play-state:paused;transform:rotateY(-12deg) rotateX(2deg);}
@keyframes book-float{
  0%,100%{transform:rotateY(-22deg) rotateX(4deg) translateY(0);}
  50%    {transform:rotateY(-22deg) rotateX(4deg) translateY(-8px);}
}
.book-cover{
  position:absolute;inset:0;
  background:
    linear-gradient(140deg,#14102B 0%,#3B1F6E 42%,#5B21B6 72%,#7C3AED 100%);
  border-radius:2px 8px 8px 2px;
  overflow:hidden;
  padding:18px 16px;
  display:flex;flex-direction:column;
  box-shadow:
    5px 8px 24px rgba(0,0,0,0.6),
    0 0 40px rgba(124,58,237,0.28);
  border-right:1px solid rgba(167,139,250,0.18);
  border-top:1px solid rgba(167,139,250,0.12);
}
.book-cover::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(167,139,250,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(167,139,250,0.05) 1px,transparent 1px);
  background-size:18px 18px;pointer-events:none;
}
.book-cover::after{
  content:'';position:absolute;top:0;left:0;right:0;height:38%;
  background:linear-gradient(to bottom,rgba(255,255,255,0.06),transparent);
  pointer-events:none;
}
.book-inner{
  position:relative;z-index:1;display:flex;flex-direction:column;height:100%;
}
.book-tag{
  align-self:flex-start;
  font-family:'Cinzel',serif;font-weight:500;
  font-size:7px;letter-spacing:0.32em;text-transform:uppercase;color:var(--lavender);
  display:inline-flex;align-items:center;gap:6px;margin-bottom:10px;
}
.book-tag::before{content:'';width:12px;height:1px;background:var(--lavender);}
.book-num{
  font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;font-style:italic;
  font-size:72px;line-height:0.85;letter-spacing:-0.04em;
  background:linear-gradient(135deg,#F0EEFF,#C4B5FD);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:2px;
}
.book-title-txt{
  font-family:'Playfair Display',Georgia,serif;font-weight:400;
  font-size:12px;line-height:1.15;letter-spacing:-0.01em;color:var(--fg);
  margin-bottom:4px;
}
.book-sub-txt{
  font-family:'EB Garamond',Georgia,serif;font-style:italic;
  font-size:9px;line-height:1.45;color:var(--lilac);letter-spacing:-0.003em;
}
.book-foot{margin-top:auto;position:relative;z-index:1;}
.book-rule{height:1px;background:rgba(167,139,250,0.25);margin-bottom:8px;}
.book-brand{
  font-family:'Cinzel',serif;font-weight:500;
  font-size:7px;letter-spacing:0.32em;text-transform:uppercase;color:var(--lilac);
}
.book-spine{
  position:absolute;top:0;left:-12px;width:12px;height:100%;
  background:linear-gradient(90deg,#0B0816,#1A0F2E 40%,#2D1A6E);
  border-radius:3px 0 0 3px;
  box-shadow:-2px 0 6px rgba(0,0,0,0.5);
}
.book-pages{
  position:absolute;top:2px;right:-6px;width:6px;height:calc(100% - 4px);
  background:repeating-linear-gradient(to bottom,#EDE9FE 0,#EDE9FE 1px,#C4B5FD 1px,#C4B5FD 2px);
  border-radius:0 2px 2px 0;opacity:0.5;
}

/* Card typography (smaller than the standalone variant since it's half-width) */
.lm-eyebrow{
  font-family:'Cinzel',serif;font-weight:500;
  font-size:10px;letter-spacing:0.32em;text-transform:uppercase;color:var(--lavender);
  display:inline-flex;align-items:center;gap:14px;margin-bottom:20px;
}
.lm-eyebrow::before,.lm-eyebrow::after{
  content:'';width:22px;height:1px;background:rgba(167,139,250,0.4);
}
.lm-title{
  font-family:'Playfair Display',Georgia,serif;font-weight:400;
  font-size:clamp(22px,2.2vw,30px);line-height:1.18;letter-spacing:-0.012em;
  color:var(--fg);margin-bottom:16px;text-wrap:balance;
}
.lm-title em{color:var(--lavender);font-style:italic;}
.lm-subtitle{
  font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;font-style:italic;
  font-size:clamp(16px,1.3vw,18px);line-height:1.45;letter-spacing:-0.004em;
  color:var(--moon);margin:0 auto 28px;max-width:36ch;
}
.lm-subtitle em{color:var(--lilac);}

/* Form — single column since card is narrow */
.lm-form{
  display:flex;flex-direction:column;gap:10px;
  max-width:360px;margin:0 auto 16px;
}
.lm-form .lm-input{
  background:var(--void);
  border:1px solid var(--border);
  border-radius:2px;
  padding:13px 16px;
  color:var(--fg);
  font-family:'EB Garamond',Georgia,serif;font-size:15px;letter-spacing:-0.003em;
  outline:none;
  transition:border-color 0.3s var(--ease),box-shadow 0.3s var(--ease);
}
.lm-form .lm-input::placeholder{color:var(--ash);font-style:italic;}
.lm-form .lm-input:focus{
  border-color:var(--lavender);
  box-shadow:0 0 0 3px rgba(167,139,250,0.12);
}
.lm-cta{
  background:var(--g-cta);color:#fff;border:none;border-radius:100px;
  padding:14px 24px;margin-top:4px;
  font-family:'Josefin Sans',sans-serif;font-weight:400;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  cursor:pointer;
  transition:transform 0.3s var(--ease),box-shadow 0.3s var(--ease),opacity 0.3s var(--ease);
}
.lm-cta:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(124,58,237,0.4);}
.lm-cta:disabled{opacity:0.55;transform:none;box-shadow:none;cursor:wait;}
.lm-privacy{
  font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--dust);
  margin-top:4px;
}
.lm-privacy .sep{color:var(--nebula);margin:0 8px;}
.lm-msg{
  font-family:'EB Garamond',Georgia,serif;font-style:italic;
  font-size:14px;line-height:1.45;color:var(--lavender);
  min-height:18px;margin-top:16px;
}
.lm-msg.is-error{color:#f87171;}

/* Responsive: stack below 960px */
@media (max-width:960px){
  .problem-layout{grid-template-columns:1fr;gap:64px;}
  .lead-magnet-card{max-width:480px;margin:0 auto;}
}
@media (max-width:540px){
  .lead-magnet-card{padding:40px 24px 32px;}
  .book-3d{width:140px;height:190px;}
  .book-num{font-size:58px;}
  .book-title-txt{font-size:11px;}
  .lm-privacy .sep{display:none;}
  .lm-privacy{line-height:1.8;}
}
@media (prefers-reduced-motion:reduce){
  .book-3d{animation:none;transform:rotateY(-18deg) rotateX(3deg);}
}

/* ══════════════════════════════════════════════════════════════
   CANVAS TRAIL — cursor/touch-following luminous trail.
   Opt in by adding data-canvas-trail on any <section>.
   brand.js injects a <canvas> + pointer listeners and drives 50
   spring-chained lines that glow additively (globalCompositeOp:lighter).
   Purple-only hue range (250–290). Paused when offscreen (IO).
══════════════════════════════════════════════════════════════ */
/* Single viewport-wide canvas trail — follows the cursor across the whole page.
   Sits above content but blends additively (screen), so only the bright strokes
   tint the page while empty-black pixels become transparent. Text stays readable
   because screen-blend can only lighten, never darken. */
.canvas-trail-global{
  position:fixed;inset:0;
  width:100vw;height:100vh;
  pointer-events:none;
  z-index:100;
  mix-blend-mode:screen;
  opacity:0;
  transition:opacity 1.6s var(--ease);
}
.canvas-trail-global.is-ready{opacity:0.95;}
@media (prefers-reduced-motion:reduce){
  .canvas-trail-global{display:none;}
}
/* Legacy per-section trail styles (kept for backward compat — not in active use) */
[data-canvas-trail],.canvas-trail-host{position:relative;overflow:hidden;}
[data-canvas-trail] > *:not(.canvas-trail-layer),
.canvas-trail-host > *:not(.canvas-trail-layer){position:relative;z-index:1;}
.canvas-trail-layer{position:absolute;inset:0;pointer-events:none;z-index:0;display:block;opacity:0;transition:opacity 1.6s var(--ease);}
.canvas-trail-layer.is-ready{opacity:1;}
@media (prefers-reduced-motion:reduce){.canvas-trail-layer{display:none;}}

/* ══════════════════════════════════════════════════════════════
   SCROLL TRAIL — dotted S-curve with 3D send-icon orb that
   follows the scroll. Enabled by <body data-scroll-trail>.
   Auto-injected by brand.js.
══════════════════════════════════════════════════════════════ */
.scroll-trail{
  position:absolute;top:0;left:0;right:0;
  pointer-events:none;z-index:15;overflow:hidden;
  opacity:0;transition:opacity 1.2s var(--ease);
}
.scroll-trail.is-ready{opacity:1;}
.scroll-trail__svg{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  overflow:visible;
}
.scroll-trail__path{
  fill:none;
  stroke:rgba(167,139,250,0.28);
  stroke-width:1.3;
  stroke-linecap:round;
  stroke-dasharray:2 9;
  vector-effect:non-scaling-stroke;
}
.scroll-trail__glow{
  fill:none;
  stroke:url(#scrollTrailGlowGrad);
  stroke-width:2.4;
  stroke-linecap:round;
  vector-effect:non-scaling-stroke;
  filter:blur(6px);
  opacity:0.4;
}

/* Marker is FIXED to viewport — stays in view while scrolling,
   like a Google Maps navigation marker. x is set by JS from path. */
.scroll-trail__marker{
  position:fixed;top:50%;left:0;
  width:52px;height:52px;
  transform:translate(-50%,-50%) translate3d(var(--marker-x,32px),0,0);
  will-change:transform;
  transition:opacity 0.6s var(--ease);
  opacity:0;
  pointer-events:none;
  z-index:16;
}
.scroll-trail.is-ready .scroll-trail__marker{opacity:1;}

/* 3D orb — purple gradient sphere with highlight + inset shadow */
.scroll-trail__orb{
  width:100%;height:100%;border-radius:50%;
  background:
    radial-gradient(circle at 30% 28%, #c4b5fd 0%, #a78bfa 22%, #7c3aed 55%, #4c1d95 100%);
  box-shadow:
    0 10px 28px rgba(124,58,237,0.45),
    0 0 32px rgba(124,58,237,0.3),
    inset 0 -6px 14px rgba(76,29,149,0.55),
    inset 0 4px 8px rgba(255,255,255,0.28);
  display:flex;align-items:center;justify-content:center;
  position:relative;
  animation:scrollTrailFloat 4s ease-in-out infinite;
}
.scroll-trail__orb::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(ellipse at 30% 25%, rgba(255,255,255,0.35) 0%, transparent 45%);
  pointer-events:none;
}
/* Icon wrapper rotates to point in direction of travel (set by JS) */
.scroll-trail__icon{
  position:relative;z-index:1;
  width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;
  transform:rotate(var(--icon-angle,90deg));
  transition:transform 0.45s var(--ease);
}
.scroll-trail__orb svg{
  width:22px;height:22px;
  fill:#fff;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,0.25));
}
@keyframes scrollTrailFloat{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-3px);}
}

/* Hide on narrow screens where it would crowd content */
@media (max-width:900px){
  .scroll-trail{display:none;}
}
@media (prefers-reduced-motion:reduce){
  .scroll-trail{display:none;}
}

/* ──────── REDUCED MOTION ──────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.001ms!important;animation-iteration-count:1!important;
    transition-duration:0.001ms!important;scroll-behavior:auto!important;
  }
  .reveal{opacity:1;transform:none;}
}

/* ──────────────────────────────────────────────────────────────
   LEAD MAGNET EYEBROW — top-of-page promo bar (used on blog pages)
   Styled like Adapty's "State of in-app subscriptions" eyebrow.
   ────────────────────────────────────────────────────────────── */
.lm-eyebrow{
  display:flex;align-items:center;justify-content:center;
  width:100%;padding:13px 24px;
  background:linear-gradient(90deg,rgba(124,58,237,0.18),rgba(91,33,182,0.10) 50%,rgba(124,58,237,0.18));
  border-bottom:1px solid rgba(167,139,250,0.16);
  text-decoration:none;color:var(--moon);
  font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:13px;letter-spacing:0.02em;
  position:relative;z-index:201;
  transition:background 0.4s var(--ease);
}
.lm-eyebrow:hover{background:linear-gradient(90deg,rgba(124,58,237,0.28),rgba(91,33,182,0.18) 50%,rgba(124,58,237,0.28));}
.lm-eyebrow-inner{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;text-align:center;}
.lm-eyebrow .lm-emoji{font-size:14px;line-height:1;}
.lm-eyebrow strong{color:var(--star-white);font-weight:400;letter-spacing:0;}
.lm-eyebrow .lm-meta{color:var(--ash);font-family:'Cinzel',serif;font-weight:500;font-size:10px;letter-spacing:0.24em;text-transform:uppercase;padding-left:8px;border-left:1px solid rgba(167,139,250,0.22);}
.lm-eyebrow .lm-arrow{color:var(--lavender);font-size:16px;line-height:1;transition:transform 0.3s var(--ease);}
.lm-eyebrow:hover .lm-arrow{transform:translateX(4px);}
@media (max-width:640px){
  .lm-eyebrow{padding:11px 16px;font-size:12px;}
  .lm-eyebrow .lm-meta{display:none;}
  .lm-eyebrow strong{font-size:12px;}
}

/* On blog article pages, push the fixed nav down to make room for the eyebrow */
body.has-lm-eyebrow nav[aria-label="Primary"]{top:54px;}
@media (max-width:640px){body.has-lm-eyebrow nav[aria-label="Primary"]{top:48px;}}
