/* =========================================================================
   Houston Media Source — Global Community Media Ecosystem
   Shared design system: dark navy/black foundation, gold accents, cream/white.
   Cinematic, premium, community-centered. Mobile-first.
   ========================================================================= */

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
a{text-decoration:none;color:inherit}
:focus-visible{outline:2px solid var(--gold-lit);outline-offset:3px;border-radius:4px}

/* ===== TOKENS ===== */
:root{
  --ink:#060d18;            /* deep navy-black */
  --navy:#0a1627;
  --navy-2:#0d1e33;
  --navy-3:#112743;
  --gold:#c69a3e;
  --gold-lit:#e0bb6b;
  --gold-bright:#f3d488;
  --gold-soft:rgba(224,187,107,.14);
  --cream:#f4eede;
  --white:#ffffff;
  --text:#dde6f1;          /* soft white */
  --sub:#9fb1c6;           /* muted blue-grey */
  --muted:#74879e;
  --line:rgba(224,187,107,.20);
  --line-cool:rgba(150,180,215,.14);
  --shadow:0 34px 90px -40px rgba(0,0,0,.85);
  --shadow-gold:0 20px 50px -22px rgba(224,187,107,.5);
  --maxw:1220px;
  --space:clamp(68px,9vw,138px);
  --radius:16px;
}

body{
  background:var(--ink);
  color:var(--text);
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* atmospheric navy backdrop */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1100px 720px at 80% -6%,rgba(20,52,92,.55),transparent 60%),
    radial-gradient(820px 560px at 4% 6%,rgba(224,187,107,.07),transparent 55%),
    linear-gradient(180deg,var(--ink),var(--navy) 52%,var(--ink));
}

/* ===== TYPOGRAPHY ===== */
.display{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.02;letter-spacing:-.01em}
.kicker{font-family:'Archivo',sans-serif;font-weight:700;letter-spacing:.32em;text-transform:uppercase;font-size:.72rem;color:var(--gold-lit);display:inline-block}
.kicker::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);vertical-align:middle;margin-right:12px;margin-bottom:3px}
em{font-style:italic;color:var(--gold-lit)}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;color:var(--white);line-height:1.08;letter-spacing:-.01em}
p{color:var(--text)}
.lead{font-size:clamp(1.06rem,1.7vw,1.28rem);color:var(--sub);line-height:1.7}

