/* ============================================================
   SCANTUCSON — Desert Noir Design System
   Aesthetic: Dark desert night · stark contrast · bold type
   ============================================================ */

/* === TOKENS === */
:root {
  /* Background layers */
  --bg-void:    #0c0e14;
  --bg-base:    #10131c;
  --bg-surface: #161b28;
  --bg-raised:  #1c2235;
  --bg-hover:   #222840;

  /* Brand */
  --orange:     #e05a2b;
  --orange-lit: #f07040;
  --orange-dim: #7a2e10;
  --orange-glow:rgba(224, 90, 43, 0.15);

  /* Accent categories */
  --fire:       #e84040;
  --fire-dim:   rgba(232,64,64,0.12);
  --law:        #4080e8;
  --law-dim:    rgba(64,128,232,0.12);
  --military:   #60c080;
  --military-dim:rgba(96,192,128,0.12);
  --federal:    #c890f0;
  --federal-dim:rgba(200,144,240,0.12);
  --radio:      #f0b840;
  --radio-dim:  rgba(240,184,64,0.12);

  /* Border */
  --border:     rgba(255,255,255,0.07);
  --border-lit: rgba(255,255,255,0.14);
  --border-glow:rgba(224,90,43,0.3);

  /* Text */
  --text-hi:    #f0f4ff;
  --text-mid:   #8892a8;
  --text-lo:    #454e64;

  /* Type */
  --font-display: 'Rajdhani', sans-serif;
  --font-body:    'DM Sans', sans-serif;

  /* Geometry */
  --r:   6px;
  --r-lg:12px;
  --r-xl:18px;
  --ease: cubic-bezier(0.22,1,0.36,1);
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  color:var(--text-mid);
  background:var(--bg-void);
  min-height:100vh;
  overflow-x:hidden;
}
a{color:var(--orange-lit);text-decoration:none;transition:color .2s}
a:hover{color:var(--orange)}
img{max-width:100%;height:auto;display:block}

/* === SCAN LINE === */
.scan-line{
  position:fixed;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--orange) 50%,transparent 100%);
  z-index:200;opacity:0.6;
}

/* === HEADER === */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(12,14,20,0.9);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}
.header-inner{
  max-width:1280px;margin:0 auto;padding:0 28px;
  height:68px;display:flex;align-items:center;gap:24px;
}

/* Logo */
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0;text-decoration:none;}
.logo-mark svg{display:block;}
.logo-wordmark{display:flex;flex-direction:column;line-height:1;gap:3px;}
.wm-scan,.wm-tucson{font-family:var(--font-display);font-weight:700;}
.wm-scan{font-size:20px;color:var(--text-hi);letter-spacing:0.04em;}
.wm-tucson{font-size:20px;color:var(--orange);letter-spacing:0.12em;margin-left:1px;}
.logo .wm-scan,.logo .wm-tucson{display:inline;}
.logo-wordmark>*:first-child .wm-scan,
.logo-wordmark>*:first-child .wm-tucson{display:inline;}
/* inline treatment */
.logo-wordmark{flex-direction:column;}
.wm-scan{color:var(--text-hi);}
.wm-sub{font-size:10px;color:var(--text-lo);letter-spacing:0.14em;text-transform:uppercase;font-family:var(--font-display);}

/* Nav */
.main-nav{display:flex;align-items:center;gap:2px;margin-left:auto;}
.nav-link{
  padding:6px 14px;
  font-family:var(--font-display);font-size:14px;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--text-lo);border-radius:var(--r);
  transition:color .2s,background .2s;
}
.nav-link:hover,.nav-link.is-active{color:var(--text-hi);background:var(--bg-raised);}
.nav-cta{
  margin-left:12px;padding:7px 20px;
  font-family:var(--font-display);font-size:14px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--orange);border:1px solid var(--orange-dim);
  border-radius:var(--r);
  transition:background .2s,color .2s,border-color .2s;
}
.nav-cta:hover{background:var(--orange);color:#fff;border-color:var(--orange);}

.burger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:8px;margin-left:auto;
}
.burger span{display:block;width:22px;height:2px;background:var(--text-mid);border-radius:2px;transition:.2s;}

