*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* ── Texas Flag Fixed Colors ── */
  --red:#BF0A30;
  --navy:#002868;
  --white:#F0EDE8;
  --white-pure:#FFFFFF;
  --gold:var(--white);
  --emoji:'Apple Color Emoji','Segoe UI Emoji','Noto Color Emoji','Twemoji Mozilla',sans-serif;
  --fh:'Barlow Condensed',var(--emoji);
  --fb:'Barlow',var(--emoji);

  /* ── Dark Mode (default) ── */
  --dark:#06090F;
  --mid:#081422;
  --card:#0D1C30;
  --card2:#122540;
  --text:#EDF0F5;
  --muted:#6B8AAF;
  --dim:#3D5270;
  --border:rgba(255,255,255,0.07);
  --border2:rgba(255,255,255,0.15);

  /* ── Theme transition ── */
  --theme-transition: background-color 0.25s ease, color 0.2s ease, border-color 0.2s ease;
}

/* ── LIGHT MODE ── */
html.light{
  --dark:#F4F1EC;
  --mid:#E8E4DC;
  --card:#FFFFFF;
  --card2:#F9F6F0;
  --text:#0D1828;
  --muted:#4A6080;
  --dim:#8AA0BC;
  --border:rgba(0,40,104,0.1);
  --border2:rgba(0,40,104,0.18);
  --white:#1A2C50;        /* accent text flips to navy in light mode */
  --gold:var(--white);
}

/* smooth transitions on theme switch */
html.theme-transitioning *{transition:var(--theme-transition) !important}
html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--text);font-family:var(--fb);overflow-x:hidden;transition:var(--theme-transition)}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--dim);border-radius:3px}
a{color:inherit;text-decoration:none}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:56px;
  background:rgba(6,9,15,0.92);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);display:flex;align-items:center;
  justify-content:space-between;padding:0 2rem;gap:1rem}
.logo{font-family:var(--fh);font-weight:900;font-size:1.25rem;letter-spacing:.04em;
  display:flex;align-items:center;gap:6px;cursor:pointer;white-space:nowrap}
.logo .g{color:var(--gold)}.logo .r{color:var(--red)}
.nav-links{display:flex;list-style:none;gap:0;overflow-x:auto}
.nav-links a{font-family:var(--fh);font-size:.75rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);text-decoration:none;
  padding:0 12px;height:56px;display:flex;align-items:center;border-bottom:2px solid transparent;
  transition:color .18s,border-color .18s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--white);border-color:var(--white)}
.lang-switcher{display:flex;gap:4px;flex-shrink:0}
.lang-btn{font-family:var(--fh);font-size:.7rem;font-weight:700;letter-spacing:.08em;
  background:transparent;border:1px solid var(--border2);color:var(--muted);
  padding:4px 8px;cursor:pointer;transition:all .15s;border-radius:2px}
.lang-btn:hover,.lang-btn.active{background:var(--white);color:var(--navy);border-color:var(--white)}

/* BUTTONS */
.btn-prim{font-family:var(--fh);font-weight:700;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;background:var(--red);color:#fff;border:none;
  padding:13px 28px;cursor:pointer;transition:background .18s,transform .1s;display:inline-block}
.btn-prim:hover{background:#960822;transform:translateY(-2px)}
.btn-sec{font-family:var(--fh);font-weight:700;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;background:transparent;color:var(--white);
  border:1.5px solid rgba(240,237,232,.6);padding:13px 28px;cursor:pointer;
  transition:all .18s;display:inline-block}
.btn-sec:hover{background:var(--white);color:var(--navy)}
.btn-ghost{font-family:var(--fh);font-weight:700;font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;background:transparent;color:var(--muted);
  border:1px solid var(--border2);padding:10px 20px;cursor:pointer;
  transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{color:var(--text);border-color:var(--border)}

/* EXT LINK BADGE */
.ext-link{display:inline-flex;align-items:center;gap:6px;
  font-family:var(--fh);font-size:.72rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--gold);padding:7px 14px;
  border:1px solid rgba(240,237,232,.3);background:rgba(240,237,232,.06);
  transition:all .15s;white-space:nowrap}
.ext-link:hover{background:rgba(240,237,232,.14);border-color:rgba(240,237,232,.6)}
.ext-link svg{width:10px;height:10px;opacity:.7}

/* SECTIONS */
section{padding:4.5rem 2rem}
.sec-label{font-family:var(--fh);font-size:.7rem;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--white);margin-bottom:.4rem;
  display:flex;align-items:center;gap:8px}
