/* =========================================================
   1. TOKENS
========================================================= */
:root{
  --c-bg:#0b0c10;
  --c-bg-alt:#0e1015;
  --c-surface:#161922;
  --c-surface-2:#1c202b;
  --c-surface-3:#232838;
  --c-border:#282e3d;
  --c-border-soft:#1f2430;

  --c-text:#eae7e1;
  --c-text-muted:#a7abb8;
  --c-text-dim:#6d7280;

  --c-accent:#f0a94e;
  --c-accent-2:#e08a2c;
  --c-accent-soft:rgba(240,169,78,.14);

  --c-violet:#7b74f7;
  --c-violet-2:#4a44c9;

  --gradient-accent:linear-gradient(135deg,var(--c-accent),var(--c-accent-2));
  --gradient-violet:linear-gradient(135deg,var(--c-violet),var(--c-violet-2));
  --gradient-hero-bg:radial-gradient(circle at 18% 15%, rgba(123,116,247,.20), transparent 45%),
                     radial-gradient(circle at 82% 5%, rgba(240,169,78,.16), transparent 42%),
                     linear-gradient(180deg,#0b0c10 0%, #0d0f15 55%, #0b0c10 100%);

  --shadow-sm:0 1px 2px rgba(0,0,0,.45);
  --shadow-md:0 10px 28px -10px rgba(0,0,0,.55), 0 2px 8px rgba(0,0,0,.4);
  --shadow-lg:0 28px 64px -20px rgba(0,0,0,.65), 0 10px 24px -10px rgba(0,0,0,.5);
  --shadow-glow:0 0 0 1px rgba(240,169,78,.18), 0 0 44px -8px rgba(240,169,78,.35);
  --shadow-glow-violet:0 0 0 1px rgba(123,116,247,.2), 0 0 44px -8px rgba(123,116,247,.4);

  --radius-sm:10px;
  --radius-md:16px;
  --radius-lg:24px;
  --radius-xl:32px;
  --radius-pill:999px;

  --space-1:0.5rem;
  --space-2:1rem;
  --space-3:1.5rem;
  --space-4:2rem;
  --space-5:3rem;
  --space-6:4.5rem;
  --space-7:6.5rem;
  --space-8:9rem;

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* =========================================================
   2. RESET
========================================================= */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body,h1,h2,h3,h4,p,dl,dd,ul,ol,figure{margin:0;}
ul,ol{padding:0;list-style:none;}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;text-decoration:none;}
button{font:inherit;border:none;background:none;cursor:pointer;color:inherit;}
input,textarea{font:inherit;}
iframe{border:0;}

/* =========================================================
   3. BASE
========================================================= */
body{
  background:var(--c-bg);
  color:var(--c-text);
  font-family:'Plus Jakarta Sans', sans-serif;
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{
  font-family:'Plus Jakarta Sans', sans-serif;
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.01em;
}
mark{
  background:none;
  color:var(--c-accent);
  font-weight:700;
  padding:0 .1em;
}
small{color:var(--c-text-dim); font-size:.82rem;}
main{display:block;}

/* =========================================================
   4. UTILITIES
========================================================= */
.u-hidden{display:none !important;}
.u-text-center{text-align:center;}
.u-reveal{opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease);}
.u-reveal.is-visible{opacity:1; transform:translateY(0);}

/* =========================================================
   5. BUTTONS
========================================================= */
.c-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.6rem;
  border-radius:var(--radius-pill);
  font-weight:600;
  font-size:.95rem;
  min-height:44px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
}
.c-btn--accent{
  background:var(--gradient-accent);
  color:#1a1102;
  box-shadow:var(--shadow-glow);
}
.c-btn--accent:hover{ transform:translateY(-2px); box-shadow:0 0 0 1px rgba(240,169,78,.3), 0 12px 40px -8px rgba(240,169,78,.5); }
.c-btn--ghost{
  background:transparent;
  color:var(--c-text);
  border:1px solid var(--c-border);
}
.c-btn--ghost:hover{ border-color:var(--c-accent); color:var(--c-accent); transform:translateY(-2px); }
.c-btn--lg{ padding:1rem 2rem; font-size:1rem; }

