/* ============================================================
   MOSES BONILLA — SHARED DESIGN SYSTEM  (--mb-* )
   Reverse-engineered from new-construction-guide.html +
   moses-design-system-v2.md. Editorial luxury, midnight + gold.
   ============================================================ */
:root{
  /* Core palette */
  --mb-midnight:#0B1B3A;
  --mb-midnight-deep:#061229;
  --mb-midnight-slate:#1E3055;
  --mb-gold:#D4A437;
  --mb-gold-dark:#B8862A;
  --mb-gold-light:#E8C572;
  --mb-ivory:#F5F1E8;
  --mb-ivory-warm:#EFE9D8;
  --mb-mist:#E4DFD2;
  --mb-stone:#6B6B66;
  --mb-stone-dark:#3C3C38;
  --mb-bordeaux:#5E1F2C;
  --mb-sage:#3B5340;

  /* The only gradient permitted */
  --mb-grad-gold:linear-gradient(135deg,#B8862A 0%,#D4A437 50%,#E8C572 100%);

  /* Dark-canvas semantic tokens */
  --mb-fg-dark:var(--mb-ivory);
  --mb-fg-dark-muted:rgba(245,241,232,0.72);
  --mb-fg-dark-subtle:rgba(245,241,232,0.48);
  --mb-rule-dark:rgba(245,241,232,0.16);
  --mb-rule-dark-strong:rgba(245,241,232,0.32);

  /* Type */
  --mb-font-display:"Cormorant Garamond","EB Garamond",Georgia,serif;
  --mb-font-body:"Source Sans 3",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mb-font-numeral:"Cormorant Garamond",Georgia,serif;

  --mb-fs-display:clamp(64px,9vw,120px);
  --mb-fs-h1:clamp(40px,5.2vw,64px);
  --mb-fs-h2:clamp(32px,3.6vw,44px);
  --mb-fs-h3:28px;
  --mb-fs-h4:22px;
  --mb-fs-body-lg:18px;
  --mb-fs-body:16px;
  --mb-fs-body-sm:14px;
  --mb-fs-caption:13px;
  --mb-fs-eyebrow:12px;
  --mb-fs-stat:clamp(88px,12vw,144px);

  --mb-lh-display:0.94;
  --mb-lh-heading:1.08;
  --mb-lh-body:1.75;
  --mb-lh-tight:1.25;

  --mb-tr-display:-0.022em;
  --mb-tr-h1:-0.018em;
  --mb-tr-h2:-0.012em;
  --mb-tr-h3:-0.006em;
  --mb-tr-body:0.004em;
  --mb-tr-caption:0.02em;
  --mb-tr-eyebrow:0.18em;

  --mb-fw-light:300;
  --mb-fw-regular:400;
  --mb-fw-medium:500;
  --mb-fw-semibold:600;
  --mb-fw-bold:700;

  /* Spacing — 4px base */
  --mb-space-1:4px;--mb-space-2:8px;--mb-space-3:12px;--mb-space-4:16px;
  --mb-space-5:24px;--mb-space-6:32px;--mb-space-7:48px;--mb-space-8:64px;
  --mb-space-9:96px;--mb-space-10:128px;--mb-space-11:192px;--mb-space-12:256px;

  --mb-gutter-page:clamp(24px,6vw,96px);
  --mb-gutter-section:clamp(64px,10vw,192px);

  /* Radii */
  --mb-radius-0:0px;--mb-radius-sm:2px;--mb-radius-pill:9999px;

  /* Shadows — long, soft */
  --mb-shadow-card:0 24px 48px -16px rgba(11,27,58,0.18);
  --mb-shadow-lift:0 32px 80px -24px rgba(11,27,58,0.28);

  /* Motion */
  --mb-ease-in:cubic-bezier(0.22,1,0.36,1);
  --mb-ease-out:cubic-bezier(0.4,0,0.6,1);
  --mb-ease-rule:cubic-bezier(0.65,0,0.35,1);
  --mb-dur-hover:180ms;
  --mb-dur-component:320ms;
  --mb-dur-page:600ms;
  --mb-stagger:80ms;

  --mb-z-nav:40;
}

/* ============================================================ BASE */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  scroll-behavior:smooth;
  scroll-padding-top:88px;
}
body{
  background:
    radial-gradient(ellipse 80% 60% at 18% -10%, rgba(30,48,85,0.40) 0%, rgba(11,27,58,0) 60%),
    radial-gradient(ellipse 60% 50% at 100% 25%, rgba(212,164,55,0.03) 0%, rgba(11,27,58,0) 55%),
    var(--mb-midnight);
  background-attachment:fixed;
  color:var(--mb-fg-dark);
  font-family:var(--mb-font-body);
  font-size:var(--mb-fs-body-lg);
  line-height:var(--mb-lh-body);
  letter-spacing:var(--mb-tr-body);
  overflow-x:hidden;
}
::selection{background:var(--mb-gold);color:var(--mb-midnight-deep)}
img{max-width:100%;display:block}
a{color:var(--mb-gold);text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font-family:inherit;color:inherit;background:transparent;border:none;outline:none}
:focus-visible{outline:2px solid var(--mb-gold);outline-offset:3px;border-radius:1px}