/* Mobile nav */
.mobile-nav{
  background:var(--bg-base);border-bottom:1px solid var(--border);
  padding:16px 28px 24px;display:flex;flex-direction:column;gap:2px;
}
.mnav-link{
  padding:11px 0;font-family:var(--font-display);font-size:17px;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;color:var(--text-mid);
  border-bottom:1px solid var(--border);
}
.mnav-link.mnav-donate{color:var(--orange);border-bottom:none;margin-top:12px;}

/* === HERO === */
.hero{
  position:relative;overflow:hidden;
  padding:80px 28px 100px;
  background:var(--bg-base);
  border-bottom:1px solid var(--border);
}

/* Desert sky gradient atmosphere */
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 20%, rgba(224,90,43,0.06) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 20% 80%, rgba(64,128,232,0.04) 0%, transparent 70%);
  pointer-events:none;
}

/* Grid texture */
.hero::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:48px 48px;
  opacity:0.4;pointer-events:none;
}

.hero-inner{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}

.hero-left{}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--orange);
  margin-bottom:28px;
  padding:5px 14px 5px 10px;
  background:var(--orange-glow);border:1px solid var(--border-glow);border-radius:100px;
}
.live-dot{
  width:8px;height:8px;border-radius:50%;background:var(--orange);
  box-shadow:0 0 8px var(--orange);
  animation:blink 1.8s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

.hero h1{
  font-family:var(--font-display);
  font-size:clamp(48px,6vw,80px);
  font-weight:700;line-height:0.92;
  letter-spacing:-0.5px;
  color:var(--text-hi);
  margin-bottom:24px;
}
.hero h1 em{
  font-style:normal;color:var(--orange);
  display:block;
}

.hero-desc{font-size:16px;color:var(--text-mid);max-width:420px;line-height:1.7;margin-bottom:36px;}

.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;}

.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;
  font-family:var(--font-display);font-size:15px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  background:var(--orange);color:#fff;border-radius:var(--r);
  border:none;cursor:pointer;
  transition:background .2s var(--ease),transform .15s;
}
.btn-primary:hover{background:var(--orange-lit);color:#fff;transform:translateY(-1px);}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;
  font-family:var(--font-display);font-size:15px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  background:transparent;color:var(--text-mid);
  border:1px solid var(--border-lit);border-radius:var(--r);
  cursor:pointer;transition:background .2s,color .2s,border-color .2s;
}
.btn-ghost:hover{background:var(--bg-raised);color:var(--text-hi);border-color:var(--border-lit);}