/* =========================================================
   6. NAVIGATION
========================================================= */
.c-nav-wrapper{
  position:fixed; top:0; left:0; right:0; z-index:900;
  background:rgba(11,12,16,.78);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--c-border-soft);
  transition:transform .45s var(--ease);
}
.c-nav-wrapper.is-hidden{ transform:translateY(-100%); }
.c-nav{
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:1rem var(--space-3);
  gap:var(--space-3);
}
.c-nav__brand{ display:flex; align-items:center; flex-shrink:0; }
.c-nav__logo{ height:28px; width:auto; }
.c-nav__links{ display:flex; align-items:center; gap:var(--space-4); flex:1; justify-content:center; }
.c-nav__links a{
  font-size:.92rem; font-weight:500; color:var(--c-text-muted);
  position:relative; padding:.4rem 0;
  transition:color .25s var(--ease);
}
.c-nav__links a::after{
  content:''; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:var(--gradient-accent); transition:width .3s var(--ease);
}
.c-nav__links a:hover{ color:var(--c-text); }
.c-nav__links a:hover::after,
.c-nav__links a[aria-current="page"]::after{ width:100%; }
.c-nav__links a[aria-current="page"]{ color:var(--c-text); }
.c-nav__cta{ flex-shrink:0; }
.c-nav__toggle{
  display:none; flex-direction:column; gap:5px; width:44px; height:44px;
  align-items:center; justify-content:center;
}
.c-nav__toggle span{ display:block; width:22px; height:2px; background:var(--c-text); border-radius:2px; transition:transform .3s var(--ease), opacity .3s var(--ease); }


.c-mobile-menu{
  position:fixed; top:0; left:0; height:100%; width:80%; max-width:340px;
  background:var(--c-surface); z-index:999;
  transform:translateX(-100%);
  transition:transform .45s var(--ease);
  padding:calc(var(--space-4) + 20px) var(--space-4) var(--space-4);
  display:flex; flex-direction:column; gap:var(--space-4);
  box-shadow:var(--shadow-lg);
}
.c-mobile-menu.is-open{ transform:translateX(0); }
.c-mobile-menu__links{ display:flex; flex-direction:column; gap:.4rem; }
.c-mobile-menu__links li{
  opacity:0; transform:translateX(-16px);
}
.c-mobile-menu.is-open .c-mobile-menu__links li{
  animation:menuItemIn .5s var(--ease) forwards;
  animation-delay:calc(var(--i) * 70ms);
}
@keyframes menuItemIn{ to{ opacity:1; transform:translateX(0);} }
.c-mobile-menu__links a{
  display:block; padding:.9rem .5rem; font-size:1.05rem; font-weight:600;
  border-bottom:1px solid var(--c-border-soft); color:var(--c-text-muted);
}
.c-mobile-menu__links a[aria-current="page"]{ color:var(--c-accent); }
.c-mobile-menu__cta{ align-self:flex-start; }
.c-mobile-menu__overlay{
  position:fixed; inset:0; z-index:998;
  background:rgba(4,4,6,.65);
  opacity:0; pointer-events:none;
  transition:opacity .45s var(--ease);
}
.c-mobile-menu__overlay.is-open{ opacity:1; pointer-events:auto; }


.c-tabbar{
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:900;
  background:rgba(14,16,21,.92);
  backdrop-filter:blur(16px);
  border-top:1px solid var(--c-border-soft);
  padding:.5rem .5rem calc(.5rem + env(safe-area-inset-bottom));
  justify-content:space-around;
  align-items:center;
}
.c-tabbar a{
  display:flex; align-items:center; justify-content:center;
  width:48px; height:48px; border-radius:var(--radius-md);
  color:var(--c-text-dim); font-size:1.1rem;
  transition:color .25s var(--ease), background .25s var(--ease);
}
.c-tabbar a[aria-current="page"]{ color:var(--c-accent); background:var(--c-accent-soft); }

