/* ASU NAA — Legacy Torch / Gateway brand (Concept 1)
   Gold #C99700 · Hornet Black #111111 · Tower Graphite #5E6267 · Silver #BFC2C4 · Warm White #FBF8EF
   Headlines: Cinzel (collegiate) · Body/UI: Inter */
:root{
  --gold:#C99700; --gold-deep:#A87E00; --gold-soft:#F3E4B8;
  --black:#111111; --graphite:#5E6267; --silver:#BFC2C4; --warm:#FBF8EF;
  --white:#fff; --line:#E8E2D2; --ok:#2E7D46; --warn:#B54708; --red:#B42318;
  --shadow:0 10px 30px rgba(17,17,17,.10); --rad:14px;
  --serif:'Cinzel',serif; --sans:'Inter',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--black);background:var(--warm);line-height:1.6;font-size:16.5px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
h1,h2,h3,.serif{font-family:var(--serif);font-weight:700;line-height:1.15;letter-spacing:.01em}
.kick{font:700 12px/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);display:flex;align-items:center;gap:10px;margin-bottom:14px}
.kick::before{content:"";width:34px;height:2px;background:var(--gold)}
.center .kick{justify-content:center}
.center{text-align:center}
section{padding:84px 0}
.sub{color:var(--graphite);max-width:640px}
.center .sub{margin:0 auto}