/* ============================================================ SEMANTIC TYPE */
.mb-display{font-family:var(--mb-font-display);font-size:var(--mb-fs-display);font-weight:var(--mb-fw-light);line-height:var(--mb-lh-display);letter-spacing:var(--mb-tr-display)}
.mb-h1{font-family:var(--mb-font-display);font-size:var(--mb-fs-h1);font-weight:var(--mb-fw-regular);line-height:var(--mb-lh-heading);letter-spacing:var(--mb-tr-h1)}
.mb-h2{font-family:var(--mb-font-display);font-size:var(--mb-fs-h2);font-weight:var(--mb-fw-regular);line-height:var(--mb-lh-heading);letter-spacing:var(--mb-tr-h2)}
.mb-h3{font-family:var(--mb-font-display);font-size:var(--mb-fs-h3);font-weight:var(--mb-fw-medium);line-height:var(--mb-lh-tight);letter-spacing:var(--mb-tr-h3)}
.mb-eyebrow{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.gold-text,.gold,em.gold{background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
em.gold,.mb-display em,.hero h1 em{font-style:italic}

/* ============================================================ SIGNATURE ELEMENTS */
.gold-rule{display:block;height:2px;width:48px;background:var(--mb-grad-gold);border:0;margin:0}
.gold-rule--wide{width:56px}

/* Reveal + wipe motion */
.reveal{--tw-reveal-y:14px;--tw-reveal-dur:600ms;--tw-stagger:80ms;opacity:0;transform:translateY(var(--tw-reveal-y));transition:opacity var(--tw-reveal-dur) var(--mb-ease-in),transform var(--tw-reveal-dur) var(--mb-ease-in)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:calc(var(--tw-stagger)*1)}
.reveal[data-delay="2"]{transition-delay:calc(var(--tw-stagger)*2)}
.reveal[data-delay="3"]{transition-delay:calc(var(--tw-stagger)*3)}
.reveal[data-delay="4"]{transition-delay:calc(var(--tw-stagger)*4)}
.reveal[data-delay="5"]{transition-delay:calc(var(--tw-stagger)*5)}
.wipe{transform-origin:left center;transform:scaleX(0);transition:transform var(--mb-dur-component) var(--mb-ease-rule)}
.wipe.in{transform:scaleX(1)}
@media (prefers-reduced-motion:reduce){
  .reveal,.wipe{opacity:1!important;transform:none!important;transition:none!important}
  html{scroll-behavior:auto}
  *{transition-duration:0ms!important;animation:none!important}
}

/* ============================================================ SITE NAV (multi-page) */
.site-nav{
  position:sticky;top:0;z-index:var(--mb-z-nav);
  height:64px;display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--mb-gutter-page);
  background:rgba(11,27,58,0.72);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--mb-rule-dark);
}
.wordmark{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:21px;letter-spacing:-0.01em;color:var(--mb-ivory);white-space:nowrap}
.wordmark .role{
  display:inline-block;margin-left:12px;padding-left:12px;
  border-left:1px solid var(--mb-rule-dark-strong);
  font-family:var(--mb-font-body);font-size:10px;font-weight:var(--mb-fw-semibold);
  letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;
  color:var(--mb-fg-dark-muted);vertical-align:4px;
}
.nav-right{display:flex;align-items:center;gap:clamp(20px,3vw,40px)}
.nav-links{display:flex;align-items:center;gap:clamp(18px,2.4vw,34px);list-style:none}
.nav-links a{
  font-family:var(--mb-font-body);font-size:13px;font-weight:var(--mb-fw-semibold);
  letter-spacing:0.06em;text-transform:uppercase;color:var(--mb-fg-dark-muted);
  position:relative;padding:6px 0;transition:color var(--mb-dur-hover) var(--mb-ease-in);
}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--mb-grad-gold);transition:right var(--mb-dur-component) var(--mb-ease-in)}
.nav-links a:hover{color:var(--mb-ivory)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-links a.active{color:var(--mb-gold-light)}
.nav-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--mb-ivory);transition:transform var(--mb-dur-component) var(--mb-ease-in),opacity var(--mb-dur-hover)}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Buttons */
.btn-gold{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mb-font-body);font-size:13px;font-weight:var(--mb-fw-semibold);
  letter-spacing:0.16em;text-transform:uppercase;color:var(--mb-midnight-deep);
  background:var(--mb-grad-gold);padding:14px 24px 13px;border-radius:var(--mb-radius-sm);
  transition:opacity var(--mb-dur-hover) var(--mb-ease-in),transform var(--mb-dur-hover) var(--mb-ease-in);
}
.btn-gold:hover{opacity:0.92}
.btn-gold:active{transform:translateY(1px)}
.btn-gold .arrow{transition:transform var(--mb-dur-component) var(--mb-ease-in)}
.btn-gold:hover .arrow{transform:translateX(4px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mb-font-body);font-size:13px;font-weight:var(--mb-fw-semibold);
  letter-spacing:0.16em;text-transform:uppercase;color:var(--mb-ivory);
  padding:13px 24px;border:1px solid var(--mb-rule-dark-strong);border-radius:var(--mb-radius-sm);
  transition:border-color var(--mb-dur-hover) var(--mb-ease-in),color var(--mb-dur-hover) var(--mb-ease-in);
}
.btn-ghost:hover{border-color:var(--mb-gold);color:var(--mb-gold-light)}
.btn-ghost .arrow{transition:transform var(--mb-dur-component) var(--mb-ease-in)}
.btn-ghost:hover .arrow{transform:translateX(4px)}
.nav-cta{padding:11px 20px 10px;font-size:12px}
@media(max-width:860px){.nav-cta-label-long{display:none}}

/* Mobile nav drawer */
.nav-drawer{
  position:fixed;inset:64px 0 0;z-index:39;
  background:rgba(6,18,41,0.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  padding:var(--mb-space-8) var(--mb-gutter-page);
  display:flex;flex-direction:column;gap:8px;
  opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity var(--mb-dur-component) var(--mb-ease-in),transform var(--mb-dur-component) var(--mb-ease-in),visibility var(--mb-dur-component);
}
.nav-drawer.open{opacity:1;visibility:visible;transform:none}
.nav-drawer a{
  font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:34px;
  color:var(--mb-ivory);padding:16px 0;border-bottom:1px solid var(--mb-rule-dark);
  display:flex;justify-content:space-between;align-items:center;
}
.nav-drawer a .ix{font-family:var(--mb-font-numeral);font-style:italic;font-size:15px;color:var(--mb-gold);opacity:0.7}
.nav-drawer a:hover{color:var(--mb-gold-light)}
.nav-drawer .drawer-cta{margin-top:var(--mb-space-6)}

/* ============================================================ LAYOUT PRIMITIVES */
.wrap{padding-left:var(--mb-gutter-page);padding-right:var(--mb-gutter-page)}
.col-12{display:grid;grid-template-columns:repeat(12,1fr);column-gap:clamp(16px,2vw,32px)}
.section{padding-top:var(--mb-gutter-section);padding-bottom:var(--mb-gutter-section)}
.section--tight{padding-top:var(--mb-space-9);padding-bottom:var(--mb-space-9)}
section{position:relative}
.divider{height:1px;background:var(--mb-rule-dark);border:0}

/* Section heading block */
.block-head{display:grid;grid-template-columns:repeat(12,1fr);column-gap:clamp(16px,2vw,32px);margin-bottom:64px}
.block-head .ey{grid-column:1/span 12;font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.block-head h2{grid-column:1/span 9;margin:24px 0 0;font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:clamp(36px,4.4vw,56px);line-height:1.06;letter-spacing:-0.015em;color:var(--mb-ivory)}
.block-head h2 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.block-head .gold-rule{grid-column:1/span 1;align-self:end;margin-top:32px}
.block-head .lead{grid-column:1/span 7;margin:22px 0 0;font-size:18px;line-height:1.6;color:var(--mb-fg-dark-muted)}

/* ============================================================ IMAGE / MEDIA TREATMENT */
.media-frame{position:relative;overflow:hidden;border-radius:var(--mb-radius-sm);background:var(--mb-midnight-deep)}
.media-frame img,.media-frame video{width:100%;height:100%;object-fit:cover;display:block}
.media-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,18,41,0.72) 0%,rgba(6,18,41,0.10) 45%,rgba(6,18,41,0) 70%);pointer-events:none}
.media-frame .tone{position:absolute;inset:0;background:var(--mb-midnight);mix-blend-mode:multiply;opacity:0.18;pointer-events:none}
.media-frame .frame-cap{position:absolute;left:24px;right:24px;bottom:20px;z-index:2;display:flex;align-items:center;gap:14px}
.media-frame .frame-cap .gold-rule{width:32px}
.media-frame .frame-cap span{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-ivory)}