@media (max-width:860px){
  .c-nav__links, .c-nav__cta{ display:none; }
  .c-nav__toggle{ display:flex; }
  .c-tabbar{ display:flex; }
  main{ padding-bottom:70px; }
}

/* =========================================================
   7. SECTION HEAD / SHARED
========================================================= */
.s-section-head{ max-width:760px; margin-bottom:var(--space-5); }
.s-section-head--center{ margin-left:auto; margin-right:auto; text-align:center; }
.s-section-head__eyebrow{
  color:var(--c-accent); font-weight:600; font-size:.8rem;
  letter-spacing:.08em; text-transform:uppercase; margin-bottom:var(--space-2);
}
.s-section-head__title{ font-size:clamp(1.8rem,3.6vw,2.6rem); margin-bottom:var(--space-2); }
.s-section-head__lead{ color:var(--c-text-muted); font-size:1.05rem; }

/* =========================================================
   8. HERO
========================================================= */
.s-hero{
  position:relative;
  padding:calc(var(--space-8) + 60px) var(--space-3) var(--space-7);
  display:grid; grid-template-columns:1.1fr .9fr; gap:var(--space-6);
  align-items:center;
  max-width:1280px; margin:0 auto;
}
.s-hero__bg{
  position:absolute; inset:0; top:-40px; z-index:-1;
  background:var(--gradient-hero-bg);
}
.s-hero__eyebrow{
  display:inline-flex; align-items:center; gap:.5rem;
  color:var(--c-accent); font-weight:600; font-size:.82rem;
  letter-spacing:.05em; margin-bottom:var(--space-3);
  background:var(--c-accent-soft); padding:.5rem 1rem; border-radius:var(--radius-pill);
  animation:fadeUp .8s var(--ease) both;
}
.s-hero__title{
  font-size:clamp(2.4rem, 5vw, 3.8rem);
  margin-bottom:var(--space-3);
  animation:fadeUp .8s var(--ease) .1s both;
}
.s-hero__lead{
  font-size:1.15rem; color:var(--c-text-muted); max-width:52ch;
  margin-bottom:var(--space-4);
  animation:fadeUp .8s var(--ease) .2s both;
}
.s-hero__actions{ display:flex; gap:var(--space-2); flex-wrap:wrap; margin-bottom:var(--space-5);
  animation:fadeUp .8s var(--ease) .3s both; }
.s-hero__facts{
  display:flex; gap:var(--space-5); flex-wrap:wrap;
  animation:fadeUp .8s var(--ease) .4s both;
}
.s-hero__facts dt{ font-size:.78rem; color:var(--c-text-dim); text-transform:uppercase; letter-spacing:.06em; margin-bottom:.3rem; }
.s-hero__facts dd{ font-weight:700; font-size:1.05rem; }
.s-hero__figure{
  border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg);
  border:1px solid var(--c-border-soft);
  animation:fadeUp 1s var(--ease) .2s both;
}
.s-hero__figure img{ aspect-ratio:4/5; object-fit:cover; }
.s-hero__figure figcaption{ padding:1rem 1.2rem; background:var(--c-surface); }

@keyframes fadeUp{
  from{ opacity:0; transform:translateY(24px); }
  to{ opacity:1; transform:translateY(0); }
}

@media (max-width:960px){
  .s-hero{ grid-template-columns:1fr; }
  .s-hero__figure{ order:-1; }
}