/* ── top bar + nav ── */
.topbar{background:var(--black);color:#D9D3C0;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a{color:var(--gold);font-weight:600}
.topbar .tb-l{display:flex;gap:18px;align-items:center}
nav.main{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:900}
nav.main .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo img{height:52px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none}
.nav-links a{font:600 14.5px var(--sans);color:var(--black);padding:6px 2px;border-bottom:2px solid transparent;transition:.2s}
.nav-links a:hover,.nav-links a.on{color:var(--gold-deep);border-color:var(--gold)}
.btn{display:inline-flex;align-items:center;gap:9px;font:700 15px var(--sans);padding:13px 26px;border-radius:8px;border:2px solid var(--gold);background:var(--gold);color:var(--black);cursor:pointer;transition:.2s;white-space:nowrap}
.btn:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--black)}
.btn.ghost:hover{background:var(--gold);color:var(--black)}
/* nav Donate button — solid so it doesn't read weak next to Join */
.nav-links .btn.ghost{background:var(--black);color:#fff;border-color:var(--black)}
.nav-links .btn.ghost:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.btn.dark{background:var(--black);border-color:var(--black);color:#fff}
.btn.dark:hover{background:#000;transform:translateY(-1px)}
.btn.sm{padding:9px 16px;font-size:13.5px}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:24px;height:2.5px;background:var(--black);margin:5px 0;border-radius:2px}

/* ── hero (full-bleed bg photo) ── */
.hero{position:relative;overflow:hidden;color:#fff;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:url('assets/hero.jpg') center/cover no-repeat;}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg,rgba(10,10,10,.92) 0%,rgba(14,14,14,.78) 42%,rgba(20,16,4,.55) 100%);}
.hero .wrap{max-width:1200px;padding-top:118px;padding-bottom:118px;position:relative}
.hero-inner{max-width:680px}
.hero h1{font-size:clamp(38px,5.4vw,66px);color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero p{color:#E4DFD0;margin:22px 0 32px;font-size:18.5px;max-width:560px}
.hero .kick{color:var(--gold)}
.hero .kick::before{background:var(--gold)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ── announcements auto-scroll bar ── */
.ann{background:var(--black);border-top:3px solid var(--gold);border-bottom:1px solid #26251F;overflow:hidden;position:relative}
.ann-label{position:absolute;left:0;top:0;bottom:0;z-index:3;display:flex;align-items:center;gap:9px;background:var(--gold);color:var(--black);font:800 12px var(--sans);letter-spacing:.14em;text-transform:uppercase;padding:0 20px 0 24px;clip-path:polygon(0 0,100% 0,calc(100% - 16px) 100%,0 100%)}
.ann-label svg{width:16px;height:16px;stroke:var(--black);fill:none;stroke-width:2}
.ann-track-mask{overflow:hidden;padding:16px 0 16px 190px}
.ann-track{display:flex;gap:44px;width:max-content;animation:annscroll 46s linear infinite}
.ann:hover .ann-track{animation-play-state:paused}
.ann-item{display:flex;align-items:center;gap:12px;color:#E4DFD0;font-size:14.5px;white-space:nowrap}
.ann-item b{color:#fff;font-weight:700}
.ann-item .tag{font:800 10px var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:4px 9px;border-radius:99px}
.ann-item .dot{color:var(--gold);font-size:18px;line-height:0}
@keyframes annscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ann-track{animation:none;flex-wrap:wrap;white-space:normal}.ann-track-mask{padding-left:24px}.ann-label{display:none}}
@media(max-width:760px){.ann-label{display:none}.ann-track-mask{padding-left:24px}}

/* stats band */
.stats{background:var(--gold);padding:0}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.stat{padding:34px 10px;border-right:1px solid rgba(17,17,17,.12)}
.stat:last-child{border-right:0}
.stat b{font:700 40px/1.05 var(--serif);display:block;color:var(--black)}
.stat span{font:600 12.5px var(--sans);letter-spacing:.14em;text-transform:uppercase;color:#5b4a05}

/* ── cards / grids ── */
.grid{display:grid;gap:26px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--rad);padding:30px;box-shadow:var(--shadow)}
.card h3{font-size:21px;margin-bottom:10px}
.card p{color:var(--graphite);font-size:15px}
.ic{width:52px;height:52px;border-radius:12px;background:var(--black);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.ic svg{width:26px;height:26px;stroke:var(--gold);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* tier cards */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:stretch}
.tier{background:var(--white);border:1px solid var(--line);border-radius:var(--rad);padding:34px 28px;display:flex;flex-direction:column;box-shadow:var(--shadow);position:relative}
.tier.hot{border:2px solid var(--gold);transform:scale(1.02)}
.tier .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--black);font:700 11px var(--sans);letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border-radius:99px}
.tier h3{font-size:19px}
.tier .price{font:700 42px/1 var(--serif);margin:16px 0 2px}
.tier .price small{font:600 14px var(--sans);color:var(--graphite)}
.tier .per{color:var(--graphite);font-size:13.5px;margin-bottom:18px}
.tier ul{list-style:none;margin:0 0 24px;flex:1}
.tier li{padding:7px 0 7px 26px;position:relative;font-size:14.5px;color:#333}
.tier li::before{content:"✓";position:absolute;left:2px;color:var(--gold-deep);font-weight:800}
.tier .btn{width:100%;justify-content:center}

/* dark section */
.dark{background:var(--black);color:#fff}
.dark .sub{color:#BDB7A6}
.dark .card{background:#1B1B18;border-color:#2A2822;box-shadow:none}
.dark .card p{color:#A9A392}
.dark .card h3{color:#fff}

/* footer */
footer{background:var(--black);color:#A9A392;padding:64px 0 0;font-size:14.5px}
footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.1fr;gap:34px;padding-bottom:44px}
footer h4{font:700 13px var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
footer a{display:block;padding:4px 0;color:#CFC9B8}
footer a:hover{color:var(--gold)}
.fmark{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.fmark img{height:54px;background:var(--warm);border-radius:10px;padding:6px}
.fmark b{font-family:var(--serif);color:#fff;font-size:18px;line-height:1.2}
.legal{border-top:1px solid #26251F;padding:20px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px}
.legal a{display:inline;color:var(--gold)}

/* page hero (interior) */
.phero{background:linear-gradient(160deg,#181818,#111 60%,#1E1A0E);color:#fff;padding:72px 0 64px}
/* photo-backed page hero: set the image with inline --img on the header */
.phero.shot{position:relative;background:#111;isolation:isolate}
.phero.shot::before{content:"";position:absolute;inset:0;z-index:-2;background:var(--img) center/cover no-repeat}
.phero.shot::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(12,12,12,.92) 0%,rgba(15,13,6,.72) 55%,rgba(20,16,4,.5) 100%)}
.phero h1{font-size:clamp(30px,3.6vw,46px);color:#fff}
.phero .kick{color:var(--gold)}.phero .kick::before{background:var(--gold)}
.phero p{color:#CFC9B8;margin-top:14px;max-width:640px;font-size:17px}
.crumb{font-size:13px;color:#8f8a7a;margin-bottom:18px}
.crumb a{color:var(--gold)}

/* tables (admin + reports) */
table.data{width:100%;border-collapse:collapse;background:var(--white);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);font-size:14px}
table.data th{background:var(--black);color:var(--gold);font:600 12px var(--sans);letter-spacing:.08em;text-transform:uppercase;padding:12px 14px;text-align:left}
table.data td{padding:12px 14px;border-bottom:1px solid var(--line)}
table.data tr:hover td{background:#FDF9EE}
.pill{display:inline-block;font:600 11.5px var(--sans);padding:4px 10px;border-radius:99px}
.pill.ok{background:#E7F4EB;color:var(--ok)}
.pill.warn{background:#FEF0E6;color:var(--warn)}
.pill.bad{background:#FDECEA;color:var(--red)}
.pill.gold{background:var(--gold-soft);color:#6b5304}
.pill.gray{background:#EEF0F2;color:var(--graphite)}

/* forms */
input,select,textarea{font:400 15px var(--sans);padding:12px 14px;border:1.5px solid var(--silver);border-radius:8px;background:#fff;width:100%;color:var(--black)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
label{font:600 13px var(--sans);display:block;margin:0 0 6px;color:#333}
.field{margin-bottom:18px}

/* demo ribbon */
.demo-note{background:var(--gold-soft);color:#6b5304;text-align:center;font:600 12.5px var(--sans);padding:8px 12px}

/* legal pages */
.legal-body{max-width:820px;margin:0 auto;padding:56px 0 20px}
.legal-body h2{font-size:22px;margin:38px 0 12px;padding-top:10px;border-top:1px solid var(--line)}
.legal-body h2:first-of-type{border-top:0;margin-top:8px}
.legal-body h3{font-size:16px;margin:22px 0 8px;font-family:var(--sans);font-weight:700}
.legal-body p{color:#3a3a3a;margin-bottom:14px;font-size:15.5px}
.legal-body ul{margin:0 0 16px 4px;padding:0;list-style:none}
.legal-body li{position:relative;padding:5px 0 5px 24px;color:#3a3a3a;font-size:15px}
.legal-body li::before{content:"";position:absolute;left:2px;top:13px;width:7px;height:7px;background:var(--gold);border-radius:2px;transform:rotate(45deg)}
.legal-body .updated{color:var(--graphite);font-size:13.5px;margin-bottom:6px}
.legal-body a{color:var(--gold-deep);font-weight:600}
.legal-body .box{background:#FDF8EA;border:1px solid var(--gold-soft);border-radius:12px;padding:20px 24px;margin:20px 0}
.legal-body .box p:last-child{margin-bottom:0}

/* map */
#map{height:560px;border-radius:var(--rad);border:1px solid var(--line);box-shadow:var(--shadow);z-index:1}
.chip-row{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0}
.chip{font:600 13px var(--sans);padding:9px 18px;border-radius:99px;border:1.5px solid var(--silver);background:#fff;cursor:pointer;transition:.15s}
.chip.on,.chip:hover{background:var(--black);color:var(--gold);border-color:var(--black)}

/* home photo mosaic */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:158px;gap:14px}
.pgrid a{overflow:hidden;border-radius:12px;display:block;box-shadow:var(--shadow)}
.pgrid img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.pgrid a:hover img{transform:scale(1.06)}
@media(max-width:760px){.pgrid{grid-template-columns:1fr 1fr;grid-auto-rows:130px}.pgrid a:first-child{grid-row:span 2}}

/* reveal helper (ape.js) */
.rv{opacity:0}
@media (prefers-reduced-motion:reduce){.rv{opacity:1}}

@media (max-width:1020px){
  .g4,.tiers{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:repeat(2,1fr)}
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .hero-art{display:none}
  footer .cols{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-links{display:none;position:absolute;top:78px;left:0;right:0;background:#fff;flex-direction:column;padding:18px 24px;gap:6px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{display:block;padding:12px 0;font-size:16px}
  .burger{display:block}
  .g2,.g3,.g4,.tiers{grid-template-columns:1fr}
  .stats .wrap{grid-template-columns:repeat(2,1fr)}
  .stat{border-right:0;border-bottom:1px solid rgba(17,17,17,.12)}
  section{padding:60px 0}
  .topbar .tb-l span.hide-m{display:none}
}
