/* ══════════════════════════════════════════════════════
   Social Graces Behavioral Coaching — Shared Stylesheet
   ══════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:'DM Sans',system-ui,sans-serif;background:#faf8f4;color:#12152e;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}

:root{
  --navy:#1a1f3c;--navy-mid:#232848;--navy-deep:#13172d;
  --gold:#f0b429;--gold-lt:#f7cf6a;--gold-dk:#c9880a;
  --purple-vivid:#6b3fa0;--purple-deep:#3d1d6e;--purple-mid:#7c4db5;
  --cream:#f5f1e8;--cream-lt:#faf8f4;--white:#ffffff;
  --muted:#4a4e6a;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --nav-h:68px;--r:12px;
}

/* ── KEYFRAMES ── */
@keyframes goldShimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}
@keyframes borderGlow {
  0%,100% { box-shadow: 0 0 0 0 rgba(232,201,126,0); }
  50%      { box-shadow: 0 0 22px 6px rgba(232,201,126,0.28); }
}
@keyframes hFade{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* ── UTILITY ── */
.shimmer {
  background: linear-gradient(105deg,var(--gold-dk) 0%,var(--gold) 30%,#fff8e8 48%,var(--gold) 65%,var(--gold-dk) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: goldShimmer 4s linear infinite;
  display: inline-block;
}
.container{max-width:1160px;margin:0 auto;padding:0 40px}
.eyebrow{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.sr{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.sr.in{opacity:1;transform:none}
.sr.d1{transition-delay:.1s}.sr.d2{transition-delay:.2s}.sr.d3{transition-delay:.3s}

/* ── BUTTONS ── */
.btn-gold{display:inline-flex;align-items:center;justify-content:center;background:var(--gold);color:var(--navy-deep);font-family:var(--sans);font-size:15px;font-weight:600;padding:14px 32px;border-radius:100px;border:none;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;white-space:nowrap;letter-spacing:.02em}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-1px);box-shadow:0 0 24px 6px rgba(232,201,126,0.3)}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:#fff;font-family:var(--sans);font-size:15px;font-weight:400;padding:13px 32px;border-radius:100px;border:1.5px solid rgba(255,255,255,.45);cursor:pointer;transition:border-color .15s,background .15s;white-space:nowrap}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}

/* ── ANNOUNCEMENT BANNER ── */
#announcement-bar{
  background:linear-gradient(135deg,var(--purple-deep) 0%,var(--navy-deep) 60%,var(--purple-deep) 100%);
  border-bottom:1px solid rgba(232,201,126,0.3);
  padding:10px 20px;
  text-align:center;
  position:relative;
  z-index:950;
}
#announcement-bar .ann-inner{
  display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;
  max-width:1160px;margin:0 auto;
}
#announcement-bar .ann-text,
#announcement-bar .ann-headline{
  font-size:13px;color:rgba(255,255,255,.9);line-height:1.5;
}
#announcement-bar .ann-text strong{color:var(--gold-lt)}
#announcement-bar .ann-subtext{
  font-size:12px;color:rgba(255,255,255,.75);line-height:1.5;
}
#announcement-bar .ann-btn{
  display:inline-flex;align-items:center;background:var(--gold);color:var(--navy-deep);
  font-size:12px;font-weight:600;padding:6px 16px;border-radius:100px;
  white-space:nowrap;transition:background .15s;border:none;cursor:pointer;font-family:var(--sans);
  letter-spacing:.02em;text-decoration:none;
}
#announcement-bar .ann-btn:hover{background:var(--gold-lt)}
#announcement-bar .ann-dismiss,
#announcement-bar .ann-close{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:rgba(255,255,255,.4);font-size:18px;
  cursor:pointer;line-height:1;padding:4px;transition:color .12s;
}
#announcement-bar .ann-dismiss:hover,
#announcement-bar .ann-close:hover{color:rgba(255,255,255,.8)}
#announcement-bar.hidden{display:none}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:900;background:linear-gradient(135deg,#13172d 0%,#1d1040 100%);height:var(--nav-h);display:flex;align-items:center;border-bottom:1px solid rgba(107,63,160,0.5);box-shadow:0 2px 24px rgba(61,29,110,0.45)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.logo{display:flex;flex-direction:column;line-height:1;color:#fff}
.logo-name{font-family:var(--serif);font-size:20px;font-weight:700;
  background:linear-gradient(105deg,#fff 0%,#fff8e8 40%,var(--gold) 55%,#fff8e8 70%,#fff 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  animation: goldShimmer 6s linear infinite;
}
.logo-sub{font-size:9px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-size:14px;color:#ffffff;transition:color .15s;font-weight:400}
.nav-links a:hover,.nav-links a.active{
  background: linear-gradient(105deg,var(--gold-dk) 0%,var(--gold) 40%,#fff8e8 55%,var(--gold) 70%,var(--gold-dk) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  animation: goldShimmer 4s linear infinite;
}
.nav-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-ham span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.nav-ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-ham.open span:nth-child(2){opacity:0}
.nav-ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-drawer{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--navy-deep);padding:28px 32px 36px;border-bottom:1px solid rgba(255,255,255,.08);z-index:800}
.nav-drawer.open{display:block}
.nav-drawer ul{list-style:none}
.nav-drawer ul li{border-bottom:1px solid rgba(255,255,255,.07)}
.nav-drawer ul li a{display:block;padding:14px 0;font-size:16px;color:rgba(255,255,255,.8)}
.nav-drawer .btn-gold{width:100%;text-align:center;margin-top:20px}

/* ── HERO ── */
#hero{
  position:relative;min-height:calc(100vh - var(--nav-h));
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
  background:
    linear-gradient(to bottom,rgba(61,29,110,0.45) 0%,rgba(26,31,60,0.55) 40%,rgba(13,17,45,0.82) 85%,rgba(13,17,45,0.96) 100%),
    url('../../images/background.png') center/cover no-repeat;
}
.hero-inner{position:relative;z-index:10;max-width:800px;padding:80px 40px 120px;animation: hFade .9s ease both}
.hero-text{display:contents}
.hero-eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:22px;display:block}
#hero h1{font-family:var(--serif);font-size:clamp(46px,7vw,84px);font-weight:700;line-height:1.04;color:#fff;margin-bottom:22px;text-shadow:0 2px 40px rgba(61,29,110,0.5)}
#hero h1 .shimmer-word{
  background:linear-gradient(105deg,var(--gold-dk) 0%,var(--gold) 30%,#fff8e8 48%,var(--gold) 65%,var(--gold-dk) 100%);
  background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation: goldShimmer 4s linear infinite;display:inline;
}
.hero-sub{font-size:clamp(17px,2vw,21px);font-weight:300;color:rgba(255,255,255,.9);margin-bottom:44px;line-height:1.75;max-width:560px;margin-left:auto;margin-right:auto;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.hero-divider{width:60px;height:1px;margin:0 auto 36px;background:linear-gradient(90deg,transparent,var(--gold),var(--gold-lt),var(--gold),transparent);background-size:200% auto;animation: goldShimmer 3s linear infinite}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-pill{display:none}
.hero-chevron{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.25);font-size:22px;animation:bob 2.2s ease-in-out infinite;cursor:pointer;z-index:5}