/* =========================================================
   9. PAGE HERO (inner pages)
========================================================= */
.s-page-hero{
  padding:calc(var(--space-7) + 40px) var(--space-3) var(--space-5);
  background:var(--gradient-hero-bg);
}
.s-page-hero__inner{ max-width:760px; margin:0 auto; text-align:center; }
.s-page-hero h1{ font-size:clamp(2rem,4.4vw,3rem); margin:var(--space-2) 0; }

/* =========================================================
   10. BENTO GRID
========================================================= */
.s-bento{ padding:var(--space-7) var(--space-3); max-width:1280px; margin:0 auto; }
.s-bento--compact{ padding-top:var(--space-6); padding-bottom:var(--space-6); }
.bento-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:minmax(180px,auto);
  gap:var(--space-3);
}
.bento-grid--four{ grid-template-columns:repeat(4,1fr); }
.bento-item{
  background:linear-gradient(160deg, var(--c-surface), var(--c-surface-2));
  border:1px solid var(--c-border-soft);
  border-radius:var(--radius-lg);
  padding:var(--space-4);
  box-shadow:var(--shadow-md);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  display:flex; flex-direction:column; gap:var(--space-2);
  grid-column:span 1;
}
.bento-item:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:rgba(240,169,78,.3); }
.bento-item--lg{ grid-column:span 2; grid-row:span 2; }
.bento-item--wide{ grid-column:span 2; }
.bento-item--img{ padding:0; overflow:hidden; }
.bento-item--img figure{ height:100%; display:flex; flex-direction:column; }
.bento-item--img img{ height:100%; object-fit:cover; flex:1; }
.bento-item--img figcaption{ padding:1rem 1.2rem; }
.bento-item__icon{ font-size:1.5rem; color:var(--c-accent); }
.bento-item h3{ font-size:1.15rem; }
.bento-item p{ color:var(--c-text-muted); font-size:.95rem; }
.bento-item__dl{ margin-top:auto; display:flex; flex-direction:column; gap:.6rem; padding-top:var(--space-2); border-top:1px solid var(--c-border-soft); }
.bento-item__dl dt{ font-size:.75rem; text-transform:uppercase; letter-spacing:.05em; color:var(--c-accent); }
.bento-item__dl dd{ font-size:.9rem; color:var(--c-text-muted); }
.bento-item--book dl{ display:flex; flex-direction:column; gap:.2rem; margin:.2rem 0; }
.bento-item--book dt{ font-size:.72rem; color:var(--c-text-dim); text-transform:uppercase; letter-spacing:.05em; }
.bento-item--book dd{ font-size:.9rem; color:var(--c-text-muted); margin-bottom:.4rem; }

@media (max-width:960px){
  .bento-grid, .bento-grid--four{ grid-template-columns:repeat(2,1fr); }
  .bento-item--lg{ grid-column:span 2; grid-row:span 1; }
}
@media (max-width:560px){
  .bento-grid, .bento-grid--four{ grid-template-columns:1fr; }
  .bento-item--lg, .bento-item--wide{ grid-column:span 1; }
}

/* =========================================================
   11. HOW IT WORKS
========================================================= */
.s-how{ padding:var(--space-7) var(--space-3); max-width:1280px; margin:0 auto; }
.s-how__list{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4); counter-reset:step; }
.s-how__card{
  background:var(--c-surface); border:1px solid var(--c-border-soft); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow-md); position:relative;
  display:flex; flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.s-how__card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.s-how__number{
  position:absolute; top:1rem; left:1rem; z-index:2;
  font-size:.85rem; font-weight:800; color:#1a1102;
  background:var(--gradient-accent); padding:.4rem .8rem; border-radius:var(--radius-pill);
  box-shadow:var(--shadow-glow);
}
.s-how__figure img{ aspect-ratio:16/10; object-fit:cover; }
.s-how__figure figcaption{ padding:.7rem 1.2rem; background:var(--c-surface-2); }
.s-how__body{ padding:var(--space-3); display:flex; flex-direction:column; gap:.6rem; }
.s-how__body i{ color:var(--c-violet); font-size:1.3rem; }
.s-how__body h3{ font-size:1.2rem; }
.s-how__body p{ color:var(--c-text-muted); font-size:.95rem; }