/* Hero right — live feed ticker */
.hero-right{}
.hero-feeds-label{
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--text-lo);
  margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);
}
.hero-feed-list{display:flex;flex-direction:column;gap:10px;}
.hero-feed-item{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;
  background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);
  transition:border-color .2s,background .2s;
  cursor:pointer;text-decoration:none;
}
.hero-feed-item:hover{border-color:var(--border-lit);background:var(--bg-raised);}
.hfi-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;animation:blink 1.8s ease infinite;}
.hfi-info{flex:1;min-width:0;}
.hfi-name{
  font-family:var(--font-display);font-size:15px;font-weight:600;
  color:var(--text-hi);letter-spacing:0.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hfi-sub{font-size:12px;color:var(--text-lo);margin-top:1px;}
.hfi-badge{
  font-family:var(--font-display);font-size:10px;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:3px 8px;border-radius:4px;flex-shrink:0;
}
.hfi-arrow{color:var(--text-lo);font-size:16px;flex-shrink:0;}

/* category colors */
.cat-fire   .hfi-dot,.hfi-dot.cat-fire   {background:var(--fire);}
.cat-law    .hfi-dot,.hfi-dot.cat-law    {background:var(--law);}
.cat-military .hfi-dot,.hfi-dot.cat-military{background:var(--military);}
.cat-federal .hfi-dot,.hfi-dot.cat-federal{background:var(--federal);}
.cat-radio  .hfi-dot,.hfi-dot.cat-radio  {background:var(--radio);}

.cat-fire    .hfi-badge{background:var(--fire-dim);color:var(--fire);}
.cat-law     .hfi-badge{background:var(--law-dim);color:var(--law);}
.cat-military .hfi-badge{background:var(--military-dim);color:var(--military);}
.cat-federal  .hfi-badge{background:var(--federal-dim);color:var(--federal);}
.cat-radio   .hfi-badge{background:var(--radio-dim);color:var(--radio);}

/* === STATS STRIP === */
.stats-strip{
  background:var(--bg-surface);border-bottom:1px solid var(--border);
}
.stats-inner{
  max-width:1280px;margin:0 auto;padding:0 28px;
  display:flex;align-items:stretch;
  overflow-x:auto;
}
.stat-item{
  flex:1;min-width:140px;
  padding:24px 20px;
  border-right:1px solid var(--border);
  text-align:center;
}
.stat-item:last-child{border-right:none;}
.stat-val{
  font-family:var(--font-display);font-size:36px;font-weight:700;
  color:var(--orange);line-height:1;margin-bottom:6px;letter-spacing:-0.5px;
}
.stat-lbl{
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--text-lo);
}

/* === MAIN === */
.main-wrap{max-width:1280px;margin:0 auto;padding:60px 28px 100px;}

/* Section label */
.section-eyebrow{
  display:flex;align-items:center;gap:16px;margin-bottom:32px;
}
.section-eyebrow-text{
  font-family:var(--font-display);font-size:11px;font-weight:700;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--orange);
  white-space:nowrap;
}
.section-rule{flex:1;height:1px;background:var(--border);}
.section-count{
  font-family:var(--font-display);font-size:11px;color:var(--text-lo);
  letter-spacing:0.08em;white-space:nowrap;
}

/* Filter bar */
.filter-bar{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;
}
.filter-btn{
  padding:6px 16px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  background:transparent;color:var(--text-lo);
  border:1px solid var(--border);border-radius:100px;
  cursor:pointer;transition:all .2s;
}
.filter-btn:hover{color:var(--text-mid);border-color:var(--border-lit);}
.filter-btn.is-active{background:var(--orange-glow);color:var(--orange);border-color:var(--border-glow);}

/* === SCANNER GRID === */
.scanner-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.scanner-card{
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .25s var(--ease),transform .25s var(--ease),background .25s;
  position:relative;
}
.scanner-card:hover{
  border-color:var(--border-lit);
  background:var(--bg-raised);
  transform:translateY(-3px);
}
.scanner-card[data-cat="fire"]:hover   {border-color:rgba(232,64,64,0.35);}
.scanner-card[data-cat="law"]:hover    {border-color:rgba(64,128,232,0.35);}
.scanner-card[data-cat="military"]:hover{border-color:rgba(96,192,128,0.35);}
.scanner-card[data-cat="federal"]:hover{border-color:rgba(200,144,240,0.35);}
.scanner-card[data-cat="radio"]:hover  {border-color:rgba(240,184,64,0.35);}

/* Accent stripe */
.card-stripe{height:2px;width:100%;}
.scanner-card[data-cat="fire"]     .card-stripe{background:var(--fire);}
.scanner-card[data-cat="law"]      .card-stripe{background:var(--law);}
.scanner-card[data-cat="military"] .card-stripe{background:var(--military);}
.scanner-card[data-cat="federal"]  .card-stripe{background:var(--federal);}
.scanner-card[data-cat="radio"]    .card-stripe{background:var(--radio);}

.card-body{padding:22px 22px 16px;flex:1;display:flex;flex-direction:column;}