/* ===== LAYOUT ===== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,52px)}
.wrap-narrow{max-width:840px;margin:0 auto;padding:0 clamp(20px,5vw,52px)}
section{position:relative}
.section{padding:var(--space) 0}
.section-tight{padding:clamp(48px,6vw,84px) 0}

/* Cream interruption band */
.band-cream{background:linear-gradient(180deg,#f6f1e4,#efe7d3);color:#23303f}
.band-cream h1,.band-cream h2,.band-cream h3{color:#16212e}
.band-cream p{color:#3a4a5c}
.band-cream .kicker{color:#9a7a23}
.band-cream .kicker::before{background:#bb8f2f}

/* Skip link */
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--gold);color:#1a1206;padding:12px 18px;border-radius:0 0 10px 0;font-family:'Archivo';font-weight:700}
.skip:focus{left:0}

/* ===== TOP BAR ===== */
.topbar{background:linear-gradient(90deg,var(--navy-2),var(--navy-3) 50%,var(--navy-2));border-bottom:1px solid var(--line);color:var(--sub);font-family:'Archivo';font-weight:600;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;text-align:center;padding:9px 16px}
.topbar b{color:var(--gold-bright);font-weight:700}

/* ===== NAVBAR ===== */
.nav{position:sticky;top:0;z-index:60;background:rgba(6,13,24,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line-cool)}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0}
.brand{display:flex;align-items:center;gap:13px}
.brand-mark{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#1a1206;font-family:'Fraunces';font-weight:700;font-size:1.34rem;box-shadow:var(--shadow-gold)}
.brand-txt b{display:block;font-family:'Archivo';font-weight:800;letter-spacing:.02em;font-size:.92rem;color:var(--white);line-height:1.04}
.brand-txt small{display:block;font-family:'Archivo';font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.54rem;color:var(--gold-lit);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-family:'Archivo';font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.74rem;color:var(--sub);transition:color .2s;white-space:nowrap}
.nav-links a:hover{color:var(--white)}
.nav-links a[aria-current="page"]{color:var(--gold-lit)}
.nav-cta{padding:10px 18px!important;font-size:.74rem!important}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:10px;width:46px;height:42px;padding:0;place-items:center;color:var(--white)}
.nav-toggle svg{width:22px;height:22px}

/* responsive nav: collapse to drawer */
@media(max-width:1080px){
  .nav-toggle{display:grid}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(82vw,360px);
    flex-direction:column;align-items:flex-start;gap:4px;
    background:var(--navy);border-left:1px solid var(--line);
    padding:88px 28px 40px;transform:translateX(100%);transition:transform .32s ease;
    overflow-y:auto;box-shadow:var(--shadow);z-index:55;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:.92rem;padding:11px 0;width:100%;border-bottom:1px solid var(--line-cool)}
  .nav-links .nav-cta{margin-top:16px;border-bottom:none!important;width:100%}
  .nav-backdrop{position:fixed;inset:0;background:rgba(3,7,14,.6);backdrop-filter:blur(2px);z-index:54;opacity:0;visibility:hidden;transition:opacity .3s}
  .nav-backdrop.open{opacity:1;visibility:visible}
}

/* ===== BUTTONS (CTAButton) ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:'Archivo',sans-serif;font-weight:700;font-size:.92rem;letter-spacing:.04em;text-transform:uppercase;padding:15px 28px;border-radius:11px;border:1px solid transparent;transition:transform .2s,box-shadow .2s,background .2s,color .2s,border-color .2s;text-align:center;line-height:1}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-gold{background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#1a1206;box-shadow:0 16px 40px -18px rgba(224,187,107,.7)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 24px 54px -18px rgba(224,187,107,.85)}
.btn-ghost{background:transparent;color:var(--white);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--gold-lit);color:var(--gold-lit);transform:translateY(-3px)}
.btn-outline{background:rgba(255,255,255,.03);color:var(--white);border-color:var(--line-cool)}
.btn-outline:hover{border-color:var(--gold-lit);color:var(--gold-lit)}
.btn-lg{padding:18px 36px;font-size:1.02rem}
.band-cream .btn-ghost{color:#1a2330;border-color:rgba(40,30,10,.25)}
.band-cream .btn-ghost:hover{border-color:#9a7a23;color:#7a5f15}

/* Cream-band contrast fixes for components that default to light text */
.band-cream .lead,.band-cream .sub,.band-cream .section-head p,.band-cream .feature-list li,.band-cream .impact-note{color:#3a4a5c}
.band-cream .card,.band-cream .tile,.band-cream .pcard,.band-cream .scard,.band-cream .quote{background:linear-gradient(165deg,rgba(255,255,255,.78),rgba(255,255,255,.5));border-color:rgba(40,30,10,.14)}
.band-cream .card h3,.band-cream .tile h3,.band-cream .pcard-body h3,.band-cream .scard .price,.band-cream .quote blockquote{color:#16212e}
.band-cream .card p,.band-cream .tile p,.band-cream .pcard-body p,.band-cream .scard .desc{color:#3a4a5c}
.band-cream .pcard-body .tag,.band-cream .scard .tier,.band-cream .stat-row .st b,.band-cream .impact-num{color:#9a7a23}
.band-cream .stat-row .st span{color:#5a6b7d}
.band-cream .tile .ic,.band-cream .card .ic{background:rgba(187,143,47,.12);border-color:rgba(187,143,47,.3)}
.band-cream .feature-list li svg,.band-cream .scard li svg,.band-cream .tile .ic svg{stroke:#9a7a23}
.band-cream .scard li{color:#2a3a4a}

/* ===== SECTION HEADER ===== */
.section-head{max-width:680px;margin-bottom:clamp(34px,5vw,58px)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,4.6vw,3.4rem);margin-top:16px}
.section-head p{margin-top:18px;font-size:clamp(1.02rem,1.6vw,1.18rem);color:var(--sub)}
.rule{height:1px;background:linear-gradient(90deg,var(--gold),transparent);border:none;margin:0}

/* ===== HERO ===== */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:center;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-1}
.hero-media img{width:100%;height:100%;object-fit:cover;animation:slowzoom 22s ease-out forwards}
.hero-media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(6,13,24,.62),rgba(6,13,24,.55) 40%,rgba(6,13,24,.92)),
  linear-gradient(95deg,rgba(6,13,24,.85),rgba(6,13,24,.15) 70%)}
.hero-inner{padding:clamp(60px,10vh,120px) 0;max-width:760px}
.hero h1{font-size:clamp(2.5rem,6.4vw,5rem);color:var(--white);line-height:1.02}
.hero h1 .gold{color:var(--gold-bright)}
.hero .sub{margin-top:24px;font-size:clamp(1.06rem,1.9vw,1.32rem);color:var(--text);max-width:620px;line-height:1.7}
.hero-actions{margin-top:36px;display:flex;flex-wrap:wrap;gap:14px}
.hero-tag{font-family:'Archivo';font-weight:700;letter-spacing:.28em;text-transform:uppercase;font-size:.72rem;color:var(--gold-lit);margin-bottom:22px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}

/* secondary / page hero (no full-bleed photo) */
.page-hero{padding:clamp(72px,12vh,150px) 0 clamp(40px,6vw,72px);position:relative}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.4rem);margin-top:18px}
.page-hero p{margin-top:22px;max-width:660px;font-size:clamp(1.04rem,1.7vw,1.24rem);color:var(--sub)}
.page-hero .hero-actions{margin-top:32px}

@keyframes slowzoom{from{transform:scale(1.08)}to{transform:scale(1)}}
@media(prefers-reduced-motion:reduce){.hero-media img{animation:none}}

/* ===== CARD GRID + ICON CARDS ===== */
.grid{display:grid;gap:clamp(16px,2vw,24px)}
.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:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:linear-gradient(165deg,rgba(255,255,255,.045),rgba(255,255,255,.01));border:1px solid var(--line-cool);border-radius:var(--radius);padding:clamp(22px,2.6vw,32px);transition:transform .25s,border-color .25s,box-shadow .25s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:var(--shadow)}
.card h3{font-size:1.32rem;margin-bottom:10px}
.card p{color:var(--sub);font-size:.98rem}

/* icon card (ecosystem strip) */
.icard{text-align:left}
.icard .ic{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;background:var(--gold-soft);border:1px solid var(--line);margin-bottom:18px}
.icard .ic svg{width:26px;height:26px;stroke:var(--gold-lit);fill:none;stroke-width:1.6}
.icard h3{font-size:1.12rem;margin-bottom:6px}
.icard p{font-size:.9rem;color:var(--sub)}

/* ===== IMPACT COUNTERS ===== */
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-cool);border:1px solid var(--line-cool);border-radius:var(--radius);overflow:hidden}
@media(max-width:720px){.impact-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.impact-grid{grid-template-columns:1fr}}
.impact-cell{background:var(--navy);padding:clamp(28px,3.4vw,40px) clamp(20px,2.4vw,30px);text-align:center}
.impact-num{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(2.4rem,5.2vw,3.6rem);color:var(--gold-bright);line-height:1;letter-spacing:-.02em}
.impact-num .suffix{color:var(--gold)}
.impact-label{margin-top:12px;font-family:'Archivo';font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.78rem;color:var(--sub)}
.impact-note{margin-top:22px;text-align:center;font-size:.86rem;color:var(--muted);font-style:italic}

/* ===== MESSAGE COLUMNS (Why HMS) ===== */
.msg-cols{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(18px,2vw,28px);counter-reset:msg}
@media(max-width:980px){.msg-cols{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.msg-cols{grid-template-columns:1fr}}
.msg-col{padding-top:24px;border-top:2px solid rgba(155,123,40,.4)}
.msg-col::before{counter-increment:msg;content:"0" counter(msg);font-family:'Fraunces';font-weight:600;font-size:1.1rem;color:#bb8f2f;display:block;margin-bottom:14px}
.msg-col p{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(1.08rem,1.5vw,1.22rem);line-height:1.4;color:#21303f}

/* ===== SPLIT (text + image) ===== */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
.split.reverse .split-media{order:-1}
@media(max-width:860px){.split{grid-template-columns:1fr}.split.reverse .split-media{order:0}}
.split-media{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .9s ease}
.split-media:hover img{transform:scale(1.04)}
.split-body h2{font-size:clamp(1.8rem,3.8vw,2.9rem)}
.split-body p{margin-top:18px;color:var(--sub);font-size:1.08rem}
.split-body .btn{margin-top:28px}

/* ===== IMAGE GALLERY ===== */
.gallery{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 18px;-webkit-overflow-scrolling:touch}
.gallery::-webkit-scrollbar{height:8px}
.gallery::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.gallery figure{position:relative;flex:0 0 clamp(260px,32vw,380px);scroll-snap-align:start;border-radius:14px;overflow:hidden;border:1px solid var(--line-cool)}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .8s ease}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:24px 16px 12px;background:linear-gradient(transparent,rgba(6,13,24,.9));font-family:'Archivo';font-weight:600;font-size:.78rem;letter-spacing:.04em;color:var(--cream);text-transform:uppercase}

/* ===== VIDEO BLOCK ===== */
.video-block{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;display:grid;place-items:center;background:linear-gradient(160deg,var(--navy-2),var(--ink))}
.video-block img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.video-play{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:18px;color:var(--white)}
.video-play .pbtn{width:84px;height:84px;border-radius:50%;background:rgba(224,187,107,.16);border:1.5px solid var(--gold-lit);display:grid;place-items:center;transition:transform .25s,background .25s}
.video-block:hover .pbtn{transform:scale(1.08);background:rgba(224,187,107,.28)}
.video-play .pbtn svg{width:30px;height:30px;fill:var(--gold-bright);margin-left:5px}
.video-play span{font-family:'Archivo';font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;color:var(--cream)}

/* ===== PROGRAM CARD ===== */
.pcard{display:flex;flex-direction:column;background:linear-gradient(165deg,rgba(255,255,255,.04),rgba(255,255,255,.008));border:1px solid var(--line-cool);border-radius:var(--radius);overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s}
.pcard:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:var(--shadow)}
.pcard-media{aspect-ratio:16/10;overflow:hidden}
.pcard-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.pcard:hover .pcard-media img{transform:scale(1.06)}
.pcard-body{padding:24px 24px 28px}
.pcard-body .tag{font-family:'Archivo';font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.66rem;color:var(--gold-lit)}
.pcard-body h3{font-size:1.3rem;margin:10px 0 8px}
.pcard-body p{color:var(--sub);font-size:.95rem}

/* ===== SPONSOR CARD (pricing packages) ===== */
.scard{display:flex;flex-direction:column;background:linear-gradient(170deg,rgba(255,255,255,.05),rgba(255,255,255,.012));border:1px solid var(--line-cool);border-radius:var(--radius);padding:30px 26px 34px;transition:transform .25s,border-color .25s,box-shadow .25s}
.scard:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:var(--shadow)}
.scard.featured{border-color:var(--gold);box-shadow:var(--shadow-gold)}
.scard .tier{font-family:'Archivo';font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.7rem;color:var(--gold-lit)}
.scard .price{font-family:'Fraunces';font-weight:600;font-size:2.2rem;color:var(--white);margin:14px 0 4px;line-height:1}
.scard .price small{font-family:'Archivo';font-size:.8rem;font-weight:600;color:var(--muted);letter-spacing:.04em}
.scard .desc{color:var(--sub);font-size:.95rem;margin-bottom:18px}
.scard ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:26px;flex:1}
.scard li{display:flex;gap:11px;font-size:.94rem;color:var(--text);align-items:flex-start;line-height:1.45}
.scard li svg{width:18px;height:18px;flex-shrink:0;margin-top:2px;stroke:var(--gold-lit);fill:none;stroke-width:2}
.scard .btn{width:100%}
.badge-pop{align-self:flex-start;font-family:'Archivo';font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.62rem;color:#1a1206;background:linear-gradient(135deg,var(--gold-bright),var(--gold));padding:5px 12px;border-radius:99px;margin-bottom:14px}

/* ===== TESTIMONIAL ===== */
.quote{background:linear-gradient(165deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border:1px solid var(--line-cool);border-left:3px solid var(--gold);border-radius:14px;padding:30px 28px}
.quote blockquote{font-family:'Fraunces',serif;font-weight:500;font-style:italic;font-size:1.16rem;line-height:1.5;color:var(--text)}
.quote .who{margin-top:18px;font-family:'Archivo';font-weight:700;letter-spacing:.04em;font-size:.86rem;color:var(--gold-lit)}
.quote .who span{display:block;font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--muted);margin-top:3px}

/* ===== LIST FEATURE (checkmark lists) ===== */
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px;margin-top:8px}
@media(max-width:600px){.feature-list{grid-template-columns:1fr}}
.feature-list li{list-style:none;display:flex;gap:12px;align-items:flex-start;color:var(--text)}
.feature-list li svg{width:20px;height:20px;flex-shrink:0;margin-top:3px;stroke:var(--gold-lit);fill:none;stroke-width:2}