@media (max-width:960px){ .s-how__list{ grid-template-columns:1fr; } }

/* =========================================================
   12. ACCORDION
========================================================= */
.s-accordion{ padding:var(--space-7) var(--space-3); max-width:960px; margin:0 auto; }
.c-accordion__item{
  background:var(--c-surface); border:1px solid var(--c-border-soft);
  border-radius:var(--radius-md); margin-bottom:var(--space-2);
  overflow:hidden; transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.c-accordion__item[data-state="open"]{ border-color:rgba(240,169,78,.35); box-shadow:var(--shadow-md); }
.c-accordion__trigger{
  width:100%; display:flex; align-items:center; gap:var(--space-2);
  padding:var(--space-3); text-align:left;
}
.c-accordion__num{
  font-size:.75rem; font-weight:700; color:var(--c-accent);
  background:var(--c-accent-soft); padding:.35rem .7rem; border-radius:var(--radius-pill);
  flex-shrink:0;
}
.c-accordion__label{ flex:1; font-weight:600; display:flex; align-items:center; gap:.6rem; }
.c-accordion__label i{ color:var(--c-violet); }
.c-accordion__chevron{ transition:transform .35s var(--ease); color:var(--c-text-dim); }
.c-accordion__item[data-state="open"] .c-accordion__chevron{ transform:rotate(180deg); color:var(--c-accent); }
.c-accordion__panel{
  max-height:0; overflow:hidden; transition:max-height .4s var(--ease), padding .4s var(--ease);
  padding:0 var(--space-3);
}
.c-accordion__item[data-state="open"] .c-accordion__panel{ max-height:300px; padding:0 var(--space-3) var(--space-3); }
.c-accordion__panel p{ color:var(--c-text-muted); }

/* =========================================================
   13. SCHEDULE
========================================================= */
.s-schedule{
  display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6);
  align-items:center; padding:var(--space-7) var(--space-3); max-width:1280px; margin:0 auto;
}
.s-schedule__text p{ color:var(--c-text-muted); margin:var(--space-2) 0 var(--space-3); }
.s-schedule__dl{ display:grid; grid-template-columns:auto 1fr; gap:.5rem var(--space-3); margin-bottom:var(--space-4); }
.s-schedule__dl dt{ color:var(--c-accent); font-weight:600; }
.s-schedule__dl dd{ color:var(--c-text-muted); }
.s-schedule__figure{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--c-border-soft); }
.s-schedule__figure img{ aspect-ratio:4/3; object-fit:cover; }
.s-schedule__figure figcaption{ padding:.8rem 1.1rem; background:var(--c-surface); }

@media (max-width:900px){ .s-schedule{ grid-template-columns:1fr; } }

/* =========================================================
   14. CTA
========================================================= */
.s-cta{
  margin:0 var(--space-3) var(--space-7); padding:var(--space-6) var(--space-4);
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg, rgba(123,116,247,.16), rgba(240,169,78,.12)), var(--c-surface);
  border:1px solid var(--c-border-soft);
  max-width:1280px; margin-left:auto; margin-right:auto;
  text-align:center;
}
.s-cta__inner{ max-width:640px; margin:0 auto; display:flex; flex-direction:column; gap:var(--space-2); align-items:center; }
.s-cta h2{ font-size:clamp(1.6rem,3vw,2.2rem); }
.s-cta p{ color:var(--c-text-muted); margin-bottom:var(--space-2); }