/* Row 1: status + short code */
.card-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.live-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-size:10px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;
  padding:3px 10px;border-radius:100px;
}
.live-badge.is-live{
  background:rgba(224,90,43,0.12);color:var(--orange);
  border:1px solid rgba(224,90,43,0.25);
}
.live-badge .dot{
  width:6px;height:6px;border-radius:50%;background:var(--orange);
  animation:blink 1.8s ease infinite;
}
.card-short{
  font-family:var(--font-display);font-size:11px;font-weight:700;
  letter-spacing:0.16em;color:var(--text-lo);
}

/* Name */
.card-name{
  font-family:var(--font-display);font-size:24px;font-weight:700;
  color:var(--text-hi);line-height:1.1;letter-spacing:-0.2px;margin-bottom:4px;
}
.card-subtitle{
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:14px;
}
.scanner-card[data-cat="fire"]     .card-subtitle{color:var(--fire);}
.scanner-card[data-cat="law"]      .card-subtitle{color:var(--law);}
.scanner-card[data-cat="military"] .card-subtitle{color:var(--military);}
.scanner-card[data-cat="federal"]  .card-subtitle{color:var(--federal);}
.scanner-card[data-cat="radio"]    .card-subtitle{color:var(--radio);}

.card-desc{font-size:13px;color:var(--text-mid);line-height:1.6;margin-bottom:14px;flex:1;}

/* Note */
.card-note{
  display:flex;align-items:flex-start;gap:8px;
  background:rgba(240,184,64,0.07);border:1px solid rgba(240,184,64,0.2);
  border-radius:var(--r);padding:8px 10px;margin-bottom:14px;
  font-size:12px;color:rgba(240,184,64,0.85);line-height:1.5;
}
.card-note svg{flex-shrink:0;margin-top:1px;}

/* Location */
.card-location{
  display:flex;align-items:center;gap:5px;
  font-size:12px;color:var(--text-lo);margin-bottom:12px;
}
.card-location svg{flex-shrink:0;}

/* Tags */
.card-tags{display:flex;flex-wrap:wrap;gap:5px;}
.tag{
  font-family:var(--font-display);font-size:10px;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:2px 8px;border-radius:3px;
}
.scanner-card[data-cat="fire"]     .tag{background:var(--fire-dim);color:var(--fire);}
.scanner-card[data-cat="law"]      .tag{background:var(--law-dim);color:var(--law);}
.scanner-card[data-cat="military"] .tag{background:var(--military-dim);color:var(--military);}
.scanner-card[data-cat="federal"]  .tag{background:var(--federal-dim);color:var(--federal);}
.scanner-card[data-cat="radio"]    .tag{background:var(--radio-dim);color:var(--radio);}

/* Card footer */
.card-footer{
  padding:14px 22px;border-top:1px solid var(--border);
  display:flex;gap:8px;
}
.btn-listen{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 14px;
  font-family:var(--font-display);font-size:13px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  background:var(--orange);color:#fff;border-radius:var(--r);
  border:none;cursor:pointer;text-decoration:none;
  transition:background .2s;
}
.btn-listen:hover{background:var(--orange-lit);color:#fff;}
.btn-archive{
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 12px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--text-mid);background:transparent;
  border:1px solid var(--border);border-radius:var(--r);
  cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:border-color .2s,color .2s;
}
.btn-archive:hover{border-color:var(--border-lit);color:var(--text-hi);}