/* ============================================================ HERO (homepage / page openers) */
.hero{position:relative;overflow:hidden;padding-top:var(--mb-space-9);padding-bottom:var(--mb-gutter-section)}
.hero .col-12{position:relative;z-index:1;align-items:center;row-gap:var(--mb-space-7)}
.hero-copy{grid-column:1/span 7}
.hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:var(--mb-space-6)}
.hero-eyebrow .gold-rule{width:48px}
.hero-eyebrow span{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.hero h1{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(52px,8vw,112px);line-height:0.92;letter-spacing:-0.028em;color:var(--mb-ivory);margin:0}
.hero h1 em{font-style:italic;font-weight:var(--mb-fw-light);background:linear-gradient(110deg,#B8862A 0%,#B8862A 25%,#E8C572 40%,#FFF6DC 50%,#E8C572 60%,#B8862A 75%,#B8862A 100%);background-size:400% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;padding-right:0.04em;animation:mb-sheen 5s linear infinite}
@keyframes mb-sheen{from{background-position:0% 0}to{background-position:100% 0}}
@media(prefers-reduced-motion:reduce){.hero h1 em,.opener-headline h1 em{animation:none;background:var(--mb-grad-gold);background-size:100% 100%}}
.hero .hero-sub{margin-top:var(--mb-space-6);font-family:var(--mb-font-display);font-style:italic;font-weight:var(--mb-fw-light);font-size:clamp(20px,2.4vw,28px);line-height:1.3;color:var(--mb-fg-dark-muted);max-width:24ch}
.hero .hero-lead{margin-top:var(--mb-space-5);font-size:18px;line-height:1.6;color:var(--mb-fg-dark);max-width:52ch}
.hero-actions{margin-top:var(--mb-space-7);display:flex;flex-wrap:wrap;align-items:center;gap:18px}
.hero-media{grid-column:8/span 5;position:relative}
.hero-media .media-frame{aspect-ratio:4/5}
.hero-media .num-ghost,.hero .num-ghost{position:absolute;top:50%;right:-2vw;transform:translateY(-50%) translateY(var(--py,0px));font-family:var(--mb-font-numeral);font-style:italic;font-weight:var(--mb-fw-light);font-size:clamp(12rem,26vw,30rem);line-height:1;color:rgba(212,164,55,0.05);pointer-events:none;user-select:none;z-index:0}
/* Hero trust strip */
.trust-strip{display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,56px);margin-top:var(--mb-space-7);padding-top:var(--mb-space-6);border-top:1px solid var(--mb-rule-dark)}
.trust-strip .ts{display:flex;flex-direction:column;gap:4px}
.trust-strip .ts .v{font-family:var(--mb-font-numeral);font-weight:var(--mb-fw-light);font-size:clamp(34px,4vw,52px);line-height:1;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums lining-nums}
.trust-strip .ts .k{font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--mb-fg-dark-muted)}

/* Full-bleed cinematic hero variant */
.hero--fullbleed{padding:0;min-height:calc(100vh - 64px);display:flex;align-items:center}
.hero-video-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-video-bg img,.hero-video-bg video{width:100%;height:100%;object-fit:cover;object-position:55% center;display:block}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(92deg,rgba(6,18,41,0.95) 0%,rgba(11,27,58,0.84) 36%,rgba(11,27,58,0.48) 62%,rgba(11,27,58,0.12) 100%)}
.hero--fullbleed>.wrap{position:relative;z-index:2;padding-top:var(--mb-space-9);padding-bottom:var(--mb-gutter-section);width:100%}

/* Page opener (interior pages, lighter than homepage hero) */
.opener{padding-top:var(--mb-space-9);padding-bottom:var(--mb-space-9);position:relative;overflow:hidden}
.opener .col-12{row-gap:var(--mb-space-6);align-items:end;position:relative;z-index:1}
.opener-eyebrow{grid-column:1/span 12;display:flex;align-items:center;gap:18px}
.opener-eyebrow .label{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.opener-eyebrow .rule{flex:1;height:1px;background:var(--mb-rule-dark);max-width:420px}
.opener-headline{grid-column:1/span 9;margin:0}
.opener-headline h1{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(52px,8vw,104px);line-height:0.94;letter-spacing:-0.025em;color:var(--mb-ivory);margin:0}
.opener-headline h1 em{font-style:italic;font-weight:var(--mb-fw-light);background:linear-gradient(110deg,#B8862A 0%,#B8862A 25%,#E8C572 40%,#FFF6DC 50%,#E8C572 60%,#B8862A 75%,#B8862A 100%);background-size:400% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:mb-sheen 5s linear infinite}
.opener-lead{grid-column:6/span 6}
.opener-lead .gold-rule{margin-bottom:22px;width:56px}
.opener-lead p{margin:0;font-size:19px;line-height:1.6;color:var(--mb-fg-dark)}
.opener-lead p+p{margin-top:16px;color:var(--mb-fg-dark-muted);font-size:17px}

/* ============================================================ STAT SECTION */
.stat-section{border-top:1px solid var(--mb-rule-dark);border-bottom:1px solid var(--mb-rule-dark);padding-top:var(--mb-space-9);padding-bottom:var(--mb-space-9)}
.stat-section .col-12{align-items:start;row-gap:var(--mb-space-6)}
.stat-eyebrow{grid-column:1/span 4}
.stat-eyebrow .ey{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.stat-eyebrow .gold-rule{margin:14px 0 18px}
.stat-eyebrow p{margin:0;font-size:14px;line-height:1.5;color:var(--mb-fg-dark-muted);max-width:26ch}
.stat-figure{grid-column:5/span 4;display:flex;align-items:baseline;gap:4px}
.stat-figure .num{font-family:var(--mb-font-numeral);font-weight:var(--mb-fw-light);font-size:clamp(80px,12vw,160px);line-height:0.9;letter-spacing:-0.04em;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums lining-nums;transform:translateY(var(--py,0px))}
.stat-figure .pct{font-family:var(--mb-font-numeral);font-weight:var(--mb-fw-light);font-size:clamp(36px,6vw,72px);color:var(--mb-fg-dark-muted);align-self:flex-end;margin-left:6px;line-height:1;padding-bottom:0.6em}
.stat-descriptor{grid-column:9/span 4;padding-top:18px}
.stat-descriptor h3{margin:0 0 14px;font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:28px;line-height:1.2;letter-spacing:-0.01em;color:var(--mb-ivory)}
.stat-descriptor p{margin:0;font-size:15px;line-height:1.55;color:var(--mb-fg-dark-muted)}

/* ============================================================ TRIPTYCH / CARD GRID */
.tri-grid{display:grid;grid-template-columns:0.85fr 1fr 1.25fr;gap:clamp(16px,2vw,28px);align-items:stretch}
.tri-grid.even{grid-template-columns:repeat(3,1fr)}
.card{position:relative;padding:36px 32px 40px;border:1px solid var(--mb-rule-dark);background:rgba(11,27,58,0.35);display:flex;flex-direction:column;overflow:hidden}
.card .num{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-style:italic;font-size:18px;color:var(--mb-fg-dark-subtle);letter-spacing:0.08em}
.card .verdict{margin-top:18px;font-family:var(--mb-font-body);font-size:11px;font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.card h3{margin:16px 0 0;font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:28px;line-height:1.05;letter-spacing:-0.015em;color:var(--mb-ivory)}
.card .desc{margin:20px 0 0;font-size:16px;line-height:1.55;color:var(--mb-fg-dark-muted)}
.card ul{margin:28px 0 0;padding:0;list-style:none;border-top:1px solid var(--mb-rule-dark)}
.card li{padding:12px 0;border-bottom:1px solid var(--mb-rule-dark);font-size:14px;color:var(--mb-fg-dark);display:flex;gap:12px;align-items:baseline}
.card li:last-child{border-bottom:0}
.card li::before{content:"";display:inline-block;flex:none;width:6px;height:1px;background:var(--mb-grad-gold);transform:translateY(-4px)}
.card li strong{color:var(--mb-ivory);font-weight:var(--mb-fw-semibold)}
.card.skip{background:rgba(6,18,41,0.5)}
.card.skip .verdict{color:var(--mb-stone)}
.card.skip h3{color:var(--mb-fg-dark-muted);font-size:26px;font-weight:var(--mb-fw-light);font-style:italic}
.card.skip li{color:var(--mb-fg-dark-muted)}
.card.skip li::before{background:rgba(245,241,232,0.3)}
.card.consider{background:rgba(11,27,58,0.55)}
.card.consider::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--mb-grad-gold);opacity:0.55}
.card.consider .verdict{color:var(--mb-gold-light)}
.card.consider h3{font-size:30px}
.card.always{background:var(--mb-midnight-slate);border-color:transparent;box-shadow:var(--mb-shadow-lift)}
.card.always::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--mb-grad-gold)}
.card.always .verdict{color:transparent;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text}
.card.always h3{font-size:32px;color:var(--mb-ivory)}
.card.always li::before{background:var(--mb-grad-gold);width:8px}

/* ============================================================ FLIP CARD SYSTEM */
.card:has(.card-inner),.card.is-flip{padding:0;background:none!important;border:none!important;overflow:visible;display:block;height:100%;min-height:280px;cursor:pointer}
.card:has(.card-inner)::before,.card.is-flip::before{display:none!important}
.card-inner{position:relative;height:100%;min-height:280px;transform-style:preserve-3d;transition:transform 0.65s cubic-bezier(0.4,0,0.2,1);will-change:transform}
.card.is-flipped .card-inner{transform:rotateY(180deg)!important}
.card-front,.card-back{position:absolute;inset:0;padding:36px 32px 40px;display:flex;flex-direction:column;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:1px solid var(--mb-rule-dark)}
.card-front{background:rgba(11,27,58,0.35)}
.card.skip .card-front{background:rgba(6,18,41,0.5)}
.card.consider .card-front{background:rgba(11,27,58,0.55)}
.card.consider .card-front::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--mb-grad-gold);opacity:0.55}
.card.always .card-front{background:rgba(11,27,58,0.55);border-color:rgba(212,175,55,0.28);box-shadow:none}
.card.always .card-front::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--mb-grad-gold)}
.card-back{background:rgba(7,18,44,0.97);border-color:rgba(212,175,55,0.35);transform:rotateY(180deg);overflow:hidden}
.card-back::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--mb-grad-gold)}
.card-back ul{margin:0}
.card-flip-hint{margin-top:auto;padding-top:20px;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--mb-fg-dark-subtle);display:flex;align-items:center;gap:6px;opacity:0.6}
.back-label{font-size:11px;font-family:var(--mb-font-body);font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--mb-gold-light);margin-bottom:16px}
.back-close{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--mb-fg-dark-subtle);opacity:0.6;margin-top:16px;display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.back-cta-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:13px;color:var(--mb-gold-light);text-decoration:none;letter-spacing:0.03em;opacity:0.9}
.back-cta-link:hover{opacity:1}
@media(max-width:560px){.card-front,.card-back{padding:28px 24px 32px}}