/* =========================================================
   15. SPLIT SECTIONS
========================================================= */
.s-split{
  display:grid; grid-template-columns:.9fr 1.1fr; gap:var(--space-6); align-items:center;
  padding:var(--space-6) var(--space-3); max-width:1280px; margin:0 auto;
}
.s-split--reverse{ direction:rtl; }
.s-split--reverse > *{ direction:ltr; }
.s-split__figure{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--c-border-soft); }
.s-split__figure img{ aspect-ratio:4/3; object-fit:cover; }
.s-split__figure figcaption{ padding:.8rem 1.1rem; background:var(--c-surface); }
.s-split__text h2{ font-size:clamp(1.5rem,2.8vw,2rem); margin-bottom:var(--space-2); }
.s-split__text p{ color:var(--c-text-muted); margin-bottom:var(--space-2); }

@media (max-width:900px){
  .s-split, .s-split--reverse{ grid-template-columns:1fr; direction:ltr; }
}

/* =========================================================
   16. OUTPUTS PAGE EXTRAS
========================================================= */
.s-outputs{ padding:var(--space-6) var(--space-3); max-width:1280px; margin:0 auto; }
.s-outputs__dl{ display:flex; flex-direction:column; gap:.3rem; margin:var(--space-3) 0; }
.s-outputs__dl dt{ color:var(--c-accent); font-weight:700; font-size:.85rem; text-transform:uppercase; letter-spacing:.04em; margin-top:.8rem; }
.s-outputs__dl dd{ color:var(--c-text-muted); }
.s-outputs__meter{ margin-top:var(--space-3); display:flex; flex-direction:column; gap:.5rem; }
.s-outputs__meter label{ font-size:.85rem; color:var(--c-text-muted); }
.s-outputs__meter meter{ width:100%; height:12px; }

/* =========================================================
   17. BOOKS PAGE
========================================================= */
.s-books{ padding:var(--space-6) var(--space-3); max-width:1280px; margin:0 auto; }

/* =========================================================
   18. CONTACT PAGE
========================================================= */
.s-contact-grid{
  display:grid; grid-template-columns:1fr 1.1fr; gap:var(--space-6);
  padding:var(--space-6) var(--space-3); max-width:1280px; margin:0 auto;
}
.s-contact-info__list{ display:flex; flex-direction:column; gap:var(--space-3); margin-bottom:var(--space-5); }
.s-contact-info__list li{ display:flex; align-items:flex-start; gap:var(--space-2); }
.s-contact-info__list i{ color:var(--c-accent); font-size:1.2rem; margin-top:.2rem; }
.s-contact-info__list dt{ font-size:.75rem; text-transform:uppercase; letter-spacing:.05em; color:var(--c-text-dim); }
.s-contact-info__list dd{ font-weight:600; }
.s-contact-hours{ background:var(--c-surface); border:1px solid var(--c-border-soft); border-radius:var(--radius-lg); padding:var(--space-3); margin-bottom:var(--space-4); }
.s-contact-hours h2{ font-size:1.2rem; margin-bottom:var(--space-2); }
.s-contact-hours__dl{ display:grid; grid-template-columns:auto 1fr; gap:.4rem var(--space-2); }
.s-contact-hours__dl dt{ color:var(--c-accent); font-weight:600; }
.s-contact-hours__dl dd{ color:var(--c-text-muted); }
.s-contact-map{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--c-border-soft); box-shadow:var(--shadow-md); }
.s-contact-map figcaption{ padding:.6rem 1rem; background:var(--c-surface); }

.s-contact-form-wrap{ background:var(--c-surface); border:1px solid var(--c-border-soft); border-radius:var(--radius-lg); padding:var(--space-4); box-shadow:var(--shadow-md); align-self:start; }
.s-contact-form-wrap h2{ margin-bottom:var(--space-3); font-size:1.3rem; }

@media (max-width:900px){ .s-contact-grid{ grid-template-columns:1fr; } }