.sec-label::before{content:'';width:16px;height:2px;background:var(--red)}
.sec-title{font-family:var(--fh);font-weight:900;font-size:clamp(2rem,5vw,3.2rem);
  text-transform:uppercase;line-height:.92;margin-bottom:2rem}
.sec-title em{color:var(--red);font-style:normal}

/* PAGE HERO (detail pages) */
.page-hero{padding:6rem 2rem 3rem;background:var(--mid);border-bottom:1px solid var(--border);
  position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(191,10,48,.12) 0%,transparent 65%)}
.page-hero-content{position:relative;z-index:2;max-width:800px}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:1.25rem}
.breadcrumb a{font-family:var(--fh);font-size:.7rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:var(--dim);font-size:.7rem}
.page-hero h1{font-family:var(--fh);font-weight:900;font-size:clamp(2.5rem,7vw,5rem);
  line-height:.9;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:1rem}
.page-hero h1 em{color:var(--gold);font-style:normal}
.page-hero-sub{font-size:1rem;color:var(--muted);line-height:1.75;max-width:560px;font-weight:300;margin-bottom:1.5rem}
.page-hero-tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-family:var(--fh);font-size:.65rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;padding:4px 10px;border-radius:1px}
.tag-gold{background:rgba(240,237,232,.1);color:var(--gold);border:1px solid rgba(240,237,232,.25)}
.tag-red{background:rgba(191,10,48,.1);color:#ff4d6d;border:1px solid rgba(191,10,48,.25)}
.tag-green{background:rgba(76,175,80,.1);color:#81C784;border:1px solid rgba(76,175,80,.25)}
.tag-blue{background:rgba(33,150,243,.1);color:#64B5F6;border:1px solid rgba(33,150,243,.25)}

/* CARDS GRID */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.card{background:var(--card);border:1px solid var(--border);padding:1.4rem;
  transition:border-color .18s,transform .15s;position:relative;overflow:hidden}
.card:hover{border-color:rgba(240,237,232,.3);transform:translateY(-3px)}
.card-label{font-family:var(--fh);font-size:.62rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.card-title{font-family:var(--fh);font-weight:700;font-size:1.05rem;text-transform:uppercase;
  letter-spacing:.02em;margin-bottom:.4rem}
.card-body{font-size:.8rem;color:var(--muted);line-height:1.65;font-weight:300;margin-bottom:1rem}
.card-arrow{position:absolute;bottom:1rem;right:1rem;font-family:var(--fh);font-weight:700;
  color:var(--dim);font-size:1.1rem;transition:color .18s,transform .18s}
.card:hover .card-arrow{color:var(--gold);transform:translate(2px,-2px)}
.card-link{display:block;text-decoration:none}
.card-link:hover .card{border-color:rgba(240,237,232,.3);transform:translateY(-3px)}

/* INFO ROW */
.info-row{display:flex;align-items:flex-start;gap:10px;padding:.75rem 0;
  border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:none}
.info-icon{font-size:1rem;flex-shrink:0;margin-top:1px;width:20px;text-align:center}
.info-body{}
.info-label{font-family:var(--fh);font-size:.65rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.info-val{font-size:.85rem;color:var(--text);line-height:1.5;font-weight:300}
.info-val a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}

/* ALERT */
.alert-box{background:rgba(191,10,48,.09);border:1px solid rgba(191,10,48,.28);
  padding:.85rem 1.1rem;display:flex;gap:10px;align-items:flex-start;
  margin-bottom:1.75rem;border-left:3px solid var(--red)}
.alert-text{font-size:.8rem;color:var(--muted);line-height:1.55;font-weight:300}
.alert-text strong{color:var(--text);font-weight:500}

/* FOOTER */
footer{background:var(--dark);border-top:1px solid var(--border);padding:2.5rem 2rem}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem}
.footer-logo{font-family:var(--fh);font-weight:900;font-size:1.5rem;letter-spacing:.04em;margin-bottom:.35rem}
.footer-logo .g{color:var(--gold)}.footer-logo .r{color:var(--red)}
.footer-tagline{font-size:.75rem;color:var(--muted);font-weight:300}
.footer-col-title{font-family:var(--fh);font-size:.65rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--dim);margin-bottom:.75rem}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:6px}
.footer-links a{font-size:.78rem;color:var(--muted);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.25rem;
  font-size:.72rem;color:var(--dim);font-weight:300}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .45s ease both}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--red);animation:pulse 1.4s infinite;vertical-align:middle;margin-right:4px}