/* ============================================================ FEATURE CARDS (guides / tools / towns with media) */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(18px,2.2vw,28px)}
.feature-grid.two{grid-template-columns:repeat(2,1fr)}
.feature-grid.three{grid-template-columns:repeat(3,1fr)}
.feature{position:relative;display:flex;flex-direction:column;border:1px solid var(--mb-rule-dark);background:rgba(11,27,58,0.35);overflow:hidden;transition:border-color var(--mb-dur-component) var(--mb-ease-in),transform var(--mb-dur-component) var(--mb-ease-in),box-shadow var(--mb-dur-component) var(--mb-ease-in)}
.feature:hover{border-color:rgba(212,164,55,0.45);transform:translateY(-5px);box-shadow:var(--mb-shadow-lift)}
.feature::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--mb-grad-gold);transform:scaleX(0);transform-origin:left;transition:transform var(--mb-dur-component) var(--mb-ease-rule);z-index:3}
.feature:hover::before{transform:scaleX(1)}
.feature .media-frame{aspect-ratio:16/10}
.feature-body{padding:28px 28px 32px;display:flex;flex-direction:column;flex:1}
.feature-body .kicker{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-gold-light);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.feature-body .kicker::before{content:"";width:20px;height:1px;background:var(--mb-grad-gold)}
.feature-body h3{font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:clamp(24px,2.6vw,30px);line-height:1.08;letter-spacing:-0.012em;color:var(--mb-ivory);margin:0 0 14px}
.feature-body h3 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.feature-body p{font-size:15px;line-height:1.6;color:var(--mb-fg-dark-muted);margin:0 0 22px}
.feature-body .more{margin-top:auto;display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:var(--mb-fw-semibold);letter-spacing:0.14em;text-transform:uppercase;color:var(--mb-gold-light)}
.feature-body .more .arrow{transition:transform var(--mb-dur-component) var(--mb-ease-in)}
.feature:hover .more .arrow{transform:translateX(5px)}

/* Town card — image-led, sharp */
.town-card{position:relative;overflow:hidden;border:1px solid var(--mb-rule-dark);min-height:280px;display:flex;align-items:flex-end;transition:border-color var(--mb-dur-component) var(--mb-ease-in),transform var(--mb-dur-component) var(--mb-ease-in)}
.town-card:hover{border-color:rgba(212,164,55,0.45);transform:translateY(-4px)}
.town-card .bg{position:absolute;inset:0}
.town-card .bg img{width:100%;height:100%;object-fit:cover}
.town-card .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,18,41,0.92) 6%,rgba(6,18,41,0.35) 55%,rgba(6,18,41,0.12) 100%)}
.town-card .bg .tone{position:absolute;inset:0;background:var(--mb-midnight);mix-blend-mode:multiply;opacity:0.15}
.town-card .tc-body{position:relative;z-index:2;padding:26px 26px 28px}
.town-card .tc-body .ix{font-family:var(--mb-font-numeral);font-style:italic;font-size:14px;color:var(--mb-gold-light);letter-spacing:0.06em}
.town-card .tc-body h3{font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:30px;line-height:1;letter-spacing:-0.01em;color:var(--mb-ivory);margin:8px 0 8px}
.town-card .tc-body p{font-size:14px;line-height:1.5;color:var(--mb-fg-dark-muted);margin:0}
.town-card .tc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.tag{font-size:11px;font-weight:var(--mb-fw-semibold);letter-spacing:0.08em;text-transform:uppercase;color:var(--mb-gold-light);border:1px solid var(--mb-rule-dark-strong);padding:5px 10px;border-radius:var(--mb-radius-pill)}

/* ============================================================ NARRATIVE + LEDGER */
.narrative .col-12{row-gap:var(--mb-space-6);align-items:start}
.narrative .ey{grid-column:1/span 3}
.narrative .ey .gold-rule{margin-bottom:12px}
.narrative .ey span{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.narrative .prose{grid-column:4/span 6}
.narrative .prose p{margin:0 0 24px;font-size:19px;line-height:1.7;color:var(--mb-fg-dark)}
.narrative .prose p:last-child{margin-bottom:0}
.narrative .prose p em{font-family:var(--mb-font-display);font-style:italic;color:var(--mb-gold-light)}
.narrative .prose strong{color:var(--mb-ivory);font-weight:var(--mb-fw-semibold)}
.ledger{grid-column:10/span 3;border-top:1px solid var(--mb-rule-dark);padding-top:18px}
.ledger .label{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.ledger .ledger-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:14px 0;border-bottom:1px solid var(--mb-rule-dark);font-size:14px}
.ledger .ledger-row .k{color:var(--mb-fg-dark-muted)}
.ledger .ledger-row .v{font-family:var(--mb-font-numeral);font-weight:var(--mb-fw-regular);font-size:18px;color:var(--mb-ivory);font-variant-numeric:tabular-nums lining-nums;white-space:nowrap}
.ledger .ledger-row.total{border-bottom:0;padding-top:18px}
.ledger .ledger-row.total .k{font-family:var(--mb-font-body);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);color:var(--mb-gold-light)}
.ledger .ledger-row.total .v{background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:28px}
.ledger .ledger-cap{margin:18px 0 0;font-size:12px;line-height:1.5;color:var(--mb-fg-dark-subtle)}