/* =========================================================
   19. FORM (horizontal compact)
========================================================= */
.c-form__row{ display:flex; gap:var(--space-2); flex-wrap:wrap; }
.field-group{ display:flex; flex-direction:column; gap:.35rem; flex:1; min-width:150px; }
.field-group--message{ flex:1.4; min-width:200px; }
.field-group label{ font-size:.8rem; color:var(--c-text-muted); }
.field-group input[type="text"],
.field-group input[type="email"],
.field-group textarea{
  background:var(--c-bg-alt); border:1px solid var(--c-border);
  border-radius:var(--radius-sm); padding:.75rem .9rem; color:var(--c-text);
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
  min-height:44px; resize:vertical;
}
.field-group input:focus, .field-group textarea:focus{
  outline:none; border-color:var(--c-accent); box-shadow:0 0 0 3px rgba(240,169,78,.18);
}
.field-hint{ font-size:.72rem; color:var(--c-text-dim); }
.c-form__row--submit{ align-items:center; margin-top:var(--space-3); justify-content:space-between; }
.field-group--checkbox{ flex-direction:row; align-items:center; gap:.6rem; flex:2; min-width:220px; }
.field-group--checkbox input{ width:20px; height:20px; accent-color:var(--c-accent); flex-shrink:0; }
.field-group--checkbox label{ font-size:.85rem; color:var(--c-text-muted); }
.field-group--checkbox label a{ color:var(--c-accent); text-decoration:underline; }
.c-form__alert{ margin-top:var(--space-2); color:#ff8080; font-size:.85rem; }

@media (max-width:760px){
  .c-form__row{ flex-direction:column; }
  .c-form__row--submit{ flex-direction:column; align-items:stretch; gap:var(--space-2); }
}

/* =========================================================
   20. FOOTER
========================================================= */
.c-footer{ background:var(--c-bg-alt); border-top:1px solid var(--c-border-soft); margin-top:auto; }
.c-footer__grid{
  max-width:1280px; margin:0 auto; padding:var(--space-6) var(--space-3) var(--space-4);
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:var(--space-5);
}
.c-footer__logo{ height:26px; margin-bottom:var(--space-2); }
.c-footer__brand p{ color:var(--c-text-muted); font-size:.9rem; max-width:32ch; }
.c-footer__col h3{ font-size:.85rem; text-transform:uppercase; letter-spacing:.06em; color:var(--c-text-dim); margin-bottom:var(--space-2); }
.c-footer__col ul{ display:flex; flex-direction:column; gap:.6rem; }
.c-footer__col a{ color:var(--c-text-muted); font-size:.92rem; transition:color .25s var(--ease); }
.c-footer__col a:hover{ color:var(--c-accent); }
.c-footer__contact li{ display:flex; align-items:center; gap:.5rem; color:var(--c-text-muted); font-size:.92rem; }
.c-footer__contact i{ color:var(--c-accent); }
.c-footer__bottom{
  border-top:1px solid var(--c-border-soft);
  padding:var(--space-3);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem;
  max-width:1280px; margin:0 auto;
}

@media (max-width:860px){
  .c-footer__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .c-footer__grid{ grid-template-columns:1fr; }
  .c-footer__bottom{ flex-direction:column; text-align:center; }
}

/* =========================================================
   21. LEGAL PAGES
========================================================= */
.s-legal{ padding:var(--space-7) var(--space-3); max-width:820px; margin:0 auto; }
.s-legal__inner h1{ font-size:clamp(2rem,4vw,2.6rem); margin-bottom:.4rem; }
.s-legal__inner h2{ font-size:1.25rem; margin:var(--space-4) 0 var(--space-2); color:var(--c-accent); }
.s-legal__inner p{ color:var(--c-text-muted); margin-bottom:var(--space-2); }

/* =========================================================
   22. THANKS PAGE
========================================================= */
.s-thanks{
  min-height:60vh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:var(--space-7) var(--space-3); gap:var(--space-2);
}
.c-check{ margin-bottom:var(--space-3); }
.c-check__circle{
  stroke:var(--c-accent);
  stroke-dasharray:283; stroke-dashoffset:283;
  animation:drawCircle 1s var(--ease) forwards;
}
.c-check__mark{
  stroke:var(--c-accent);
  stroke-dasharray:80; stroke-dashoffset:80;
  animation:drawCheck .5s var(--ease) 1s forwards;
}
@keyframes drawCircle{ to{ stroke-dashoffset:0; } }
@keyframes drawCheck{ to{ stroke-dashoffset:0; } }
.c-check__heading{
  opacity:0; animation:fadeUp .6s var(--ease) 1.5s forwards;
  font-size:clamp(1.8rem,3.6vw,2.4rem);
}
.c-check__text{ opacity:0; animation:fadeUp .6s var(--ease) 1.7s forwards; color:var(--c-text-muted); max-width:52ch; }
.s-thanks .c-btn{ opacity:0; animation:fadeUp .6s var(--ease) 1.9s forwards; margin-top:var(--space-3); }

/* =========================================================
   23. COOKIE CONSENT (floating pill)
========================================================= */
.c-cookie{
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  z-index:1000; background:var(--c-surface-2); border:1px solid var(--c-border);
  box-shadow:var(--shadow-lg);
  transition:all .5s var(--ease);
  border-radius:var(--radius-pill);
  padding:.8rem 1.4rem;
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
  max-width:calc(100vw - 32px);
}
.c-cookie[data-state="expanded"]{
  border-radius:var(--radius-lg);
  padding:var(--space-4);
  width:min(480px, calc(100vw - 32px));
  flex-direction:column; align-items:stretch;
}
.c-cookie__text{ font-size:.85rem; color:var(--c-text-muted); }
.c-cookie__actions{ display:flex; gap:.6rem; flex-wrap:wrap; }
.c-cookie__actions .c-btn{ padding:.6rem 1.1rem; font-size:.85rem; }
.c-cookie__panel{ display:none; flex-direction:column; gap:var(--space-2); margin-top:var(--space-2); }
.c-cookie[data-state="expanded"] .c-cookie__panel{ display:flex; }
.c-cookie[data-state="expanded"] .c-cookie__pill-actions{ display:none; }
.c-cookie__category{ display:flex; justify-content:space-between; align-items:center; gap:var(--space-2); padding:.6rem 0; border-bottom:1px solid var(--c-border-soft); }
.c-cookie__category h4{ font-size:.9rem; margin-bottom:.15rem; }
.c-cookie__category p{ font-size:.78rem; color:var(--c-text-dim); }
.c-cookie__switch{ position:relative; width:42px; height:24px; flex-shrink:0; }
.c-cookie__switch input{ opacity:0; width:100%; height:100%; position:absolute; cursor:pointer; margin:0; }
.c-cookie__switch span{
  position:absolute; inset:0; background:var(--c-border); border-radius:var(--radius-pill);
  transition:background .25s var(--ease);
}
.c-cookie__switch span::before{
  content:''; position:absolute; top:3px; left:3px; width:18px; height:18px; border-radius:50%;
  background:var(--c-text); transition:transform .25s var(--ease);
}
.c-cookie__switch input:checked + span{ background:var(--c-accent); }
.c-cookie__switch input:checked + span::before{ transform:translateX(18px); background:#1a1102; }
.c-cookie__switch input:disabled + span{ opacity:.5; }
.c-cookie__footer-actions{ display:flex; gap:.6rem; justify-content:flex-end; margin-top:var(--space-2); flex-wrap:wrap; }

@media (max-width:600px){
  .c-cookie{ bottom:14px; padding:.7rem 1rem; }
  .c-cookie__text{ font-size:.8rem; }
}

/* =========================================================
   24. GENERIC CARD-WITH-DL (contact list etc)
========================================================= */
.s-contact-info__list dl{ display:flex; flex-direction:column; gap:.1rem; }