/* MATCH ROW */
.match-row{background:var(--card);border:1px solid var(--border);padding:1.1rem 1.5rem;
  display:grid;grid-template-columns:1fr 80px 1fr 130px;align-items:center;gap:1rem;
  cursor:pointer;transition:all .18s;position:relative;overflow:hidden;margin-bottom:6px}
.match-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--red);opacity:0;transition:opacity .18s}
.match-row:hover{border-color:rgba(240,237,232,.3);transform:translateX(3px)}
.match-row:hover::before,.match-row.feat::before{opacity:1}
.match-row.feat{border-color:rgba(191,10,48,.4)}
.team-side{display:flex;align-items:center;gap:10px}
.team-side.right{justify-content:flex-end;flex-direction:row-reverse}
.t-flag{font-size:1.6rem;line-height:1;font-family:'Apple Color Emoji','Segoe UI Emoji','Noto Color Emoji','Twemoji Mozilla',sans-serif}
.t-name{font-family:var(--fh);font-weight:700;font-size:1rem;text-transform:uppercase}
.match-vs{font-family:var(--fh);font-size:1.4rem;font-weight:900;color:var(--dim);text-align:center}
.match-info{text-align:right}
.mi-date{font-family:var(--fh);font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--gold);text-transform:uppercase}
.mi-time{font-size:.78rem;color:var(--muted);margin-top:1px}
.mi-round{font-size:.67rem;color:var(--dim);margin-top:3px;font-weight:300}

/* CHECKLIST */
.cl-group{background:var(--card);border:1px solid var(--border);padding:1.5rem}
.cl-group-title{font-family:var(--fh);font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:1rem}
.cl-item{display:flex;align-items:center;gap:10px;padding:.5rem .6rem;cursor:pointer;border-radius:2px;transition:background .12s;user-select:none}
.cl-item:hover{background:rgba(255,255,255,.03)}
.cl-item.done .cl-label{text-decoration:line-through;color:var(--dim)}
.cl-check{width:18px;height:18px;border:1.5px solid var(--border2);border-radius:2px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .15s}
.cl-item.done .cl-check{background:var(--gold);border-color:var(--gold);color:var(--dark)}
.cl-label{font-size:.8rem;color:var(--muted);font-weight:300;line-height:1.4}

/* Legacy responsive rules moved to mobile section below */

/* ── TEXAS FLAG BACKGROUND ── */
.texas-flag-bg{position:relative;overflow:hidden}
.texas-flag-bg::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:
    /* Blue stripe - left third */
    linear-gradient(90deg,
      #002868 0%, #002868 33.33%,
      transparent 33.33%),
    /* Red stripe - top half of right two-thirds */
    linear-gradient(180deg,
      #BF0A30 0%, #BF0A30 50%,
      white 50%);
  opacity:0.06;
  pointer-events:none
}
.texas-flag-bg > *{position:relative;z-index:1}

/* ── HERO FLAG OVERLAY ── */
.hero-texas-flag{
  position:absolute;right:0;top:0;bottom:0;
  width:55%;opacity:0.07;pointer-events:none;
  display:flex;align-items:stretch
}

/* ── SCROLLBAR in Texas colors ── */
::-webkit-scrollbar-thumb{background:var(--navy);border-radius:3px}

/* ── LIVE DOT Texas red ── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--red);animation:pulse 1.4s infinite;vertical-align:middle;margin-right:4px}

/* ── THEME TOGGLE ── */
.theme-toggle{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--border2);
  background:transparent;cursor:pointer;display:flex;align-items:center;
  justify-content:center;font-size:16px;transition:all .2s;flex-shrink:0;
  color:var(--muted);
}
.theme-toggle:hover{background:var(--mid);color:var(--text);border-color:var(--border)}
html.light .theme-toggle{color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.25)}
html.light .theme-toggle:hover{background:rgba(255,255,255,.12);color:#fff}

/* ── LIGHT MODE: page-hero backgrounds ── */
html.light .page-hero{background:var(--mid)}
html.light .page-hero-bg{
  background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(191,10,48,.08) 0%,transparent 65%);
}

/* ── LIGHT MODE: match rows ── */
html.light .match-row{background:var(--card);border-color:var(--border)}
html.light .match-row.feat{border-color:rgba(191,10,48,.4);background:rgba(191,10,48,.03)}
html.light .match-row:hover{border-color:rgba(191,10,48,.5)}