/* ============================================================ STEPS */
.steps{display:grid;gap:0;border-top:1px solid var(--mb-rule-dark)}
.step{display:grid;grid-template-columns:repeat(12,1fr);column-gap:clamp(16px,2vw,32px);padding:36px 0;border-bottom:1px solid var(--mb-rule-dark)}
.step .step-num{grid-column:1/span 2;font-family:var(--mb-font-numeral);font-style:italic;font-weight:var(--mb-fw-light);font-size:clamp(40px,5vw,72px);line-height:0.9;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-0.02em}
.step .step-body{grid-column:3/span 8}
.step .step-meta{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-gold-light);margin-bottom:12px}
.step .step-body h4{font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:clamp(26px,3vw,34px);line-height:1.1;letter-spacing:-0.012em;color:var(--mb-ivory);margin:0 0 14px}
.step .step-body p{margin:0 0 12px;font-size:17px;line-height:1.65;color:var(--mb-fg-dark-muted)}
.step .step-body p:last-child{margin-bottom:0}
.step .step-body strong{color:var(--mb-ivory);font-weight:var(--mb-fw-semibold)}
.step .step-body em{font-family:var(--mb-font-display);font-style:italic;color:var(--mb-gold-light)}

/* ============================================================ TIP PANEL */
.tip{display:grid;grid-template-columns:1fr 2fr;gap:0;background:var(--mb-midnight-deep);border:1px solid var(--mb-rule-dark);position:relative;overflow:hidden}
.tip::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--mb-grad-gold)}
.tip.alert::before{background:linear-gradient(135deg,#3F1019 0%,#8E2D3F 45%,#D4A437 100%)}
.tip-left{padding:56px 48px 56px 64px;border-right:1px solid var(--mb-rule-dark)}
.tip-left .marker{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:9999px;margin-bottom:28px;font-family:var(--mb-font-display);font-style:italic;font-weight:var(--mb-fw-light);font-size:24px;background:var(--mb-grad-gold);color:var(--mb-midnight-deep)}
.tip-left .ey{display:block;font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-gold-light);margin-bottom:12px}
.tip-left h3{margin:0;font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:clamp(28px,3.4vw,36px);line-height:1.08;letter-spacing:-0.015em;color:var(--mb-ivory)}
.tip-right{padding:56px 64px 56px 48px;display:flex;flex-direction:column;gap:18px}
.tip-right p{margin:0;font-size:17px;line-height:1.65;color:var(--mb-fg-dark)}
.tip-right p em{font-family:var(--mb-font-display);font-style:italic;color:var(--mb-gold-light)}
.tip-right strong{color:var(--mb-ivory);font-weight:var(--mb-fw-semibold)}
.tip-right .ask{margin-top:8px;border-top:1px solid var(--mb-rule-dark);padding-top:24px}
.tip-right .ask .q{font-family:var(--mb-font-display);font-style:italic;font-weight:var(--mb-fw-regular);font-size:22px;line-height:1.35;color:var(--mb-ivory);padding-left:18px;border-left:2px solid;border-image:var(--mb-grad-gold) 1}

/* ============================================================ CLOSING PRINCIPLE */
.principle-block .col-12{row-gap:var(--mb-space-6);align-items:start}
.principle-block .ey{grid-column:1/span 3}
.principle-block .ey .gold-rule{margin-bottom:12px}
.principle-block .ey span{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.principle-block .principle{grid-column:4/span 9}
.principle-block .principle h2{margin:0 0 32px;font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-style:italic;font-size:clamp(36px,5.4vw,72px);line-height:1.05;letter-spacing:-0.02em;color:var(--mb-ivory);max-width:20ch}
.principle-block .principle h2 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.principle-block .principle p{margin:0 0 18px;font-size:18px;line-height:1.7;color:var(--mb-fg-dark);max-width:60ch}
.principle-block .principle p:last-child{margin-bottom:0}
.principle-block .principle strong{color:var(--mb-ivory);font-weight:var(--mb-fw-semibold)}
.principle-block .principle em{font-family:var(--mb-font-display);font-style:italic;color:var(--mb-gold-light)}

/* ============================================================ CTA — sms-pair */
.cta{border-top:1px solid var(--mb-rule-dark)}
.cta .col-12{row-gap:var(--mb-space-6);align-items:end;padding-top:var(--mb-space-8);padding-bottom:var(--mb-space-8)}
.cta-meta{grid-column:1/span 4}
.cta-meta .ey{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.cta-meta .gold-rule{margin:14px 0 18px}
.cta-meta p{margin:0;font-size:14px;line-height:1.55;color:var(--mb-fg-dark-muted);max-width:28ch}
.cta-action{grid-column:5/span 8}
.cta-action .hed{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(34px,5vw,60px);line-height:1.05;letter-spacing:-0.018em;color:var(--mb-ivory);margin:0 0 32px}
.cta-action .hed em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.sms-pair{display:grid;grid-template-columns:auto auto 1fr;align-items:center;gap:clamp(20px,3vw,48px);border-top:1px solid var(--mb-rule-dark);border-bottom:1px solid var(--mb-rule-dark);padding:28px 0}
.sms-pair .label{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.sms-pair .keyword{display:inline-flex;align-items:center;gap:12px;font-family:var(--mb-font-body);font-size:13px;font-weight:var(--mb-fw-semibold);letter-spacing:0.22em;text-transform:uppercase;color:var(--mb-midnight-deep);background:var(--mb-grad-gold);padding:14px 22px 13px;border-radius:2px;transition:opacity var(--mb-dur-hover) var(--mb-ease-in),transform var(--mb-dur-hover)}
.sms-pair .keyword:hover{opacity:0.92}
.sms-pair .keyword:active{transform:translateY(1px)}
.sms-pair .number-block{display:flex;flex-direction:column;align-items:flex-end;justify-self:end}
.sms-pair .number-block .pre{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}
.sms-pair .number-block .num{font-family:var(--mb-font-numeral);font-weight:var(--mb-fw-light);font-size:32px;color:var(--mb-ivory);letter-spacing:0.01em;margin-top:4px}

/* ============================================================ QUESTION CHECKLIST */
.q-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px)}
.q-group .q-title{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-gold-light);font-weight:var(--mb-fw-semibold);padding-bottom:14px;border-bottom:1px solid var(--mb-rule-dark);margin-bottom:8px}
.q-group ul{list-style:none}
.q-group li{padding:14px 0 14px 30px;position:relative;border-bottom:1px solid var(--mb-rule-dark);font-size:16px;line-height:1.55;color:var(--mb-fg-dark)}
.q-group li:last-child{border-bottom:0}
.q-group li::before{content:"";position:absolute;left:0;top:1.15em;width:13px;height:13px;border:1px solid var(--mb-gold);border-radius:1px}
.q-group li em{font-family:var(--mb-font-display);font-style:italic;color:var(--mb-gold-light)}

/* ============================================================ INTERACTIVE TOOLS */
.tool{background:linear-gradient(180deg,var(--mb-midnight-slate) 0%,rgba(11,27,58,0.4) 100%);border:1px solid var(--mb-rule-dark);position:relative;overflow:hidden}
.tool::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--mb-grad-gold)}
.tool-inner{padding:clamp(32px,5vw,64px)}
.tool .tool-ey{font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-gold-light);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.tool .tool-ey::before{content:"";width:24px;height:1px;background:var(--mb-grad-gold)}
.tool h3{font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:clamp(30px,4vw,44px);line-height:1.05;letter-spacing:-0.015em;color:var(--mb-ivory);margin:0 0 14px}
.tool h3 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.tool .tool-sub{font-size:16px;color:var(--mb-fg-dark-muted);margin:0 0 48px;max-width:62ch;line-height:1.6}
.tool-grid{display:grid;grid-template-columns:5fr 7fr;gap:clamp(32px,5vw,64px);align-items:start}
.tool-inputs{display:grid;gap:24px}
.field{display:flex;flex-direction:column;gap:10px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:0.12em;color:var(--mb-fg-dark-muted);font-weight:var(--mb-fw-semibold);display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.field label .val{font-family:var(--mb-font-numeral);font-size:18px;text-transform:none;letter-spacing:0;color:var(--mb-gold-light)}
.field input[type=number],.field input[type=text],.field select{padding:13px 16px;background:rgba(6,18,41,0.6);border:1px solid var(--mb-rule-dark);border-radius:var(--mb-radius-sm);font-size:16px;color:var(--mb-ivory);transition:border-color var(--mb-dur-hover) var(--mb-ease-in);width:100%}
.field input:focus,.field select:focus{border-color:var(--mb-gold)}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23D4A437' d='M6 8L0 0h12z'/></svg>");background-repeat:no-repeat;background-position:right 16px center;padding-right:44px}
.field input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:2px;background:var(--mb-rule-dark-strong);border-radius:9999px;padding:0;border:0;margin:6px 0}
.field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--mb-gold);cursor:pointer;border:2px solid var(--mb-midnight-deep)}
.field input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--mb-gold);cursor:pointer;border:2px solid var(--mb-midnight-deep)}
.field .hint{font-size:12px;color:var(--mb-fg-dark-subtle);line-height:1.4}
/* segmented control */
.seg{display:inline-flex;border:1px solid var(--mb-rule-dark);border-radius:var(--mb-radius-sm);overflow:hidden}
.seg button{padding:10px 16px;font-size:12px;font-weight:var(--mb-fw-semibold);letter-spacing:0.08em;text-transform:uppercase;color:var(--mb-fg-dark-muted);transition:color var(--mb-dur-hover),background var(--mb-dur-hover)}
.seg button.on{background:var(--mb-grad-gold);color:var(--mb-midnight-deep)}