/* === DONATE BAND === */
.donate-band{
  margin-top:56px;
  background:var(--bg-surface);
  border:1px solid var(--border);border-radius:var(--r-xl);
  padding:48px 56px;
  display:flex;align-items:center;gap:48px;
  position:relative;overflow:hidden;
}
.donate-band::before{
  content:'';position:absolute;right:-40px;top:-40px;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(224,90,43,0.08) 0%,transparent 70%);
  pointer-events:none;
}
.donate-icon-wrap{
  width:72px;height:72px;border-radius:50%;flex-shrink:0;
  background:var(--orange-glow);border:1px solid var(--border-glow);
  display:flex;align-items:center;justify-content:center;
  font-size:32px;
}
.donate-text-wrap{flex:1;min-width:0;}
.donate-text-wrap h3{
  font-family:var(--font-display);font-size:26px;font-weight:700;
  color:var(--text-hi);margin-bottom:8px;letter-spacing:-0.2px;
}
.donate-text-wrap p{font-size:15px;color:var(--text-mid);max-width:480px;}
.btn-donate-main{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;flex-shrink:0;
  font-family:var(--font-display);font-size:15px;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  background:var(--orange);color:#fff;border-radius:var(--r);
  border:none;cursor:pointer;white-space:nowrap;
  transition:background .2s,transform .15s;
}
.btn-donate-main:hover{background:var(--orange-lit);color:#fff;transform:translateY(-1px);}

/* === PLAYER PAGE === */
.player-wrap{max-width:900px;margin:0 auto;padding:48px 28px 100px;}
.player-back{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.15em;text-transform:uppercase;color:var(--text-lo);
  margin-bottom:36px;
}
.player-back:hover{color:var(--orange);}

.player-header{margin-bottom:36px;}
.player-cat-badge{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-display);font-size:11px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;
  padding:4px 12px;border-radius:100px;margin-bottom:18px;
}
.player-title{
  font-family:var(--font-display);
  font-size:clamp(38px,6vw,64px);
  font-weight:700;line-height:0.95;
  color:var(--text-hi);letter-spacing:-0.5px;margin-bottom:10px;
}
.player-subtitle{
  font-family:var(--font-display);font-size:16px;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:12px;
}
.player-location{
  display:flex;align-items:center;gap:6px;
  font-size:14px;color:var(--text-lo);
}

/* Player embed box */
.player-box{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;margin-bottom:20px;
}
.player-box iframe{width:100%;border:none;display:block;}
.player-box-hint{
  padding:12px 20px;font-size:13px;color:var(--text-lo);
  border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;
}

/* Transcription box */
.transcription-box{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:var(--r-lg);margin-bottom:20px;overflow:hidden;
}
.transcription-header{
  padding:14px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.transcription-title{
  font-family:var(--font-display);font-size:12px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--text-lo);
  display:flex;align-items:center;gap:8px;
}
.transcription-live-pill{
  font-family:var(--font-display);font-size:10px;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:2px 8px;border-radius:100px;
  background:rgba(224,90,43,0.12);color:var(--orange);
  display:flex;align-items:center;gap:5px;
}
.transcription-body{
  padding:20px;min-height:140px;max-height:260px;overflow-y:auto;
  font-family:var(--font-body);font-size:14px;line-height:1.7;color:var(--text-mid);
}
.trans-line{margin-bottom:8px;}
.trans-time{color:var(--text-lo);font-size:12px;margin-right:10px;font-family:var(--font-display);}
.trans-placeholder{color:var(--text-lo);font-style:italic;font-size:14px;}

.player-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px;}

.player-info-card{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:24px;margin-bottom:20px;
}
.player-info-card h3{
  font-family:var(--font-display);font-size:12px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--text-lo);
  margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border);
}
.player-info-card p{font-size:14px;color:var(--text-mid);line-height:1.7;}

.player-note{
  display:flex;align-items:flex-start;gap:10px;
  background:rgba(240,184,64,0.06);border:1px solid rgba(240,184,64,0.2);
  border-radius:var(--r);padding:14px 16px;margin-top:16px;
  font-size:13px;color:rgba(240,184,64,0.85);line-height:1.6;
}
.player-note svg{flex-shrink:0;margin-top:2px;}

/* === ARCHIVE PAGE === */
.archive-wrap{max-width:960px;margin:0 auto;padding:48px 28px 100px;}
.archive-header{margin-bottom:40px;}
.archive-title{
  font-family:var(--font-display);font-size:42px;font-weight:700;
  color:var(--text-hi);letter-spacing:-0.3px;margin-bottom:10px;
}
.archive-desc{font-size:15px;color:var(--text-mid);}