/* ===== STAT ROW ===== */
.stat-row{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,72px)}
.stat-row .st b{display:block;font-family:'Fraunces';font-weight:600;font-size:clamp(1.8rem,3.4vw,2.6rem);color:var(--gold-bright);line-height:1}
.stat-row .st span{font-family:'Archivo';font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--sub)}

/* ===== CTA BAND ===== */
.cta-band{position:relative;border-radius:clamp(18px,2.5vw,28px);overflow:hidden;border:1px solid var(--line);padding:clamp(40px,6vw,74px) clamp(26px,5vw,64px);background:
  radial-gradient(700px 400px at 85% 10%,rgba(224,187,107,.16),transparent 60%),
  linear-gradient(160deg,var(--navy-3),var(--ink))}
.cta-band h2{font-size:clamp(1.9rem,4.4vw,3.2rem);max-width:680px}
.cta-band p{margin-top:18px;max-width:620px;color:var(--sub);font-size:1.1rem}
.cta-band .hero-actions{margin-top:30px}

/* ===== FORMS ===== */
.form-card{background:linear-gradient(165deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border:1px solid var(--line-cool);border-radius:var(--radius);padding:clamp(26px,3vw,40px)}
.field{margin-bottom:18px}
.field label{display:block;font-family:'Archivo';font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.74rem;color:var(--sub);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:rgba(6,13,24,.6);border:1px solid var(--line-cool);border-radius:11px;padding:13px 15px;color:var(--white);font-family:'Hanken Grotesk';font-size:1rem;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-lit)}
.field textarea{min-height:140px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}
.form-note{font-size:.82rem;color:var(--muted);margin-top:10px}
.hp{position:absolute;left:-9999px}
.form-status{margin-top:16px;padding:14px 16px;border-radius:11px;font-size:.94rem;display:none}
.form-status.ok{display:block;background:rgba(224,187,107,.12);border:1px solid var(--line);color:var(--cream)}
.form-status.err{display:block;background:rgba(200,80,80,.12);border:1px solid rgba(200,80,80,.4);color:#f0c4c4}

/* ===== ACCORDION-ish info tiles ===== */
.tile{background:linear-gradient(165deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border:1px solid var(--line-cool);border-radius:14px;padding:26px 24px}
.tile h3{font-size:1.18rem;margin-bottom:8px}
.tile p{color:var(--sub);font-size:.96rem}
.tile .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--gold-soft);border:1px solid var(--line);margin-bottom:16px}
.tile .ic svg{width:23px;height:23px;stroke:var(--gold-lit);fill:none;stroke-width:1.6}