.tool-output{background:var(--mb-midnight-deep);border:1px solid var(--mb-rule-dark);padding:clamp(24px,3vw,36px);display:flex;flex-direction:column}
.tool-output .out-ey{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-fg-dark-muted);font-weight:var(--mb-fw-semibold);margin-bottom:12px}
.tool-output .out-num{font-family:var(--mb-font-numeral);font-weight:var(--mb-fw-light);font-size:clamp(48px,7vw,80px);line-height:1;letter-spacing:-0.03em;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums lining-nums}
.tool-output .out-rule{height:2px;width:80px;background:var(--mb-grad-gold);margin:18px 0 22px;transition:width var(--mb-dur-page) var(--mb-ease-in)}
.tool-output .out-sub{font-size:15px;color:var(--mb-fg-dark-muted);margin-bottom:24px;line-height:1.6}
.tool-output .out-sub strong{color:var(--mb-gold-light);font-weight:var(--mb-fw-semibold)}
.tool-ledger{margin-top:auto;border-top:1px solid var(--mb-rule-dark);padding-top:20px;display:grid;gap:2px}
.tool-ledger .row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:9px 0;font-size:14px}
.tool-ledger .row .k{color:var(--mb-fg-dark-muted)}
.tool-ledger .row .v{font-family:var(--mb-font-numeral);font-size:17px;color:var(--mb-ivory);font-variant-numeric:tabular-nums}
.tool-ledger .row.total{border-top:1px solid var(--mb-rule-dark);margin-top:8px;padding-top:16px}
.tool-ledger .row.total .k{text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);color:var(--mb-gold-light)}
.tool-ledger .row.total .v{font-size:22px;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
/* bars */
.bars{display:flex;flex-direction:column;gap:14px;margin:8px 0 18px}
.bar-pair{display:flex;flex-direction:column;gap:6px}
.bar-track{width:100%;height:46px;background:rgba(245,241,232,0.06);position:relative;overflow:hidden}
.bar-fill{position:absolute;left:0;top:0;bottom:0;width:0%;background:var(--mb-grad-gold);transition:width var(--mb-dur-page) var(--mb-ease-in);display:flex;align-items:center;justify-content:flex-end;padding-right:10px}
.bar-fill.alt{background:rgba(245,241,232,0.30)}
.bar-fill .bv{font-family:var(--mb-font-numeral);font-size:15px;color:var(--mb-midnight-deep);font-variant-numeric:tabular-nums;white-space:nowrap}
.bar-fill.alt .bv{color:var(--mb-ivory)}
.bar-label{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:0.1em;color:var(--mb-fg-dark-muted)}
.legend{display:flex;gap:24px;font-size:12px;color:var(--mb-fg-dark-muted);margin-bottom:8px}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend i{width:10px;height:10px;display:inline-block}
.legend i.g{background:var(--mb-grad-gold)}
.legend i.s{background:rgba(245,241,232,0.30)}
.tool-verdict{border-top:1px solid var(--mb-rule-dark);padding-top:20px;margin-top:8px;font-family:var(--mb-font-display);font-size:18px;line-height:1.45;color:var(--mb-fg-dark);font-style:italic}
.tool-verdict strong{color:var(--mb-gold-light);font-weight:var(--mb-fw-regular);font-style:normal}

/* ============================================================ COMPARE TABLE (towns) */
.cmp-wrap{overflow-x:auto;border:1px solid var(--mb-rule-dark)}
.cmp{width:100%;border-collapse:collapse;min-width:680px}
.cmp th,.cmp td{text-align:left;padding:18px 20px;border-bottom:1px solid var(--mb-rule-dark);font-size:15px;vertical-align:top}
.cmp thead th{position:sticky;top:0;background:var(--mb-midnight-slate);font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:22px;letter-spacing:-0.01em;color:var(--mb-ivory)}
.cmp thead th small{display:block;font-family:var(--mb-font-body);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--mb-gold-light);margin-top:4px;font-weight:var(--mb-fw-semibold)}
.cmp tbody th{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:0.1em;color:var(--mb-fg-dark-muted);font-weight:var(--mb-fw-semibold);width:160px}
.cmp td{color:var(--mb-fg-dark)}
.cmp td .num{font-family:var(--mb-font-numeral);font-size:20px;color:var(--mb-gold-light)}
.cmp tbody tr:hover td,.cmp tbody tr:hover th{background:rgba(245,241,232,0.03)}

/* ============================================================ COSMOS + FX */
#mb-cosmos{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity 1.4s var(--mb-ease-in)}
body.fx-cosmos #mb-cosmos{opacity:1}
body.fx-vignette::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:2;background:radial-gradient(ellipse 110% 95% at 50% 38%, transparent 50%, rgba(3,9,24,0.55) 100%)}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:55;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");background-size:160px 160px;opacity:0.07;mix-blend-mode:overlay;animation:mb-grain 0.6s steps(3) infinite}
@keyframes mb-grain{0%{transform:translate(0,0)}33%{transform:translate(-5%,3%)}66%{transform:translate(4%,-4%)}100%{transform:translate(0,0)}}
@media(prefers-reduced-motion:reduce){body::after{animation:none}}
main p{line-height:1.85}
main,.site-nav,.site-footer{position:relative;z-index:3}

