/* =============================================================
   Independent Brokerage Collective (BIC)
   Global stylesheet
   Palette: Gold #B0851A · Navy #15294E · Charcoal #2F2F2F
            Ivory #F7F5F0 · Light Gray #E7E7E7
   Type:    Headings — Editor's Note (serif)
            Body     — Jost (sans-serif)
   ============================================================= */

/* ---------- Editor's Note (heading typeface) ---------- */
@font-face{font-family:"Editors Note";src:url("../assets/fonts/EditorsNote-Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Editors Note";src:url("../assets/fonts/EditorsNote-Medium.otf") format("opentype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Editors Note";src:url("../assets/fonts/EditorsNote-Semibold.otf") format("opentype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Editors Note";src:url("../assets/fonts/EditorsNote-Italic.otf") format("opentype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Editors Note";src:url("../assets/fonts/EditorsNote-MediumItalic.otf") format("opentype");font-weight:500;font-style:italic;font-display:swap}

:root{
  --gold:#B0851A;
  --gold-dark:#8a6710;
  --gold-soft:#cda63f;
  --forest:#15294E;       /* navy (kept var name --forest for cascade) */
  --forest-dark:#0e1d3a;  /* deep navy */
  --charcoal:#2F2F2F;
  --ivory:#F7F5F0;
  --gray:#E7E7E7;
  --gray-mid:#9a9a93;
  --ink:#23262e;
  --white:#ffffff;

  --maxw:1180px;
  --gutter:clamp(20px,5vw,56px);
  --radius:14px;
  --shadow-sm:0 2px 10px rgba(47,47,47,.06);
  --shadow:0 18px 50px -22px rgba(47,47,47,.35);
  --shadow-lg:0 40px 90px -40px rgba(47,47,47,.45);
  --serif:"Editors Note",Georgia,"Times New Roman",serif;
  --sans:"Jost","Helvetica Neue",Arial,sans-serif;
  --t:.35s cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--white);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--forest);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;color:var(--charcoal);margin:0 0 .5em}
h1{font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:.005em}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
p{margin:0 0 1.1em}
ul{margin:0 0 1.1em;padding-left:1.2em}
li{margin:.25em 0}
strong{font-weight:500}

/* ---------- Accessibility helpers ---------- */
.skip-link{
  position:absolute;left:-999px;top:0;z-index:1000;
  background:var(--forest);color:#fff;padding:12px 20px;border-radius:0 0 8px 0;
  font-family:var(--sans);font-size:.95rem;
}
.skip-link:focus{left:0;color:#fff}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wrap--narrow{max-width:840px}
.section{padding:clamp(60px,9vw,120px) 0}
.section--tight{padding:clamp(46px,6vw,76px) 0}
.bg-ivory{background:var(--ivory)}
.bg-gray{background:var(--gray)}
.bg-forest{background:var(--forest);color:#e6ebf5}
.bg-forest h1,.bg-forest h2,.bg-forest h3{color:#fff}
.bg-charcoal{background:var(--charcoal);color:#e9e7e1}
.bg-charcoal h2,.bg-charcoal h3{color:#fff}
.center{text-align:center}
.lead{font-size:clamp(1.1rem,1.8vw,1.35rem);font-weight:300;line-height:1.7}
.eyebrow{
  font-family:var(--sans);font-weight:500;text-transform:uppercase;
  letter-spacing:.26em;font-size:.74rem;color:var(--gold);margin:0 0 1.1rem;
}
.bg-forest .eyebrow{color:var(--gold-soft)}
.measure{max-width:62ch}
.measure.center{margin-inline:auto}
.divider{width:64px;height:3px;background:var(--gold);border:0;margin:1.4rem 0}
.center .divider{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;cursor:pointer;
  font-family:var(--sans);font-weight:400;font-size:.86rem;
  letter-spacing:.13em;text-transform:uppercase;
  padding:1em 1.9em;border-radius:50px;border:1.5px solid transparent;
  transition:transform var(--t),background var(--t),color var(--t),border-color var(--t),box-shadow var(--t);
  line-height:1;text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn--gold{background:var(--gold);color:#fff;box-shadow:0 12px 26px -12px rgba(176,138,0,.7)}
.btn--gold:hover{background:var(--gold-dark);color:#fff}
.btn--forest{background:var(--forest);color:#fff}
.btn--forest:hover{background:var(--forest-dark);color:#fff}
.btn--outline{border-color:var(--charcoal);color:var(--charcoal);background:transparent}
.btn--outline:hover{background:var(--charcoal);color:#fff}
.btn--light{border-color:rgba(255,255,255,.8);color:#fff;background:transparent}
.btn--light:hover{background:#fff;color:var(--forest)}
.btn--solid-light{background:#fff;color:var(--forest)}
.btn--solid-light:hover{background:var(--ivory);color:var(--forest)}
.btn-row{display:flex;flex-wrap:wrap;gap:16px}
.center .btn-row{justify-content:center}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--gray);
}
.header-inner{
  max-width:var(--maxw);margin-inline:auto;padding:.6rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:58px;width:auto}
.nav{display:flex;align-items:center;gap:clamp(10px,1.6vw,24px)}
.nav a{
  font-family:var(--sans);font-weight:400;color:var(--charcoal);
  font-size:.82rem;letter-spacing:.04em;position:relative;padding:.3em 0;
}
.nav a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;
  background:var(--gold);transition:width var(--t);
}
.nav a:not(.btn):hover,.nav a[aria-current="page"]{color:var(--gold)}
.nav a:not(.btn):hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav .btn{padding:.7em 1.3em;font-size:.74rem}
.nav-toggle{
  display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;
  padding:8px;
}
.nav-toggle span{width:26px;height:2px;background:var(--charcoal);transition:var(--t)}

@media (max-width:1020px){
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(86vw,360px);
    background:var(--ivory);flex-direction:column;align-items:flex-start;
    justify-content:flex-start;gap:6px;padding:96px 32px 40px;
    transform:translateX(100%);transition:transform var(--t);
    box-shadow:var(--shadow-lg);overflow-y:auto;
  }
  .nav[data-open]{transform:translateX(0)}
  .nav a{font-size:1.05rem;width:100%;padding:.5em 0;border-bottom:1px solid var(--gray)}
  .nav a:not(.btn)::after{display:none}
  .nav .btn{margin-top:14px;width:100%;justify-content:center;border-bottom:0;font-size:.8rem}
  body.nav-open{overflow:hidden}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--forest);color:#fff;isolation:isolate}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 700px at 78% -10%,rgba(176,133,26,.42),transparent 60%),
    linear-gradient(160deg,#1d3460 0%,#15294e 55%,#0c1a36 100%);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;opacity:.10;
  background-image:radial-gradient(rgba(255,255,255,.7) 1px,transparent 1px);
  background-size:30px 30px;
}
.hero-inner{padding:clamp(72px,11vw,140px) 0 clamp(64px,10vw,128px);max-width:880px}
.hero--centered .hero-inner{max-width:920px;margin-inline:auto;text-align:center}
.hero .eyebrow{color:var(--gold-soft)}
.hero h1{color:#fff;margin-bottom:.2em}
.hero .tagline{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(1.3rem,2.6vw,1.9rem);color:var(--gold-soft);margin:0 0 1.1rem;
}
.hero p.lead{color:#e6ebf5;max-width:60ch}
.hero--centered p.lead{margin-inline:auto}
.hero .btn-row{margin-top:2rem}
.hero--centered .btn-row{justify-content:center}
/* Large IBC logo emblem in hero (logo art is transparent, so a light panel keeps it legible) */
.hero-logo{margin:0 0 1.4rem;line-height:0;display:flex;justify-content:center}
.hero-logo img{
  width:min(440px,82vw);height:auto;background:#fff;border-radius:18px;
  padding:26px 38px;box-shadow:0 30px 70px -30px rgba(0,0,0,.55);
}

.page-hero{position:relative;background:var(--forest);color:#fff;isolation:isolate;text-align:center}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:linear-gradient(160deg,#1d3460 0%,#15294e 60%,#0c1a36 100%);
}
.page-hero::after{
  content:"";position:absolute;inset:0;z-index:-1;opacity:.08;
  background-image:radial-gradient(rgba(255,255,255,.8) 1px,transparent 1px);
  background-size:28px 28px;
}
.page-hero-inner{padding:clamp(64px,10vw,120px) 0 clamp(54px,8vw,96px)}
.page-hero h1{color:#fff}
.page-hero .eyebrow{color:var(--gold-soft)}
.page-hero p{color:#dde3f0;max-width:60ch;margin-inline:auto}

/* ---------- Generic grids ---------- */
.grid{display:grid;gap:clamp(20px,3vw,34px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center}
@media (max-width:840px){.split{grid-template-columns:1fr}}

/* ---------- Cards ---------- */
.card{
  background:#fff;border:1px solid var(--gray);border-radius:var(--radius);
  padding:clamp(24px,3vw,38px);box-shadow:var(--shadow-sm);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  height:100%;
  color:var(--charcoal); /* keep card text dark even inside dark-bg sections */
}
.card p{color:var(--charcoal)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#dcdcd2}
.card h3{margin-bottom:.4em;color:var(--charcoal)} /* stay dark even inside dark-bg sections */
.card p:last-child{margin-bottom:0}

/* Icon feature card */
.feature{text-align:left}
.feature .ico{
  width:54px;height:54px;border-radius:12px;display:grid;place-items:center;
  background:var(--ivory);border:1px solid var(--gray);margin-bottom:18px;color:var(--forest);
}
.feature .ico svg{width:26px;height:26px}
.feature h3{font-size:1.35rem}

/* Brokerage card */
.brokerage-card{display:flex;flex-direction:column;text-align:center;align-items:center}
.logo-slot{
  width:100%;height:150px;border-radius:10px;background:var(--ivory);
  border:1px solid var(--gray);display:grid;place-items:center;padding:22px;margin-bottom:22px;
}
.logo-slot img{max-height:106px;width:auto;object-fit:contain}
.logo-fallback{
  font-family:var(--serif);font-size:1.5rem;color:var(--charcoal);font-weight:500;
  letter-spacing:.02em;line-height:1.2;
}
.logo-fallback span{display:block;font-family:var(--sans);font-size:.66rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:6px;font-weight:500}
.brokerage-card .website-link{
  margin-top:auto;font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);font-weight:500;padding-top:16px;
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,30px)}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center;padding:18px 8px}
.stat b{
  display:block;font-family:var(--serif);font-weight:500;
  font-size:clamp(2.6rem,6vw,4rem);line-height:1;color:var(--gold);
}
.bg-forest .stat b{color:var(--gold-soft)}
.stat span{
  display:block;margin-top:.6rem;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:inherit;opacity:.85;
}

/* ---------- Quote ---------- */
.quote{max-width:880px;margin-inline:auto;text-align:center}
.quote blockquote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(1.6rem,3.4vw,2.5rem);line-height:1.35;margin:0 0 1.2rem;color:#fff;
}
.quote .mark{font-family:var(--serif);font-size:4rem;color:var(--gold-soft);line-height:.4;display:block;margin-bottom:.2em}
.quote cite{font-style:normal;font-family:var(--sans);letter-spacing:.16em;
  text-transform:uppercase;font-size:.82rem;color:var(--gold-soft)}

/* ---------- Sponsor tiers ---------- */
.tier{position:relative;display:flex;flex-direction:column}
.tier--featured{border-color:var(--gold);box-shadow:var(--shadow)}
.tier .tier-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:#fff;font-family:var(--sans);font-size:.66rem;
  letter-spacing:.18em;text-transform:uppercase;padding:.5em 1.1em;border-radius:50px;font-weight:500;
}
.tier .tier-name{font-family:var(--sans);font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;font-size:.84rem;color:var(--gold);margin-bottom:.4rem}
.tier .tier-price{font-family:var(--serif);font-size:2.6rem;color:var(--charcoal);line-height:1;margin-bottom:.2rem}
.tier .tier-price small{font-size:.9rem;color:var(--gray-mid);font-family:var(--sans);letter-spacing:.08em}
.tier ul.checks{list-style:none;padding:0;margin:1.4rem 0 0}
.tier ul.checks li{position:relative;padding-left:1.9em;margin:.7em 0;font-size:.98rem}
.tier ul.checks li::before{
  content:"";position:absolute;left:0;top:.45em;width:14px;height:8px;
  border-left:2px solid var(--gold);border-bottom:2px solid var(--gold);
  transform:rotate(-45deg);
}

/* ---------- Benefit / check list ---------- */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{position:relative;padding-left:2em;margin:.8em 0}
.checklist li::before{
  content:"";position:absolute;left:0;top:.35em;width:16px;height:9px;
  border-left:2.5px solid var(--gold);border-bottom:2.5px solid var(--gold);transform:rotate(-45deg);
}
.checklist--forest li::before{border-color:var(--gold-soft)}

/* ---------- Events ---------- */
.event{
  display:grid;grid-template-columns:96px 1fr;gap:24px;align-items:center;
  background:#fff;border:1px solid var(--gray);border-radius:var(--radius);
  padding:22px 26px;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t);
}
.event:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.event .date{
  text-align:center;background:var(--forest);color:#fff;border-radius:10px;padding:12px 6px;
}
.event .date .m{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.event .date .d{display:block;font-family:var(--serif);font-size:2.1rem;line-height:1.05}
.event h3{font-size:1.3rem;margin:0 0 .2em}
.event .meta{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin:0 0 .4em}
.event p{margin:0;font-size:.97rem}
.event-tag{display:inline-block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--forest);background:var(--ivory);border:1px solid var(--gray);padding:.3em .8em;border-radius:50px;margin-top:.5em}

/* ---------- Board cards ---------- */
.board-card{text-align:center}
.board-card .photo{
  width:150px;height:150px;border-radius:50%;margin:0 auto 20px;overflow:hidden;
  background:var(--ivory);border:1px solid var(--gray);display:grid;place-items:center;
}
.board-card .photo img{width:100%;height:100%;object-fit:cover}
.board-card .photo .initials{font-family:var(--serif);font-size:2.6rem;color:var(--gold);font-weight:500}
.board-card .role{font-family:var(--sans);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 .3rem}
.board-card h3{font-size:1.5rem;margin:0 0 .15rem}
.board-card .org{font-size:.95rem;color:var(--gray-mid);margin:0}
.board-card--soon .photo{border-style:dashed;background:transparent}
.board-card--soon .photo .initials{color:var(--gray-mid)}

/* ---------- Forms ---------- */
.form{background:#fff;border:1px solid var(--gray);border-radius:var(--radius);
  padding:clamp(26px,4vw,46px);box-shadow:var(--shadow-sm)}
.bg-ivory .form,.bg-gray .form{box-shadow:var(--shadow)}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--sans);font-weight:500;font-size:.8rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);margin-bottom:.5em}
.field .req{color:var(--gold)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:1rem;font-weight:300;color:var(--ink);
  padding:.85em 1em;border:1.5px solid var(--gray);border-radius:10px;background:#fff;
  transition:border-color var(--t),box-shadow var(--t);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,138,0,.15)}
.field textarea{min-height:130px;resize:vertical}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 22px}
@media (max-width:620px){.form-grid{grid-template-columns:1fr}}
.form-grid .span-2{grid-column:1/-1}
.form-note{font-size:.8rem;color:var(--gray-mid);margin-top:1rem}
.form-success{
  display:none;background:var(--forest);color:#fff;border-radius:10px;padding:16px 20px;margin-bottom:18px;
  font-size:.95rem;
}
.form-success.show{display:block}

/* ---------- Search / directory ---------- */
.search-bar{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px}
.search-bar input,.search-bar select{
  flex:1 1 200px;font-family:var(--sans);font-size:1rem;padding:.8em 1em;
  border:1.5px solid var(--gray);border-radius:10px;background:#fff;
}
.search-bar input:focus,.search-bar select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,138,0,.15)}
.dir-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--gray);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.dir-table th,.dir-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--gray);font-size:.96rem}
.dir-table th{font-family:var(--sans);font-weight:500;font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;color:#fff;background:var(--forest)}
.dir-table tr:last-child td{border-bottom:0}
.dir-table tbody tr{transition:background var(--t)}
.dir-table tbody tr:hover{background:var(--ivory)}
.dir-table td .bn{font-family:var(--serif);font-size:1.2rem;color:var(--charcoal);display:block}
.no-results{text-align:center;padding:40px;color:var(--gray-mid);display:none}
@media (max-width:720px){
  .dir-table thead{display:none}
  .dir-table,.dir-table tbody,.dir-table tr,.dir-table td{display:block;width:100%}
  .dir-table tr{border-bottom:1px solid var(--gray);padding:8px 0}
  .dir-table td{border:0;padding:6px 20px}
  .dir-table td::before{content:attr(data-label);display:block;font-size:.68rem;letter-spacing:.12em;
    text-transform:uppercase;color:var(--gold);font-weight:500}
}

/* ---------- FAQ accordion ---------- */
.faq-item{border-bottom:1px solid var(--gray)}
.faq-q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:1.3em 3em 1.3em 0;position:relative;font-family:var(--serif);
  font-size:clamp(1.2rem,2.2vw,1.5rem);color:var(--charcoal);line-height:1.25;
}
.faq-q::after{content:"+";position:absolute;right:.2em;top:50%;transform:translateY(-50%);
  font-family:var(--sans);font-weight:300;font-size:1.8rem;color:var(--gold);transition:transform var(--t)}
.faq-q[aria-expanded="true"]::after{content:"–"}
.faq-q:hover{color:var(--gold)}
.faq-a{max-height:0;overflow:hidden;transition:max-height var(--t)}
.faq-a div{padding:0 0 1.5em}
.faq-a p:last-child{margin-bottom:0}

/* ---------- Partner highlight ---------- */
.partner-spotlight{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:840px){.partner-spotlight{grid-template-columns:1fr;text-align:center}}
.partner-logo{background:#fff;border:1px solid var(--gray);border-radius:var(--radius);
  padding:clamp(28px,5vw,52px);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.partner-logo img{max-height:200px}

/* ---------- Coming soon panel ---------- */
.soon-panel{
  border:2px dashed var(--gold);border-radius:var(--radius);background:var(--ivory);
  padding:clamp(34px,5vw,60px);text-align:center;
}
.soon-badge{display:inline-block;font-family:var(--sans);font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;font-size:.74rem;color:#fff;background:var(--gold);
  padding:.5em 1.3em;border-radius:50px;margin-bottom:1.2rem}
.soon-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:1.6rem;list-style:none;padding:0}
.soon-list li{background:#fff;border:1px solid var(--gray);border-radius:50px;
  padding:.6em 1.3em;font-size:.88rem;color:var(--charcoal)}

/* ---------- Resource list ---------- */
.res-card{display:flex;gap:20px;align-items:flex-start}
.res-card .ico{flex:0 0 auto;width:48px;height:48px;border-radius:10px;display:grid;place-items:center;
  background:var(--ivory);border:1px solid var(--gray);color:var(--forest)}
.res-card .ico svg{width:24px;height:24px}
.res-card h3{font-size:1.3rem;margin-bottom:.2em}
.res-card p{font-size:.95rem;margin-bottom:.5em}
.res-card .tag{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:500}

/* ---------- CTA banner ---------- */
.cta-banner{background:linear-gradient(135deg,#1d3460,#0e1d3a);color:#fff;border-radius:var(--radius);
  padding:clamp(40px,6vw,72px);text-align:center;position:relative;overflow:hidden;isolation:isolate}
.cta-banner::after{content:"";position:absolute;inset:0;z-index:-1;opacity:.12;
  background-image:radial-gradient(rgba(255,255,255,.8) 1px,transparent 1px);background-size:26px 26px}
.cta-banner h2{color:#fff}
.cta-banner p{color:#dde3f0;max-width:56ch;margin-inline:auto}

/* ---------- Newsletter ---------- */
.newsletter-form{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:14px;align-items:end;max-width:980px;margin:0 auto}
@media (max-width:820px){.newsletter-form{grid-template-columns:1fr;text-align:left}}
.newsletter-form .field{margin-bottom:0}
.newsletter-form input{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4);color:#fff}
.newsletter-form input::placeholder{color:rgba(255,255,255,.7)}
.newsletter-form label{color:#fff}
.newsletter-form .btn{height:fit-content}

/* ---------- Footer ---------- */
.site-footer{background:var(--charcoal);color:#cfcdc6;font-size:.95rem}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(30px,5vw,60px);
  padding:clamp(50px,7vw,84px) 0 clamp(36px,4vw,52px)}
@media (max-width:820px){.footer-top{grid-template-columns:1fr;gap:36px}}
.footer-brand img{height:70px;background:#fff;border-radius:10px;padding:8px 12px;margin-bottom:18px}
.footer-brand p{max-width:38ch;color:#b9b7b0}
.footer-brand .tag{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:1.1rem}
.footer h4{font-family:var(--sans);font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  font-size:.78rem;color:#fff;margin:0 0 1.2em}
.footer ul{list-style:none;padding:0;margin:0}
.footer ul li{margin:.55em 0}
.footer a{color:#cfcdc6}
.footer a:hover{color:var(--gold-soft)}
.footer .contact-line{display:block;margin:.4em 0;color:#cfcdc6;word-break:break-word}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:40px;height:40px;border:1px solid rgba(255,255,255,.25);border-radius:50%;
  display:grid;place-items:center;color:#cfcdc6;transition:var(--t)}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-2px)}
.socials svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:24px 0;text-align:center}
.footer-bottom .standards-note{font-size:.82rem;color:#9a988f;max-width:80ch;margin:0 auto 10px}
.footer-bottom .copy{font-size:.82rem;color:#86847c;margin:0}
.footer-bottom a{color:#b9b7b0;text-decoration:underline;text-underline-offset:2px}

/* ---------- Misc ---------- */
.pill{display:inline-block;font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);background:var(--ivory);border:1px solid var(--gray);
  padding:.45em 1.1em;border-radius:50px;font-weight:500}
.alt-link{font-family:var(--sans);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.note-box{background:var(--ivory);border-left:4px solid var(--gold);border-radius:0 10px 10px 0;padding:22px 26px}
.bg-forest .note-box{background:rgba(255,255,255,.07);border-left-color:var(--gold-soft);color:#e6ebf5}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}