/* ── MANIFESTO ── */
#manifesto{background:var(--cream);padding:80px 24px;display:flex;justify-content:center}
.manifesto-card{background:linear-gradient(135deg,var(--navy-deep) 0%,var(--purple-deep) 100%);border:1px solid rgba(107,63,160,0.4);border-radius:var(--r);padding:72px 64px;max-width:800px;width:100%;text-align:center}
.manifesto-card h2{font-family:var(--serif);font-size:clamp(30px,4.5vw,52px);font-weight:600;color:#fff;line-height:1.15;margin-bottom:16px}
.manifesto-card p{font-size:17px;line-height:1.8;color:rgba(255,255,255,.95);max-width:520px;margin:0 auto}

/* ── SPLIT SECTIONS ── */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.split-img{position:relative;overflow:hidden;min-height:420px}
.img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.split-body{display:flex;flex-direction:column;justify-content:center;padding:72px 56px;background:#faf8f4}
.split-body.dark{background:var(--navy);color:#fff}
.split-body h2{font-family:var(--serif);font-size:clamp(26px,3.5vw,44px);font-weight:500;line-height:1.2;margin-bottom:16px}
.split-body.dark h2{color:#fff}
.split-body p{font-size:16px;line-height:1.82;color:#2a2d45;margin-bottom:16px}
.split-body.dark p{color:rgba(255,255,255,.95)}
.pullquote{font-family:var(--serif);font-style:italic;font-size:20px;border-left:3px solid var(--gold);padding-left:18px;color:var(--navy);margin:24px 0;line-height:1.55}
.split-body.dark .pullquote{color:rgba(255,255,255,.85)}

/* ── PATTERNS ── */
#patterns{padding:96px 40px;background:#f5f1e8;text-align:center}
#patterns h2{font-family:var(--serif);font-size:clamp(30px,4vw,52px);font-weight:400;margin-bottom:12px;color:#12152e}
#patterns .intro{font-size:17px;color:#2a2d45;max-width:560px;margin:0 auto 52px;line-height:1.7}
.pattern-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;max-width:1080px;margin:0 auto}
.pattern-tile{position:relative;overflow:hidden;aspect-ratio:3/4;cursor:default}
.pattern-tile:nth-child(1){background:linear-gradient(160deg,#2a3a5c,#1a2540)}
.pattern-tile:nth-child(2){background:linear-gradient(160deg,#2a3a5c,#1a2540)}
.pattern-tile:nth-child(3){background:linear-gradient(160deg,#1a2a3a,#0d1c2a)}
.pattern-tile-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,17,45,.92) 0%,rgba(13,17,45,.2) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:32px 28px}
.pattern-tile h3{font-family:var(--serif);font-size:22px;font-weight:500;color:#fff;margin-bottom:8px}
.pattern-tile p{font-size:13px;color:rgba(255,255,255,.62);line-height:1.6}
.pattern-tile-num{position:absolute;top:20px;left:20px;font-family:var(--serif);font-size:13px;color:var(--gold);opacity:.8}

/* ── METHOD ── */
#method{background:#faf8f4;padding:96px 40px}
.method-header{text-align:center;margin-bottom:52px}
.method-header h2{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:400;margin-bottom:10px}
.method-header p{font-size:16px;color:#2a2d45;max-width:520px;margin:0 auto;line-height:1.7}
.method-img-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;max-width:1080px;margin:0 auto 48px;border-radius:var(--r);overflow:hidden}
.mic{aspect-ratio:1;position:relative;overflow:hidden;background:#0d1020}
.mic:nth-child(1){background:linear-gradient(145deg,#2d3a5a,#1a2345)}
.mic:nth-child(2){background:linear-gradient(145deg,#3b2a1e,#2c1f15)}
.mic:nth-child(3){background:linear-gradient(145deg,#1e2d3b,#121e28)}
.mic:nth-child(4){background:linear-gradient(145deg,#2e2440,#1d1630)}
.mic-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:16px;background:linear-gradient(to top,rgba(13,17,45,.8) 0%,transparent 60%)}
.mic-label b{font-family:var(--serif);font-size:13px;color:var(--gold);margin-bottom:2px}
.mic-label p{font-size:11px;color:rgba(255,255,255,.6);text-align:center}
.phases{max-width:760px;margin:0 auto}
.phase{border-bottom:1px solid rgba(26,31,60,.1)}
.phase-btn{width:100%;background:none;border:none;text-align:left;padding:22px 0;display:flex;align-items:center;gap:16px;cursor:pointer}
.phase-num{font-family:var(--serif);font-size:20px;color:var(--gold);min-width:36px;
  background:linear-gradient(105deg,var(--gold-dk) 0%,var(--gold) 35%,#fff8e8 50%,var(--gold) 65%,var(--gold-dk) 100%);
  background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation: goldShimmer 5s linear infinite;
}
.phase-title{font-family:var(--serif);font-size:19px;font-weight:500;color:#12152e;flex:1}
.phase-icon{color:var(--muted);transition:transform .25s;font-size:18px;line-height:1}
.phase.open .phase-icon{transform:rotate(45deg);color:var(--gold)}
.phase-body{display:none;padding:0 0 22px 52px;font-size:15px;line-height:1.8;color:#2a2d45}
.phase.open .phase-body{display:block}

/* ── SERVICES ── */
#services{background:#f5f1e8;padding:96px 40px}
.services-header{text-align:center;margin-bottom:52px}
.services-header h2{font-family:var(--serif);font-size:clamp(30px,4vw,50px);font-weight:400;margin-bottom:10px}
.services-header p{font-size:16px;color:#2a2d45;max-width:440px;margin:0 auto}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1080px;margin:0 auto}
.svc-card{background:#ffffff;border-radius:var(--r);overflow:hidden;border:1px solid rgba(107,63,160,0.12);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(26,31,60,.12)}
.svc-img{height:280px;position:relative;overflow:hidden;flex-shrink:0}
.svc-card:nth-child(1) .svc-img{background:linear-gradient(155deg,#1e3050,#2a4870)}
.svc-card:nth-child(2) .svc-img{background:linear-gradient(155deg,#2c1f12,#4a3422)}
.svc-card:nth-child(3) .svc-img{background:linear-gradient(155deg,#12202e,#1e3345)}
.svc-img-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.svc-img-icon{font-family:var(--serif);font-size:56px;color:rgba(255,255,255,.1);user-select:none}
.svc-body{padding:28px 28px 32px;flex:1;display:flex;flex-direction:column}
.svc-tag{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.svc-body h3{font-family:var(--serif);font-size:22px;font-weight:500;color:#12152e;margin-bottom:8px}
.svc-body p{font-size:14px;line-height:1.75;color:#2a2d45;flex:1;margin-bottom:20px}
.svc-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(26,31,60,.07);padding-top:18px;margin-top:auto}
.svc-price{font-family:var(--serif);font-size:22px;color:var(--navy)}
.svc-price span{display:block;font-size:11px;font-family:var(--sans);color:#3a3f5a;font-weight:400;letter-spacing:.04em;margin-top:2px}
.svc-cta{font-size:13px;color:var(--gold);font-weight:500;display:flex;align-items:center;gap:4px}
.svc-cta-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--gold);color:#13172d;font-family:var(--sans);font-size:14px;font-weight:600;padding:11px 24px;border-radius:100px;width:100%;transition:background .15s;border:none;cursor:pointer}
.svc-cta-btn:hover{background:var(--gold-lt)}
.svc-cta:hover{color:var(--navy)}

/* ── TESTIMONIALS ── */
#testimonials{background:linear-gradient(135deg,#13172d 0%,#1d1040 100%);padding:96px 40px;text-align:center}
#testimonials h2{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:400;color:#fff;margin-bottom:52px}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1080px;margin:0 auto}
.t-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:var(--r);padding:36px 28px;text-align:left;transition:background .2s}
.t-card:hover{background:rgba(255,255,255,.08)}
.t-mark{font-family:var(--serif);font-size:44px;color:var(--gold);opacity:.35;line-height:.8;margin-bottom:16px;user-select:none}
.t-card blockquote{font-family:var(--serif);font-style:italic;font-size:15px;line-height:1.78;color:#ffffff;margin-bottom:20px}
.t-attr{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* ── ABOUT ── */
#about{display:grid;grid-template-columns:1fr 1fr;min-height:640px}
.about-img{position:relative;overflow:hidden;background:linear-gradient(145deg,#b8b0a4,#8c857c)}
.about-body{background:linear-gradient(160deg,#13172d 0%,#1d1040 100%);display:flex;flex-direction:column;justify-content:center;padding:80px 64px}
.about-body h2{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);font-weight:500;color:#fff;line-height:1.2;margin-bottom:20px}
.about-body p{font-size:16px;line-height:1.85;color:#ffffff;margin-bottom:16px}
.about-body p:last-of-type{margin-bottom:32px}
.about-sig{font-family:var(--serif);font-style:italic;font-size:28px;color:var(--gold);margin-bottom:32px}

/* ── CHOICE ── */
#choice{background:linear-gradient(135deg,#13172d 0%,#1d1040 100%);padding:96px 24px;display:flex;justify-content:center}
.choice-wrap{max-width:780px;width:100%;text-align:center}
.choice-wrap h2{font-family:var(--serif);font-size:clamp(34px,5vw,58px);font-weight:700;color:#fff;line-height:1.08;margin-bottom:14px}
.choice-wrap h2 em{font-style:italic;color:var(--gold)}
.choice-wrap .sub{font-size:16px;color:rgba(255,255,255,.88);margin-bottom:36px;line-height:1.65}
.choice-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:24px;align-items:center}
.choice-nudge{font-size:14px;color:rgba(255,255,255,.85);font-style:italic}

/* ── SOCIAL ── */
#social{background:#f5f1e8;padding:72px 24px;text-align:center}
#social h2{font-family:var(--serif);font-size:28px;font-weight:400;color:#12152e;margin-bottom:28px;background:none;-webkit-text-fill-color:#12152e}
.social-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.soc-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;font-weight:500;padding:13px 26px;border-radius:100px;transition:all .18s;text-decoration:none;cursor:pointer;border:2px solid transparent}
.soc-btn svg{width:16px;height:16px;flex-shrink:0}
.soc-btn.fb{background:#12152e;color:#fff;border-color:#12152e}
.soc-btn.fb:hover{background:#2a3060;border-color:#2a3060;transform:translateY(-2px)}
.soc-btn.ig{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.soc-btn.ig:hover{background:var(--gold-lt);transform:translateY(-2px)}
.soc-btn.yt{background:transparent;color:#12152e;border-color:#12152e}
.soc-btn.yt:hover{background:#12152e;color:#fff;transform:translateY(-2px)}

/* ── FAQ ── */
#faq{background:#faf8f4;padding:80px 40px}
.faq-header{text-align:center;margin-bottom:40px}
.faq-header h2{font-family:var(--serif);font-size:clamp(26px,3.5vw,42px);font-weight:600;color:#12152e;margin-bottom:8px}
.faq-header p{font-size:15px;color:var(--muted)}
.faq-wrap{max-width:760px;margin:0 auto;background:var(--white);border-radius:var(--r);border:1px solid rgba(26,31,60,.07);overflow:hidden}
.faq-item{border-bottom:1px solid rgba(26,31,60,.07)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:20px 28px;font-family:var(--sans);font-size:15px;font-weight:500;color:#12152e;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:background .12s}
.faq-q:hover{background:rgba(26,31,60,.02)}
.faq-q svg{width:18px;height:18px;flex-shrink:0;color:var(--muted);transition:transform .25s}
.faq-item.open .faq-q svg{transform:rotate(45deg);color:var(--gold)}
.faq-a{display:none;padding:0 28px 20px;font-size:14px;line-height:1.78;color:#12152e}
.faq-item.open .faq-a{display:block}

/* ── FINAL CTA ── */
#final-cta{
  position:relative;overflow:hidden;
  background:
    linear-gradient(to bottom,rgba(61,29,110,0.65) 0%,rgba(13,17,45,0.92) 100%),
    url('../../images/background.png') center bottom/cover no-repeat;
  padding:120px 24px;text-align:center;
}
#final-cta .pre{font-size:clamp(16px,2.2vw,22px);font-weight:300;color:#ffffff;margin-bottom:6px;line-height:1.5}
#final-cta h2{font-family:var(--serif);font-size:clamp(36px,6vw,68px);font-weight:700;color:#fff;margin-bottom:40px;line-height:1.08}
#final-cta .note{margin-top:18px;font-size:13px;font-style:italic;color:#ffffff}

/* ── FOOTER ── */
footer{background:linear-gradient(135deg,#13172d 0%,#1d1040 100%);border-top:1px solid rgba(107,63,160,0.4);padding:28px 40px}
.footer-inner{max-width:1160px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-copy{font-size:13px;color:rgba(255,255,255,.85)}
.footer-links{display:flex;gap:24px;flex-wrap:wrap}
.footer-links a{font-size:13px;color:#e8c97e;transition:color .12s;font-weight:400}
.footer-links a:hover{color:#ffffff}
.footer-disc{max-width:1080px;margin:14px auto 0;font-size:11px;color:rgba(255,255,255,.7);text-align:center}

/* ── PAGE HERO (interior pages) ── */
.page-hero{
  background:linear-gradient(135deg,var(--navy-deep) 0%,var(--purple-deep) 100%);
  padding:80px 40px 72px;text-align:center;
}
.page-hero h1{font-family:var(--serif);font-size:clamp(36px,5vw,60px);font-weight:700;color:#fff;line-height:1.1;margin-bottom:16px}
.page-hero p{font-size:18px;color:rgba(255,255,255,.8);max-width:540px;margin:0 auto;line-height:1.7}
.page-hero .eyebrow{margin-bottom:16px}

/* ── QUIZ MODAL STYLES ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(10,12,28,.82);z-index:1000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.modal-overlay.active{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;position:relative;padding:40px 36px 36px;color:#1a1f3c}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;font-size:22px;color:#aaa;cursor:pointer;line-height:1;padding:4px}
.modal-close:hover{color:#1a1f3c}
.step-pill{display:inline-block;background:#fef3d0;color:#8a6a00;font-size:12px;font-weight:500;padding:5px 14px;border-radius:100px;margin-bottom:20px}
.modal h2{font-family:'Playfair Display',serif;font-size:32px;font-weight:500;color:#1a1f3c;text-align:center;margin-bottom:6px}
.modal .modal-sub{text-align:center;font-size:14px;color:#8a8fa8;margin-bottom:24px}
.progress-bar-wrap{height:3px;background:#eee;border-radius:2px;margin-bottom:28px}
.progress-bar-fill{height:100%;background:#e8c97e;border-radius:2px;transition:width .3s ease}
.question-text{font-size:16px;font-weight:500;color:#1a1f3c;margin-bottom:16px;line-height:1.5}
.option-list{display:flex;flex-direction:column;gap:10px}
.option-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1.5px solid #e8e4f0;border-radius:10px;cursor:pointer;transition:border-color .12s,background .12s;font-size:14px;line-height:1.55;color:#1a1f3c}
.option-item:hover{border-color:#c8c0e0;background:#f9f8ff}
.option-item.selected{border-color:#1a1f3c;background:#f0f0f8}
.radio-circle{width:20px;height:20px;border-radius:50%;border:2px solid #d0cce4;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:border-color .12s}
.option-item.selected .radio-circle{border-color:#1a1f3c;background:#1a1f3c}
.radio-dot{width:8px;height:8px;border-radius:50%;background:#fff;display:none}
.option-item.selected .radio-dot{display:block}
.modal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid #eee}
.btn-back{background:none;border:none;color:#8a8fa8;font-size:14px;cursor:pointer;padding:8px 0}
.btn-back:hover{color:#1a1f3c}
.btn-next{background:#e8c97e;color:#13172d;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;padding:12px 28px;border-radius:100px;border:none;cursor:pointer;transition:background .15s,opacity .15s}
.btn-next:disabled{opacity:.4;cursor:not-allowed}
.btn-next:not(:disabled):hover{background:#f0d99a}
.result-modal{text-align:center;padding:44px 36px 36px}
.result-badge{display:inline-block;background:#f0f0f8;color:#1a1f3c;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:7px 18px;border-radius:100px;margin-bottom:20px}
.result-modal h2{font-family:'Playfair Display',serif;font-size:clamp(24px,4vw,34px);font-weight:500;color:#1a1f3c;line-height:1.2;margin-bottom:16px}
.result-modal p{font-size:15px;line-height:1.75;color:#4a5072;max-width:400px;margin:0 auto 24px}
.result-modal .btn-next{width:100%;max-width:380px;padding:15px}
.result-close-link{display:block;margin-top:14px;font-size:13px;color:#aaa;cursor:pointer;background:none;border:none;text-decoration:underline}
.email-modal{text-align:center}
.email-modal h2{font-family:'Playfair Display',serif;font-size:26px;font-weight:500;color:#1a1f3c;margin-bottom:10px;line-height:1.25}
.email-modal p{font-size:14px;color:#8a8fa8;line-height:1.65;margin-bottom:24px}
.email-input{width:100%;padding:14px 16px;border:1.5px solid #ddd;border-radius:10px;font-size:15px;font-family:'DM Sans',sans-serif;color:#1a1f3c;outline:none;margin-bottom:14px;transition:border-color .12s}
.email-input:focus{border-color:#1a1f3c}

/* ── RESULTS OVERLAY ── */
#results-overlay{display:none;position:fixed;inset:0;z-index:1100;background:#faf8f4;overflow-y:auto}
.ro-close-bar{position:sticky;top:0;z-index:10;background:rgba(250,247,242,.95);backdrop-filter:blur(8px);border-bottom:1px solid rgba(26,31,60,.08);padding:14px 32px;display:flex;align-items:center;justify-content:space-between}
.ro-close-bar span{font-size:13px;color:#8a8fa8}
.ro-close-btn{background:none;border:1px solid rgba(26,31,60,.15);border-radius:100px;padding:7px 18px;font-size:13px;color:#1a1f3c;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .12s}
.ro-close-btn:hover{background:rgba(26,31,60,.05)}
.ro-hero{background:#1a1f3c;padding:72px 24px 60px;text-align:center}
.ro-eyebrow{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:#e8c97e;margin-bottom:18px}
.ro-hero h1{font-family:'Playfair Display',serif;font-size:clamp(30px,5vw,50px);font-weight:300;line-height:1.12;color:#fff;margin-bottom:10px}
.ro-hero h1 em{font-style:italic;color:#e8c97e}
.ro-tagline{font-size:16px;line-height:1.7;color:rgba(255,255,255,.55);max-width:440px;margin:0 auto;font-style:italic}
.ro-body{max-width:640px;margin:0 auto;padding:52px 24px 80px}
.ro-reflection p{font-size:17px;line-height:1.85;color:#12152e;margin-bottom:14px}
.ro-section-label{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#8a7355;margin:36px 0 18px}
.offer-card{background:#1a1f3c;border-radius:12px;padding:36px 32px;margin-bottom:8px;color:#fff}
.offer-title{font-family:'Playfair Display',serif;font-size:26px;font-weight:500;color:#fff;margin-bottom:8px}
.offer-subtitle{font-size:14px;color:rgba(255,255,255,.6);margin-bottom:20px;line-height:1.65}
.offer-divider{height:1px;background:rgba(255,255,255,.12);margin:20px 0}
.offer-list{list-style:none;margin-bottom:20px}
.offer-list li{font-size:14px;color:rgba(255,255,255,.8);padding:7px 0;border-bottom:1px solid rgba(255,255,255,.08);display:flex;gap:10px;align-items:flex-start;line-height:1.55}
.offer-list li:last-child{border-bottom:none}
.offer-list li::before{content:'';width:6px;height:6px;border-radius:50%;background:#e8c97e;flex-shrink:0;margin-top:6px}
.best-for{display:inline-flex;align-items:center;background:rgba(232,201,126,.12);border:1px solid rgba(232,201,126,.3);color:#f0d99a;font-size:12px;font-weight:500;padding:6px 14px;border-radius:100px}
.why-fits-box{background:#f5f1e8;border:1px solid rgba(107,63,160,0.2);border-radius:8px;padding:28px;margin-bottom:36px}
.why-fits-box p{font-size:16px;line-height:1.8;color:#12152e}
.ro-cta{background:#1a1f3c;border-radius:12px;padding:44px 36px;text-align:center;margin-bottom:0}
.ro-cta h2{font-family:'Playfair Display',serif;font-size:28px;font-weight:300;color:#fff;margin-bottom:12px}
.ro-cta p{font-size:15px;line-height:1.75;color:rgba(255,255,255,.55);margin-bottom:28px;max-width:420px;margin-left:auto;margin-right:auto}
.ro-cta .btn-book{display:inline-block;background:#e8c97e;color:#13172d;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;padding:15px 36px;border-radius:100px;text-decoration:none;transition:background .15s}
.ro-cta .btn-book:hover{background:#f0d99a}
.ro-cta-sub{font-size:12px;color:rgba(255,255,255,.3);margin-top:14px;font-style:italic}

/* ── LEGAL MODAL ── */
.legal-modal-overlay{display:none;position:fixed;inset:0;background:rgba(13,17,45,.82);z-index:2000;align-items:flex-start;justify-content:center;padding:20px;backdrop-filter:blur(6px);overflow-y:auto}
.legal-modal-overlay.active{display:flex}
.legal-modal{background:#fff;border-radius:16px;width:100%;max-width:720px;margin:auto;position:relative;overflow:hidden}
.legal-modal-header{background:var(--navy);padding:28px 36px 24px;position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between}
.legal-modal-header h2{font-family:var(--serif);font-size:22px;font-weight:500;color:#fff}
.legal-modal-header .eyebrow{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;margin-top:0}
.legal-close{background:none;border:none;color:rgba(255,255,255,.6);font-size:22px;cursor:pointer;line-height:1;padding:4px}
.legal-close:hover{color:#fff}
.legal-modal-body{padding:32px 36px 40px;max-height:70vh;overflow-y:auto;font-size:14px;line-height:1.8;color:#12152e}
.legal-modal-body h3{font-family:var(--serif);font-size:17px;font-weight:500;color:#12152e;margin:24px 0 8px}
.legal-modal-body h3:first-child{margin-top:0}
.legal-modal-body p{margin-bottom:12px}
.legal-modal-body ul{margin:8px 0 12px 20px}
.legal-modal-body ul li{margin-bottom:6px}
.legal-modal-body a{color:var(--navy);text-decoration:underline}

/* ── BOOKING MODAL ── */
.booking-modal-overlay{display:none;position:fixed;inset:0;background:rgba(13,17,45,.85);z-index:2000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
.booking-modal-overlay.active{display:flex}
.booking-modal{background:#fff;border-radius:16px;width:100%;max-width:640px;overflow:hidden;position:relative}
.booking-modal-header{background:var(--navy);padding:20px 28px;display:flex;align-items:center;justify-content:space-between}
.booking-modal-header h3{font-family:var(--serif);font-size:18px;color:#fff;font-weight:500}
.booking-close{background:none;border:none;color:rgba(255,255,255,.6);font-size:22px;cursor:pointer;line-height:1}
.booking-close:hover{color:#fff}
.booking-modal iframe{display:block;width:100%;height:600px;border:none}

/* ── PATTERN GUIDE MODAL ── */
#pg-overlay{display:none;position:fixed;inset:0;background:rgba(13,17,45,.78);z-index:2000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
.pg-inner{background:#fff;border-radius:16px;max-width:640px;width:100%;overflow:hidden;position:relative;max-height:90vh;overflow-y:auto}
.pg-header{background:var(--navy);padding:32px 36px 28px;text-align:center}
.pg-eyebrow{font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.pg-header h2{font-family:var(--serif);font-size:clamp(22px,4vw,30px);font-weight:500;color:#fff;line-height:1.25}
.pg-body{padding:32px 36px 36px}
.pg-body p{font-size:15px;line-height:1.78;color:#12152e;margin-bottom:20px}
.pg-section{margin-bottom:28px}
.pg-section h3{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--navy);margin-bottom:14px}
.pg-pattern{background:#faf8f4;border-radius:10px;padding:16px 20px;margin-bottom:10px;border-left:3px solid var(--gold)}
.pg-pattern strong{font-size:14px;font-weight:500;color:#12152e;display:block;margin-bottom:4px}
.pg-pattern p{font-size:13px;color:#2a2d45;margin:0;line-height:1.6}
.pg-pullquote{background:var(--navy);border-radius:10px;padding:24px 28px;margin:24px 0}
.pg-pullquote blockquote{font-family:var(--serif);font-style:italic;font-size:16px;color:rgba(255,255,255,.85);line-height:1.65;margin-bottom:8px}
.pg-pullquote cite{font-size:12px;color:var(--gold);letter-spacing:.08em}
.pg-method{background:#f0ecf8;border-radius:10px;padding:20px 24px;margin:20px 0;border:1px solid rgba(107,63,160,0.15)}
.pg-method h4{font-family:var(--serif);font-size:16px;color:var(--navy);margin-bottom:10px}
.pg-method p{font-size:13px;color:#2a2d45;line-height:1.7;margin:0}
.pg-footer{text-align:center;padding:0 36px 36px}
.pg-footer .btn-gold{width:100%;justify-content:center;font-size:15px;padding:16px}
.pg-footer .pg-note{font-size:12px;color:#aaa;margin-top:12px;font-style:italic}
.pg-close{position:absolute;top:14px;right:18px;background:none;border:none;font-size:22px;cursor:pointer;color:rgba(255,255,255,.6);line-height:1;z-index:10}
.pg-close:hover{color:#fff}

/* ── BLOG STYLES ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1080px;margin:0 auto}
.blog-card{background:#fff;border-radius:var(--r);overflow:hidden;border:1px solid rgba(26,31,60,.07);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(26,31,60,.1)}
.blog-card-img{height:220px;position:relative;overflow:hidden;background:linear-gradient(145deg,#1e2d45,#2a3a5c)}
.blog-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.blog-card-body{padding:24px 24px 28px;flex:1;display:flex;flex-direction:column}
.blog-card-cat{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.blog-card-body h3{font-family:var(--serif);font-size:20px;font-weight:500;color:#12152e;margin-bottom:10px;line-height:1.3}
.blog-card-body p{font-size:14px;line-height:1.72;color:#2a2d45;flex:1;margin-bottom:16px}
.blog-card-meta{font-size:12px;color:var(--muted);margin-top:auto}
.blog-card-link{font-size:13px;color:var(--gold);font-weight:500;display:inline-flex;align-items:center;gap:4px;margin-top:12px;transition:color .12s}
.blog-card-link:hover{color:var(--navy)}
.blog-featured-badge{background:var(--gold);color:var(--navy-deep);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:100px;margin-left:8px;vertical-align:middle}
.post-content{max-width:740px;margin:0 auto;padding:60px 40px 80px}
.post-content h2,.post-content h3{font-family:var(--serif);color:#12152e;margin:32px 0 14px}
.post-content h2{font-size:clamp(24px,3.5vw,36px)}
.post-content h3{font-size:clamp(20px,2.5vw,26px)}
.post-content p{font-size:16px;line-height:1.85;color:#2a2d45;margin-bottom:18px}
.post-content .pullquote{font-family:var(--serif);font-style:italic;font-size:20px;border-left:3px solid var(--gold);padding-left:18px;color:var(--navy);margin:28px 0;line-height:1.55}

/* ── EVENTS STYLES ── */
.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;max-width:1080px;margin:0 auto}
.event-card{background:#fff;border-radius:var(--r);border:1px solid rgba(26,31,60,.08);overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.event-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(26,31,60,.1)}
.event-card-img{height:180px;position:relative;overflow:hidden;background:linear-gradient(145deg,#1e2d45,var(--purple-deep))}
.event-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.event-badge{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.event-badge.free{background:var(--gold);color:var(--navy-deep)}
.event-badge.workshop{background:var(--purple-vivid);color:#fff}
.event-badge.keynote{background:var(--navy);color:#fff;border:1px solid rgba(240,180,41,.4)}
.event-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.event-card-body h3{font-family:var(--serif);font-size:20px;font-weight:500;color:#12152e;margin-bottom:10px;line-height:1.3}
.event-meta{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.event-meta span{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.event-card-body p{font-size:14px;line-height:1.72;color:#2a2d45;flex:1;margin-bottom:16px}
.event-price{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--navy);margin-bottom:16px}
.event-register-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--gold);color:var(--navy-deep);font-family:var(--sans);font-size:14px;font-weight:600;padding:12px 24px;border-radius:100px;border:none;cursor:pointer;transition:background .15s;text-decoration:none;width:100%}
.event-register-btn:hover{background:var(--gold-lt)}

/* ── CORPORATE STYLES ── */
.corp-offerings{display:grid;grid-template-columns:1fr;gap:28px;max-width:900px;margin:0 auto}
.corp-card{background:#fff;border-radius:var(--r);border:1px solid rgba(26,31,60,.08);padding:40px 44px;display:flex;gap:36px;align-items:flex-start;transition:box-shadow .2s}
.corp-card:hover{box-shadow:0 12px 40px rgba(26,31,60,.08)}
.corp-card-num{font-family:var(--serif);font-size:42px;color:var(--gold);opacity:.3;min-width:52px;line-height:1}
.corp-card-body h3{font-family:var(--serif);font-size:24px;font-weight:500;color:#12152e;margin-bottom:6px}
.corp-card-type{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.corp-card-body p{font-size:15px;line-height:1.8;color:#2a2d45}
.corp-form-wrap{max-width:720px;margin:0 auto;background:#fff;border-radius:var(--r);border:1px solid rgba(26,31,60,.08);padding:44px}
.corp-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:20px;display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:13px;font-weight:500;color:#12152e}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1.5px solid #e0dded;border-radius:8px;font-size:14px;font-family:var(--sans);color:#12152e;outline:none;transition:border-color .12s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--navy)}
.form-group textarea{resize:vertical;min-height:100px}
.checkbox-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.checkbox-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#2a2d45;cursor:pointer}
.checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--navy)}
.form-success{display:none;text-align:center;padding:32px}
.form-success h3{font-family:var(--serif);font-size:26px;color:var(--navy);margin-bottom:12px}
.form-success p{font-size:15px;color:#2a2d45;line-height:1.7}

/* ── CONTACT STYLES ── */
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:900px;margin:0 auto 60px}
.contact-card{background:#fff;border-radius:var(--r);border:1px solid rgba(26,31,60,.08);overflow:hidden}
.contact-card-header{padding:20px 24px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .12s}
.contact-card-header:hover{background:#faf8f4}
.contact-card-header h3{font-family:var(--serif);font-size:18px;font-weight:500;color:#12152e}
.contact-card-header svg{width:18px;height:18px;color:var(--muted);transition:transform .25s}
.contact-card.open .contact-card-header svg{transform:rotate(45deg);color:var(--gold)}
.contact-card-body{display:none;padding:0 24px 24px;font-size:14px;line-height:1.75;color:#2a2d45}
.contact-card.open .contact-card-body{display:block}
.contact-info-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.contact-info-row a{color:var(--navy);text-decoration:underline;font-weight:500}

/* ── ADMIN STYLES ── */
.admin-wrap{max-width:900px;margin:0 auto;padding:48px 40px}
.admin-section{background:#fff;border-radius:var(--r);border:1px solid rgba(26,31,60,.08);padding:32px;margin-bottom:24px}
.admin-section h2{font-family:var(--serif);font-size:22px;font-weight:500;color:#12152e;margin-bottom:6px}
.admin-section .admin-note{font-size:13px;color:var(--muted);margin-bottom:24px;padding:10px 14px;background:#fef3d0;border-radius:6px;border-left:3px solid var(--gold)}
.admin-field{margin-bottom:18px}
.admin-field label{display:block;font-size:13px;font-weight:500;color:#12152e;margin-bottom:6px}
.admin-field input,.admin-field select,.admin-field textarea{width:100%;padding:10px 12px;border:1.5px solid #e0dded;border-radius:8px;font-size:14px;font-family:var(--sans);color:#12152e;outline:none;transition:border-color .12s}
.admin-field input:focus,.admin-field select:focus,.admin-field textarea:focus{border-color:var(--navy)}
.admin-field textarea{resize:vertical;min-height:80px}
.admin-save-btn{background:var(--gold);color:var(--navy-deep);font-family:var(--sans);font-size:14px;font-weight:600;padding:10px 24px;border-radius:100px;border:none;cursor:pointer;transition:background .15s}
.admin-save-btn:hover{background:var(--gold-lt)}
.admin-login{max-width:400px;margin:120px auto 0;padding:40px;background:#fff;border-radius:var(--r);border:1px solid rgba(26,31,60,.1);text-align:center}
.admin-login h2{font-family:var(--serif);font-size:28px;color:#12152e;margin-bottom:8px}
.admin-login p{font-size:14px;color:var(--muted);margin-bottom:24px}
.admin-login input{width:100%;padding:12px 14px;border:1.5px solid #e0dded;border-radius:8px;font-size:14px;font-family:var(--sans);color:#12152e;outline:none;margin-bottom:14px;transition:border-color .12s;text-align:center}
.admin-login input:focus{border-color:var(--navy)}
#admin-error{color:#c0392b;font-size:13px;margin-bottom:12px;display:none}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .split,.split[style*="rtl"]{grid-template-columns:1fr;direction:ltr}
  .split-img{min-height:320px;order:-1}
  .split-body{padding:52px 36px;direction:ltr}
  .split-body.dark{direction:ltr}
  .pattern-grid{grid-template-columns:1fr 1fr}
  .method-img-strip{grid-template-columns:repeat(2,1fr)}
  .services-grid,.t-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}
  #about{grid-template-columns:1fr}
  .about-img{min-height:380px}
  .about-body{padding:56px 36px}
  .hero-inner{padding:60px 28px 80px}
  .hero-pill{display:none}
  .manifesto-card{padding:48px 32px}
  #choice{padding:72px 20px}
  .choice-wrap h2{font-size:clamp(28px,6vw,44px)}
  .blog-grid{grid-template-columns:1fr 1fr}
  .contact-cards{grid-template-columns:1fr}
  .corp-card{flex-direction:column;gap:12px;padding:28px 32px}
  .corp-form-row{grid-template-columns:1fr}
}
@media(max-width:700px){
  .nav-links,.nav-cta{display:none}
  .nav-ham{display:flex}
  #hero h1{font-size:clamp(36px,9vw,52px)}
  .hero-sub{font-size:16px;max-width:100%}
  .hero-btns{flex-direction:column;align-items:flex-start;gap:12px}
  .hero-btns .btn-gold,.hero-btns .btn-ghost{width:100%;justify-content:center}
  .pattern-grid{grid-template-columns:1fr}
  .pattern-tile{aspect-ratio:4/3}
  .method-img-strip{grid-template-columns:repeat(2,1fr)}
  .manifesto-card{padding:40px 24px}
  #patterns{padding:72px 20px}
  #method{padding:72px 20px}
  #services{padding:72px 20px}
  #testimonials{padding:72px 20px}
  #choice{padding:64px 20px}
  #social{padding:56px 20px}
  #faq{padding:64px 20px}
  #final-cta{padding:80px 20px}
  .choice-btns{flex-direction:column;align-items:stretch;gap:12px}
  .choice-btns button{text-align:center;width:100%}
  .choice-wrap h2{font-size:clamp(28px,7vw,42px)}
  .about-body{padding:40px 24px}
  .about-sig{font-size:22px}
  .svc-img{height:220px}
  .faq-q{padding:18px 20px;font-size:14px}
  .faq-a{padding:0 20px 18px}
  .container{padding-left:20px;padding-right:20px}
  .split-body{padding:40px 24px}
  .footer-inner{flex-direction:column;text-align:center;gap:12px}
  .footer-links{justify-content:center;flex-direction:column;align-items:center;gap:10px}
  .modal{padding:32px 22px 28px;max-height:85vh}
  .legal-modal-body{padding:24px 20px}
  .blog-grid{grid-template-columns:1fr}
  .events-grid{grid-template-columns:1fr}
  .admin-wrap{padding:32px 20px}
  .corp-form-wrap{padding:28px 22px}
  .btn-gold,.btn-ghost{min-height:48px}
  .faq-q{min-height:52px}
  .phase-btn{min-height:52px;padding:16px 0}
  .nav-ham{width:44px;height:44px;align-items:center;justify-content:center}
  .svc-img{height:240px}
  .t-card{padding:28px 22px}
  .method-img-strip{border-radius:8px}
  .manifesto-card p{font-size:15px}
  .social-row{flex-direction:column;align-items:center;max-width:280px;margin:0 auto}
  .soc-btn{width:100%;justify-content:center}
  .pattern-tile{aspect-ratio:3/2}
  #about{min-height:auto}
  .about-img{min-height:300px}
  .hero-inner{padding:56px 22px 80px}
  .faq-a{font-size:14px;line-height:1.72}
  .choice-nudge{font-size:13px;padding:0 8px}
  .ro-body{padding:36px 18px 60px}
  .offer-card{padding:24px 20px}
  .ro-cta{padding:36px 22px}
  .ann-inner{justify-content:center}
  .ann-dismiss{top:8px;transform:none;right:8px}
}
@media(max-width:400px){
  #hero h1{font-size:32px}
  .btn-gold,.btn-ghost{font-size:14px;padding:13px 22px}
}

/* ── SAFE AREA / iOS ── */
@supports(padding: max(0px)){
  nav{padding-left:max(0px, env(safe-area-inset-left));padding-right:max(0px, env(safe-area-inset-right))}
  footer{padding-bottom:max(28px, calc(env(safe-area-inset-bottom) + 16px))}
  #hero{padding-bottom:env(safe-area-inset-bottom)}
}

/* ── PERFORMANCE ── */
.hero-collage,.split-img,.about-img,.svc-img,.pattern-tile{-webkit-transform:translateZ(0);transform:translateZ(0)}
.legal-modal-body,.modal,.pg-inner,.results-overlay{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