/* ============================================================ FOOTER */
.site-footer{border-top:1px solid var(--mb-rule-dark);padding-top:var(--mb-space-9);padding-bottom:var(--mb-space-7);margin-top:0}
.site-footer .col-12{row-gap:var(--mb-space-7)}
.footer-brand{grid-column:1/span 5}
.footer-brand .fwm{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:32px;color:var(--mb-ivory);letter-spacing:-0.01em}
.footer-brand .fmeta{margin-top:12px;font-size:13px;letter-spacing:0.04em;text-transform:uppercase;color:var(--mb-fg-dark-muted);line-height:1.8}
.footer-brand .fline{margin-top:20px;font-family:var(--mb-font-display);font-style:italic;font-size:20px;color:var(--mb-gold-light);max-width:24ch;line-height:1.3}
.footer-col{grid-column:span 2}
.footer-col:nth-of-type(2){grid-column:7/span 2}
.footer-col .ftitle{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-gold-light);font-weight:var(--mb-fw-semibold);margin-bottom:18px}
.footer-col ul{list-style:none;display:grid;gap:12px}
.footer-col a,.footer-col span{font-size:14px;color:var(--mb-fg-dark-muted);transition:color var(--mb-dur-hover)}
.footer-col a:hover{color:var(--mb-gold-light)}
.footer-cta{grid-column:11/span 2;display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.footer-cta .ftitle{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-gold-light);font-weight:var(--mb-fw-semibold)}
.footer-bottom{grid-column:1/span 12;display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;border-top:1px solid var(--mb-rule-dark);padding-top:24px;margin-top:var(--mb-space-5)}
.footer-bottom span{font-size:12px;color:var(--mb-fg-dark-subtle);letter-spacing:0.03em}

/* ============================================================ UTIL */
.note{font-size:12px;color:var(--mb-fg-dark-subtle);line-height:1.5}
.eyebrow-row{display:flex;align-items:center;gap:16px;margin-bottom:var(--mb-space-5)}
.eyebrow-row .gold-rule{width:48px}
.eyebrow-row span{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted)}

/* ============================================================ RESPONSIVE — collapse at 960px */
@media (max-width:960px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .hero-copy,.hero-media{grid-column:1/span 12}
  .hero-media{margin-top:var(--mb-space-6)}
  .hero-media .media-frame{aspect-ratio:16/11;max-height:520px}
  .opener-headline,.opener-lead{grid-column:1/span 12}
  .stat-eyebrow,.stat-figure,.stat-descriptor{grid-column:1/span 12}
  .block-head h2,.block-head .lead{grid-column:1/span 12}
  .tri-grid,.tri-grid.even,.feature-grid.two,.feature-grid.three{grid-template-columns:1fr}
  .narrative .ey,.narrative .prose,.ledger{grid-column:1/span 12}
  .ledger{margin-top:24px}
  .step{grid-template-columns:1fr;row-gap:16px}
  .step .step-num,.step .step-body{grid-column:1/span 1}
  .tip{grid-template-columns:1fr}
  .tip-left{border-right:0;border-bottom:1px solid var(--mb-rule-dark);padding:40px 32px}
  .tip-right{padding:40px 32px}
  .principle-block .ey,.principle-block .principle{grid-column:1/span 12}
  .cta-meta,.cta-action{grid-column:1/span 12}
  .sms-pair{grid-template-columns:1fr;gap:20px}
  .sms-pair .number-block{align-items:flex-start;justify-self:start}
  .tool-grid{grid-template-columns:1fr}
  .q-grid{grid-template-columns:1fr;gap:40px}
  .footer-brand,.footer-col,.footer-col:nth-of-type(2),.footer-cta{grid-column:1/span 12}
  .field-row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .tip-left,.tip-right{padding:32px 24px}
  .card{padding:28px 24px 32px}
  .nav-drawer a{font-size:28px}
}

/* ============================================================ LEAD GATE MODAL */
.lg-overlay{position:fixed;inset:0;z-index:9000;background:rgba(6,18,41,0.88);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity 300ms var(--mb-ease-in)}
.lg-overlay[hidden]{display:none!important}
.lg-overlay.lg-open{opacity:1}
.lg-modal{background:var(--mb-midnight);border:1px solid var(--mb-rule-dark-strong);max-width:580px;width:100%;max-height:90vh;overflow-y:auto;padding:48px;position:relative;border-radius:2px;transform:translateY(24px);transition:transform 350ms cubic-bezier(0.34,1.26,0.64,1);scrollbar-width:thin;scrollbar-color:var(--mb-rule-dark-strong) transparent}
.lg-overlay.lg-open .lg-modal{transform:none}
.lg-close{position:absolute;top:18px;right:18px;background:none;border:1px solid var(--mb-rule-dark);color:var(--mb-fg-dark-muted);font-size:16px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color 200ms var(--mb-ease-in),border-color 200ms var(--mb-ease-in),background 200ms var(--mb-ease-in);line-height:1}
.lg-close:hover{color:var(--mb-ivory);border-color:var(--mb-rule-dark-strong);background:rgba(255,255,255,0.06)}
.lg-close:focus-visible{outline:2px solid var(--mb-gold);outline-offset:2px}
.lg-eyebrow{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);font-weight:var(--mb-fw-semibold);letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-gold-light);margin-bottom:10px}
.lg-title{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(26px,3.5vw,38px);line-height:1.1;letter-spacing:-0.02em;color:var(--mb-ivory);margin:0 0 10px}
.lg-subtitle{font-size:var(--mb-fs-body);line-height:1.6;color:var(--mb-fg-dark-muted);margin:0 0 28px}
.lg-form{display:flex;flex-direction:column;gap:18px}
.lg-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.lg-field{display:flex;flex-direction:column;gap:7px}
.lg-field label,.lg-label-radio{font-family:var(--mb-font-body);font-size:13px;font-weight:var(--mb-fw-semibold);letter-spacing:0.03em;color:var(--mb-fg-dark-muted)}
.lg-field label span[aria-hidden],.lg-label-radio span[aria-hidden]{color:var(--mb-gold-light)}
.lg-field input[type="text"],.lg-field input[type="tel"],.lg-field input[type="email"]{background:rgba(255,255,255,0.04);border:1px solid var(--mb-rule-dark-strong);padding:13px 15px;font-family:var(--mb-font-body);font-size:var(--mb-fs-body);color:var(--mb-ivory);border-radius:var(--mb-radius-sm);transition:border-color 200ms var(--mb-ease-in),background 200ms var(--mb-ease-in)}
.lg-field input:focus{outline:none;border-color:var(--mb-gold);background:rgba(212,164,55,0.05)}
.lg-field input::placeholder{color:var(--mb-fg-dark-subtle)}
.lg-radios{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.lg-radio{display:flex;align-items:center;gap:12px;cursor:pointer;padding:11px 14px;border:1px solid var(--mb-rule-dark);border-radius:var(--mb-radius-sm);transition:border-color 200ms var(--mb-ease-in),background 200ms var(--mb-ease-in)}
.lg-radio:hover{border-color:var(--mb-rule-dark-strong);background:rgba(255,255,255,0.03)}
.lg-radio input[type="radio"]{-webkit-appearance:none;appearance:none;width:16px;height:16px;border:1.5px solid var(--mb-rule-dark-strong);border-radius:50%;flex:none;transition:border-color 200ms,background 200ms;position:relative;cursor:pointer}
.lg-radio input[type="radio"]::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);width:7px;height:7px;border-radius:50%;background:var(--mb-midnight-deep);transition:transform 150ms}
.lg-radio input[type="radio"]:checked{border-color:var(--mb-gold);background:var(--mb-gold)}
.lg-radio input[type="radio"]:checked::after{transform:translate(-50%,-50%) scale(1)}
.lg-radio:has(input:checked){border-color:rgba(212,164,55,0.4);background:rgba(212,164,55,0.06)}
.lg-radio span{font-size:var(--mb-fs-body);color:var(--mb-fg-dark);line-height:1.4}
.lg-submit{width:100%;justify-content:center;font-size:13px;padding:18px 32px;margin-top:6px;cursor:pointer}
.lg-submit:disabled{opacity:0.55;cursor:not-allowed;transform:none}
.lg-privacy{font-size:var(--mb-fs-caption);color:var(--mb-fg-dark-subtle);text-align:center;margin:0;font-style:italic;line-height:1.5}
.lg-success{display:none;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:16px 0}
.lg-success.lg-visible{display:flex}
.lg-success-icon{width:56px;height:56px;border-radius:50%;border:1.5px solid var(--mb-gold);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--mb-gold);background:rgba(212,164,55,0.08)}
@media(max-width:600px){.lg-modal{padding:32px 20px}.lg-row-2{grid-template-columns:1fr}}