.archive-table-wrap{
  background:var(--bg-surface);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
}
.archive-table{width:100%;border-collapse:collapse;}
.archive-table th{
  padding:12px 20px;text-align:left;
  font-family:var(--font-display);font-size:11px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--text-lo);
  border-bottom:1px solid var(--border);background:var(--bg-raised);
}
.archive-table td{
  padding:13px 20px;font-size:14px;color:var(--text-mid);
  border-bottom:1px solid var(--border);vertical-align:middle;
}
.archive-table tr:last-child td{border-bottom:none;}
.archive-table tr:hover td{background:var(--bg-raised);}
.archive-date{font-family:var(--font-display);color:var(--text-hi);font-size:14px;}
.archive-dur{font-family:var(--font-display);font-size:13px;color:var(--text-lo);}
.archive-play-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.08em;text-transform:uppercase;
  background:var(--bg-void);color:var(--text-mid);
  border:1px solid var(--border);border-radius:var(--r);
  cursor:pointer;text-decoration:none;
  transition:border-color .2s,color .2s;
}
.archive-play-btn:hover{border-color:var(--orange);color:var(--orange);}
.archive-empty{padding:48px 20px;text-align:center;color:var(--text-lo);font-size:14px;}

/* === FOOTER === */
.site-footer{
  background:var(--bg-base);border-top:1px solid var(--border);
  position:relative;overflow:hidden;
}
.footer-saguaro{position:absolute;top:0;left:0;right:0;height:180px;pointer-events:none;}
.footer-saguaro svg{width:100%;height:100%;}

.footer-inner{
  position:relative;max-width:1280px;margin:0 auto;
  padding:100px 28px 56px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:56px;
}
.footer-brand .footer-logo{
  font-family:var(--font-display);font-size:22px;font-weight:700;
  margin-bottom:16px;
}
.footer-brand .wm-scan{color:var(--text-hi);}
.footer-brand .wm-tucson{color:var(--orange);letter-spacing:0.1em;}
.footer-brand p{font-size:14px;color:var(--text-mid);line-height:1.7;margin-bottom:20px;}
.footer-socials{display:flex;gap:12px;flex-direction:column;}
.footer-social-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:var(--text-lo);
  transition:color .2s;
}
.footer-social-link:hover{color:var(--orange);}
.footer-heading{
  font-family:var(--font-display);font-size:11px;font-weight:700;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--text-lo);margin-bottom:20px;
}
.footer-link{
  display:block;font-size:14px;color:var(--text-mid);
  margin-bottom:10px;transition:color .2s;
}
.footer-link:hover{color:var(--orange);}
.footer-support-text{font-size:14px;color:var(--text-mid);margin-bottom:18px;line-height:1.6;}
.btn-donate-footer{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;
  font-family:var(--font-display);font-size:13px;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  background:var(--orange);color:#fff;border-radius:var(--r);
  transition:background .2s;
}
.btn-donate-footer:hover{background:var(--orange-lit);color:#fff;}

.footer-bottom{
  position:relative;max-width:1280px;margin:0 auto;
  padding:20px 28px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;color:var(--text-lo);flex-wrap:wrap;gap:8px;
}

/* === HIDDEN === */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0;
}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:48px;}
  .hero-right{display:none;}
  .scanner-grid{grid-template-columns:repeat(2,1fr);}
  .footer-inner{grid-template-columns:1fr 1fr;gap:36px;}
  .donate-band{flex-direction:column;text-align:center;padding:36px;}
  .donate-band::before{display:none;}
}
@media(max-width:768px){
  .main-nav{display:none;}
  .burger{display:flex;}
  .scanner-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;gap:28px;padding:80px 28px 36px;}
  .stats-inner{gap:0;}
  .stat-item{min-width:110px;padding:18px 12px;}
  .stat-val{font-size:28px;}
}