/* ===== FOOTER ===== */
.footer{border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(10,22,39,.6));padding:clamp(54px,7vw,84px) 0 36px;margin-top:var(--space)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
@media(max-width:860px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-brand .brand{margin-bottom:18px}
.footer-tag{font-family:'Fraunces',serif;font-style:italic;font-size:1.16rem;color:var(--gold-lit);margin-bottom:18px}
.footer-brand p{color:var(--sub);font-size:.95rem;max-width:340px}
.footer h4{font-family:'Archivo';font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.74rem;color:var(--gold-lit);margin-bottom:18px}
.footer-col a{display:block;color:var(--sub);font-size:.95rem;padding:7px 0;transition:color .2s}
.footer-col a:hover{color:var(--white)}
.socials{display:flex;gap:12px;margin-top:20px}
.socials a{width:42px;height:42px;border-radius:11px;border:1px solid var(--line-cool);display:grid;place-items:center;transition:border-color .2s,transform .2s}
.socials a:hover{border-color:var(--gold-lit);transform:translateY(-3px)}
.socials svg{width:19px;height:19px;fill:var(--sub)}
.socials a:hover svg{fill:var(--gold-lit)}
.footer-bottom{margin-top:clamp(40px,5vw,64px);padding-top:26px;border-top:1px solid var(--line-cool);display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;color:var(--muted);font-size:.84rem}
.footer-bottom a{color:var(--muted)}
.footer-bottom a:hover{color:var(--gold-lit)}

/* ===== SCROLL REVEAL ===== */
.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;transition:none}}

/* ===== UTILITY ===== */
.center{text-align:center}
.mt-s{margin-top:18px}.mt-m{margin-top:32px}.mt-l{margin-top:52px}
.gold{color:var(--gold-bright)}
.maxw-prose{max-width:680px}
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--gold-soft);border-radius:99px;padding:8px 16px;font-family:'Archivo';font-weight:600;letter-spacing:.04em;font-size:.78rem;color:var(--cream)}