/* ── LIGHT MODE: cards ── */
html.light .card,.html.light .nbh-card,.html.light .rest-card,
html.light .step-card,html.light .surv-card{background:var(--card)}

/* ── LIGHT MODE: Texas flag overlay opacity ── */
html.light .page-hero > div[style*="opacity:0.06"],
html.light .hero > div[style*="opacity:0.09"]{filter:contrast(1.5)}

/* ── LIGHT MODE: scrollbar ── */
html.light ::-webkit-scrollbar-track{background:var(--mid)}
html.light ::-webkit-scrollbar-thumb{background:var(--dim)}

/* ── LIGHT MODE: nav links ── */
html.light .nav-links a{color:rgba(255,255,255,.7)}
html.light .nav-links a:hover,html.light .nav-links a.active{color:#fff;border-color:var(--red)}
html.light .logo{color:#fff}
html.light .logo .g{color:#fff}
html.light .logo .r{color:var(--red)}

/* ── LIGHT MODE: buttons ── */
html.light .btn-sec{color:var(--navy);border-color:rgba(0,40,104,.4)}
html.light .btn-sec:hover{background:var(--navy);color:#fff}
html.light .btn-ghost{color:var(--muted);border-color:var(--border2)}
html.light .btn-ghost:hover{color:var(--text)}
html.light .ext-link{color:var(--navy);border-color:rgba(0,40,104,.3);background:rgba(0,40,104,.04)}
html.light .ext-link:hover{background:rgba(0,40,104,.1);border-color:rgba(0,40,104,.5)}

/* ── LIGHT MODE: alert box ── */
html.light .alert-box{background:rgba(191,10,48,.05);border-color:rgba(191,10,48,.2)}

/* ── LIGHT MODE: sec-label ── */
html.light .sec-label{color:var(--navy)}

/* ── LIGHT MODE: tags ── */
html.light .tag-gold{background:rgba(0,40,104,.08);color:var(--navy);border-color:rgba(0,40,104,.2)}
html.light .tag-red{background:rgba(191,10,48,.08);color:#7A0518;border-color:rgba(191,10,48,.2)}
html.light .tag-blue{background:rgba(0,40,104,.08);color:var(--navy);border-color:rgba(0,40,104,.2)}
html.light .tag-green{background:rgba(22,101,52,.08);color:#166534;border-color:rgba(22,101,52,.2)}

/* ── LIGHT MODE: hero ── */
html.light .hero-bg{
  background:
    radial-gradient(ellipse 60% 80% at 75% 40%,rgba(191,10,48,.1) 0%,transparent 60%),
    radial-gradient(ellipse 50% 70% at 15% 60%,rgba(0,40,104,.12) 0%,transparent 55%);
}
html.light .hero-grid{
  background-image:linear-gradient(rgba(0,40,104,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(0,40,104,.04) 1px,transparent 1px);
}

/* ── LIGHT MODE: weather widget ── */
html.light .weather-card{background:rgba(0,40,104,.08);border-color:rgba(0,40,104,.2)}

/* ── LIGHT MODE: cd-bar ── */
html.light .cd-bar{background:var(--mid)}
html.light .matches-wrap{background:var(--mid)}
html.light .log-wrap{background:var(--mid)}
html.light .surv-wrap{background:var(--mid)}
html.light .checklist-wrap{background:var(--dark)}

/* ── LIGHT MODE: footer ── */
html.light footer{background:var(--dark);border-color:var(--border)}
html.light .footer-links a{color:var(--muted)}
html.light .footer-links a:hover{color:var(--navy)}

/* ── LIGHT MODE: lang switcher ── */
html.light .lang-btn{border-color:rgba(255,255,255,.3);color:rgba(255,255,255,.65)}
html.light .lang-btn:hover,html.light .lang-btn.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ══════════════════════════════════════════════════════════════
   MOBILE-FIRST RESPONSIVE SYSTEM
   Breakpoints: 480px (xs), 640px (sm), 768px (md), 1024px (lg)
   ══════════════════════════════════════════════════════════════ */

/* ── HAMBURGER MENU ── */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0}
.hamburger span{display:block;height:2px;background:#F0EDE8;border-radius:1px;
  transition:transform .25s,opacity .2s,width .2s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;width:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav drawer */
.mobile-nav-drawer{display:none;position:fixed;top:56px;left:0;right:0;bottom:0;
  background:var(--dark);z-index:190;overflow-y:auto;border-top:1px solid var(--border);
  flex-direction:column;padding:1rem 0}
.mobile-nav-drawer.open{display:flex}
.mobile-nav-link{display:block;font-family:var(--fh);font-size:1.1rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;
  padding:1rem 2rem;border-left:3px solid transparent;transition:all .15s}
.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--white);border-left-color:var(--red);
  background:rgba(191,10,48,.05)}
html.light .mobile-nav-drawer{background:var(--dark)}
html.light .mobile-nav-link:hover,html.light .mobile-nav-link.active{color:#fff}

/* ── GLOBAL MOBILE FIXES ── */
@media(max-width:768px){
  section{padding:3rem 1.25rem}
  .sec-title{margin-bottom:1.25rem}

  /* Nav: hide links and lang switcher, show hamburger */
  .nav-links{display:none !important}
  .hamburger{display:flex}
  .lang-switcher{display:none !important}
  nav{padding:0 1.25rem}

  /* Hero: stack vertically, hide aside */
  .hero-aside{display:none}
  .hero-content{padding:0 1.25rem;max-width:100%}
  .hero h1{font-size:clamp(3rem,12vw,5rem)}

  /* Countdown bar: stack */
  .cd-bar{padding:1.25rem;gap:1.25rem;flex-direction:column;align-items:flex-start}
  .cd-units{gap:.75rem}
  .cu-n{font-size:1.8rem}

  /* Match rows: 2-col layout */
  .match-row{grid-template-columns:1fr auto 1fr;gap:.5rem;padding:.85rem 1rem}
  .match-info{grid-column:1/-1;border-top:1px solid var(--border);padding-top:.5rem;margin-top:.25rem;text-align:left;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}

  /* Cards grid: single column on xs */
  .cards-grid{grid-template-columns:1fr}

  /* Page hero: tighter */
  .page-hero{padding:4.5rem 1.25rem 2rem}
  .page-hero h1{font-size:clamp(2rem,10vw,4rem)}
  .page-hero-sub{font-size:.9rem}
  .page-hero-tags{gap:6px}

  /* Breadcrumb: wrap */
  .breadcrumb{flex-wrap:wrap}

  /* Footer: stack columns */
  .footer-inner{flex-direction:column;gap:1.5rem}

  /* Map: stack sidebar above canvas */
  .map-container,.map-wrap{grid-template-columns:1fr !important;height:auto !important}
  .map-sidebar{height:auto;max-height:220px;border-right:none;border-bottom:1px solid var(--border)}
  .map-canvas{height:320px}

  /* Survival grid: single col */
  .surv-grid{grid-template-columns:1fr}

  /* Steps grid: single col */
  .steps-grid{grid-template-columns:1fr}

  /* Checklist grid: single col */
  .cl-grid,.checklist-grid{grid-template-columns:1fr}

  /* Activity grid: single col */
  .activity-grid{grid-template-columns:1fr}

  /* Neighborhoods grid: single col */
  .nbh-grid{grid-template-columns:1fr}

  /* Restaurants grid: single col */
  .rest-grid{grid-template-columns:1fr}

  /* Hero btns: stack */
  .hero-btns{flex-direction:column;gap:10px}
  .btn-prim,.btn-sec{text-align:center;width:fit-content}

  /* Info grid on detail pages: 2 col */
  .info-grid{grid-template-columns:repeat(2,1fr)}

  /* Highlights grid: 1 col */
  .highlights-grid{grid-template-columns:1fr}

  /* Option grid: 1 col */
  .option-grid{grid-template-columns:1fr}

  /* Extras grid: 2 col */
  .extras-grid{grid-template-columns:repeat(2,1fr)}

  /* Quick-links: 2 col */
  .quick-links{grid-template-columns:repeat(2,1fr)}

  /* Booking section: 1 col */
  #main-booking-widget [style*="grid-template-columns"],
  #matches-booking [style*="grid-template-columns"],
  #logistics-booking [style*="grid-template-columns"]{
    grid-template-columns:1fr !important
  }

  /* Tab bars: scrollable, smaller text */
  .tab-bar{gap:0}
  .tab{font-size:.68rem;padding:9px 12px}

  /* Page-hero Texas flag: smaller */
  .page-hero > div[style*="opacity:0.06"]{width:40% !important}

  /* Lang switcher: tighter */
  .lang-switcher{gap:2px}
  .lang-btn{padding:3px 6px;font-size:.65rem}

  /* Theme toggle */
  .theme-toggle{width:30px;height:30px;font-size:14px}
}

/* ── EXTRA SMALL ── */
@media(max-width:480px){
  section{padding:2.5rem 1rem}
  nav{padding:0 1rem}
  .hero-content{padding:0 1rem}
  .hero h1{font-size:clamp(2.8rem,14vw,4.5rem)}
  .hero-btns{flex-direction:column}
  .cd-units{gap:.5rem}
  .cu-n{font-size:1.6rem}
  .cu{min-width:38px}
  .t-name{font-size:.85rem}
  .t-flag{font-size:1.3rem;font-family:'Apple Color Emoji','Segoe UI Emoji','Noto Color Emoji','Twemoji Mozilla',sans-serif}
  .match-vs{font-size:1.1rem}
  .quick-links{grid-template-columns:1fr 1fr}
  .info-grid{grid-template-columns:1fr}
  .extras-grid{grid-template-columns:repeat(2,1fr)}
  .page-hero{padding:4rem 1rem 1.75rem}
  .page-hero-tags{display:none}
  .footer-links{flex-direction:column !important}

  /* Weather: stack current card */
  #current-conditions > div{flex-direction:column}
  .current-card{min-width:unset}
  .current-temp{font-size:3.5rem}

  /* Forecast row: tighter */
  .forecast-row{grid-template-columns:80px 32px 1fr 60px;gap:.5rem;padding:.75rem .85rem}

  /* Hourly: smaller cells */
  .hour-cell{min-width:58px;padding:.7rem .5rem}
}

/* ── MEDIUM: tablet adjustments ── */
@media(min-width:769px) and (max-width:1024px){
  .hero-aside{right:1.5rem}
  .hero-badge{width:120px;height:120px}
  .badge-num{font-size:3rem}
  .map-container,.map-wrap{grid-template-columns:220px 1fr}
  section{padding:3.5rem 1.5rem}
}

/* ── TOUCH: larger tap targets ── */
@media(hover:none){
  .tab,.mobile-nav-link,.cl-item{min-height:44px;display:flex;align-items:center}
  .match-row{cursor:default}
  .cal-link{padding:8px 14px}
  .ext-link{padding:10px 16px}
  .btn-prim,.btn-sec,.btn-ghost{padding:16px 28px}
  .lang-btn{padding:6px 10px}
  .flag-btn{min-width:36px;min-height:36px}
}

/* ── MOBILE DRAWER LIGHT MODE ── */
html.light .mobile-nav-drawer{background:#001240;border-top-color:rgba(191,10,48,.5)}
html.light .mobile-nav-link{color:rgba(255,255,255,.7)}
html.light .mobile-nav-link:hover,html.light .mobile-nav-link.active{color:#fff;border-left-color:var(--red);background:rgba(191,10,48,.08)}

/* ── MOBILE: Booking widget cards ── */
@media(max-width:640px){
  /* Force single column booking cards */
  div[id$="-booking"] > div > div[style*="grid-template-columns"]{
    display:flex !important;flex-direction:column !important;
  }
  /* Affiliate cards: full width */
  div[id$="-booking"] a[href]{display:block !important}
  /* Match flight CTA: stack buttons */
  div[id^="match-cta"] > div > div:last-child{flex-direction:column !important}
  /* Progress bar: tighter */
  .cl-progress,.prog-bar-wrap{flex-wrap:wrap}
  /* Hourly weather: scroll hint */
  .hourly-scroll{-webkit-overflow-scrolling:touch}
  .hourly-scroll::after{content:'';position:absolute;right:0;top:0;bottom:0;
    width:32px;background:linear-gradient(90deg,transparent,var(--dark));pointer-events:none}
}

/* ── TAP HIGHLIGHT: remove on all interactive elements ── */
a,button,.tab,.cl-item,.match-row,.nbh-card,.rest-card,.activity-card,
.neighborhood,.ql-card,.card-link{-webkit-tap-highlight-color:transparent}

/* ── SAFE AREA: iPhone notch/home bar ── */
nav{padding-left:max(2rem,env(safe-area-inset-left));
    padding-right:max(2rem,env(safe-area-inset-right))}
footer{padding-bottom:max(2.5rem,env(safe-area-inset-bottom))}
.mobile-nav-drawer{padding-bottom:max(1rem,env(safe-area-inset-bottom))}

html.light .hamburger span{background:#fff}

/* ── DESKTOP NAV ALWAYS VISIBLE ── */
@media(min-width:769px){
  .nav-links{display:flex !important}
  .hamburger{display:none !important}
}