/* ============================================================ GUIDE COMPONENTS
   Long-form relocation guides (cover, contents, companion cross-link,
   embedded school-tool link list, lifestyle + resource-hub grids).
   Shared by guides/naperville- and fox-valley-relocation-guide.html. */
.gcover{min-height:88vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:var(--mb-space-9);padding-bottom:var(--mb-space-9)}
.gcover .num-ghost{position:absolute;top:50%;right:-3vw;transform:translateY(-50%) translateY(var(--py,0px));font-family:var(--mb-font-numeral);font-style:italic;font-weight:var(--mb-fw-light);font-size:clamp(16rem,38vw,46rem);line-height:1;color:rgba(212,164,55,0.05);pointer-events:none;user-select:none;z-index:0}
.gcover .col-12{position:relative;z-index:1;width:100%;row-gap:var(--mb-space-6)}
.gcover .cover-meta{grid-column:1/span 12;display:flex;align-items:center;gap:18px;margin-bottom:var(--mb-space-5)}
.gcover .cover-meta span{font-family:var(--mb-font-body);font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-fg-dark-muted);font-weight:var(--mb-fw-semibold)}
.gcover h1{grid-column:1/span 11;font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(56px,9vw,144px);line-height:0.9;letter-spacing:-0.03em;color:var(--mb-ivory);margin:0}
.gcover h1 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.gcover .cover-sub{grid-column:1/span 8;margin-top:18px;font-family:var(--mb-font-display);font-style:italic;font-weight:var(--mb-fw-light);font-size:clamp(20px,2.6vw,30px);line-height:1.3;color:var(--mb-fg-dark-muted)}
.gcover .cover-foot{grid-column:1/span 12;margin-top:var(--mb-space-7);display:flex;flex-wrap:wrap;align-items:center;gap:clamp(20px,4vw,56px);border-top:1px solid var(--mb-rule-dark);padding-top:var(--mb-space-6)}
.gcover .cover-credit .nm{font-family:var(--mb-font-display);font-size:24px;color:var(--mb-ivory)}
.gcover .cover-credit .org{font-family:var(--mb-font-body);font-size:13px;letter-spacing:var(--mb-tr-eyebrow);text-transform:uppercase;color:var(--mb-fg-dark-muted);margin-top:6px}
.toc-list{list-style:none;counter-reset:tp;grid-column:4/span 9}
.toc-list li{counter-increment:tp;border-bottom:1px solid var(--mb-rule-dark)}
.toc-list li:first-child{border-top:1px solid var(--mb-rule-dark)}
.toc-list a{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:clamp(16px,3vw,40px);padding:18px 0;color:var(--mb-fg-dark);transition:padding var(--mb-dur-hover) var(--mb-ease-in)}
.toc-list a::before{content:counter(tp,decimal-leading-zero);font-family:var(--mb-font-numeral);font-style:italic;font-size:22px;color:var(--mb-gold);font-weight:var(--mb-fw-light);min-width:38px}
.toc-list .t{font-family:var(--mb-font-display);font-size:clamp(19px,2vw,26px);font-weight:var(--mb-fw-regular);letter-spacing:-0.01em;color:var(--mb-ivory)}
.toc-list .d{font-family:var(--mb-font-body);font-size:13px;color:var(--mb-fg-dark-muted);text-align:right;max-width:32ch;line-height:1.3}
.toc-list a:hover{padding-left:12px}
.toc-list a:hover .t{color:var(--mb-gold-light)}
.toc-page .ey{grid-column:1/span 3}
.toc-page .toc-headline{grid-column:4/span 9;margin-bottom:var(--mb-space-6)}
.toc-page .toc-headline h2{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(36px,5vw,64px);line-height:1.02;letter-spacing:-0.02em;color:var(--mb-ivory);margin:0}
.toc-page .toc-headline h2 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.companion{border:1px solid var(--mb-rule-dark);background:rgba(11,27,58,0.45);padding:clamp(28px,4vw,44px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;position:relative;overflow:hidden}
.companion::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--mb-grad-gold)}
.companion .ctext{max-width:64ch}
.companion .ck{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-gold-light);font-weight:var(--mb-fw-semibold);margin-bottom:10px}
.companion h3{font-family:var(--mb-font-display);font-weight:var(--mb-fw-light);font-size:clamp(26px,3.2vw,38px);line-height:1.1;color:var(--mb-ivory);margin:0 0 8px}
.companion h3 em{font-style:italic;background:var(--mb-grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.companion p{margin:0;color:var(--mb-fg-dark-muted);font-size:16px;line-height:1.6}
.sd-links{display:grid;gap:2px;margin-top:4px}
.sd-link{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:13px 0;border-bottom:1px solid var(--mb-rule-dark);text-decoration:none;transition:padding var(--mb-dur-hover) var(--mb-ease-in)}
.sd-link:last-child{border-bottom:0}
.sd-link:hover{padding-left:8px}
.sd-link .k{color:var(--mb-ivory);font-size:15px}
.sd-link .v{font-family:var(--mb-font-body);font-size:12px;letter-spacing:0.04em;color:var(--mb-gold-light);white-space:nowrap}
.sd-done .sd-check{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:9999px;background:var(--mb-grad-gold);color:var(--mb-midnight-deep);font-size:22px;margin-bottom:16px}
.sd-done h4{font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:28px;color:var(--mb-ivory);margin:0 0 10px}
.sd-done p{color:var(--mb-fg-dark-muted);font-size:15px;line-height:1.6;margin:0}
.life-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,4vw,52px)}
.life-group h4{font-family:var(--mb-font-display);font-weight:var(--mb-fw-regular);font-size:24px;color:var(--mb-ivory);margin:0 0 14px;display:flex;align-items:center;gap:12px}
.life-group ul{list-style:none}
.life-group li{padding:11px 0 11px 22px;position:relative;border-bottom:1px solid var(--mb-rule-dark);font-size:15px;line-height:1.5;color:var(--mb-fg-dark)}
.life-group li:last-child{border-bottom:0}
.life-group li::before{content:"";position:absolute;left:0;top:1.15em;width:8px;height:1px;background:var(--mb-grad-gold)}
.life-group li strong{color:var(--mb-ivory);font-weight:var(--mb-fw-semibold)}
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,48px)}
.hub-col .htitle{font-size:var(--mb-fs-eyebrow);text-transform:uppercase;letter-spacing:var(--mb-tr-eyebrow);color:var(--mb-gold-light);font-weight:var(--mb-fw-semibold);padding-bottom:12px;border-bottom:1px solid var(--mb-rule-dark);margin-bottom:4px}
.hub-col ul{list-style:none}
.hub-col li{border-bottom:1px solid var(--mb-rule-dark)}
.hub-col li:last-child{border-bottom:0}
.hub-col a{display:block;padding:11px 0;color:var(--mb-fg-dark);font-size:15px;text-decoration:none;transition:color var(--mb-dur-hover)}
.hub-col a:hover{color:var(--mb-gold-light)}
.hub-col a .sub{display:block;font-size:12px;color:var(--mb-fg-dark-subtle)}
@media(max-width:760px){
  .toc-list a{grid-template-columns:auto 1fr}.toc-list .d{display:none}
  .toc-page .ey,.toc-page .toc-headline,.toc-list{grid-column:1/span 12}
  .life-grid,.hub-grid{grid-template-columns:1fr}
}
