/* ============================================================
   WHOLE TEXAS — vintage highway-map / WPA travel-poster system
   Fonts: Staatliches (display) + Bitter (body serif)
   Themes: html.t-sunrise (default) | t-noon | t-bluebonnet
           | t-honkytonk | t-bigbend
   ============================================================ */

/* ---------- THEME 1 · SUNRISE DRIVE (default flagship) ----------
   Sun-faded paper map at 7 AM on FM 1431. Burnt orange, sepia ink. */
html.t-sunrise{
  --paper:#f3e9d2; --paper2:#faf3e0; --card:#fbf5e4;
  --ink:#3a2a1c; --ink2:#6b573f; --faded:#94805f;
  --accent:#bf5700; --accent2:#1f6f6b; --gold:#c08a23;
  --line:#3a2a1c; --rule:#cdb98e; --shadow:rgba(58,42,28,.22);
  --pickbg:rgba(58,42,28,.92); --pickink:#f3e9d2;
}
/* ---------- THEME 2 · HIGH NOON ----------
   Bleached courthouse-square light. Hard black, vermillion, no mercy. */
html.t-noon{
  --paper:#f8f4e9; --paper2:#fffdf4; --card:#fffcf0;
  --ink:#181410; --ink2:#4a4138; --faded:#857a6b;
  --accent:#b3202c; --accent2:#28618c; --gold:#a87b1d;
  --line:#181410; --rule:#d9d0ba; --shadow:#181410;
  --pickbg:rgba(24,20,16,.94); --pickink:#f8f4e9;
}
/* ---------- THEME 3 · BLUEBONNET ----------
   April morning in the Hill Country. Pale sky, indigo ink, soft. */
html.t-bluebonnet{
  --paper:#e9eef6; --paper2:#f5f8fc; --card:#fbfcfe;
  --ink:#22304e; --ink2:#4a5a7d; --faded:#7d8aa6;
  --accent:#2b50aa; --accent2:#4a7c3a; --gold:#b98a2e;
  --line:#22304e; --rule:#bcc8dd; --shadow:rgba(43,80,170,.16);
  --pickbg:rgba(34,48,78,.92); --pickink:#e9eef6;
}
/* ---------- THEME 4 · HONKY-TONK NEON ----------
   Broken Spoke parking lot, 11:40 PM. Neon pink, cyan, marquee amber. */
html.t-honkytonk{
  --paper:#160f1d; --paper2:#1e1527; --card:#241a2f;
  --ink:#f5eaf6; --ink2:#cdb6d3; --faded:#8d7795;
  --accent:#ff4f9a; --accent2:#3be8e0; --gold:#ffb52e;
  --line:#54405f; --rule:#3a2b45; --shadow:rgba(255,79,154,.14);
  --pickbg:rgba(20,13,27,.94); --pickink:#f5eaf6;
}
/* ---------- THEME 5 · BIG BEND NIGHT ----------
   Darkest skies in North America. Navy ink, starlight cream, copper. */
html.t-bigbend{
  --paper:#0f1622; --paper2:#15202f; --card:#192536;
  --ink:#ece4cf; --ink2:#bfb49a; --faded:#83796a;
  --accent:#c87f4a; --accent2:#8fb4c9; --gold:#d9b45a;
  --line:#3e526b; --rule:#283a4f; --shadow:rgba(0,0,0,.45);
  --pickbg:rgba(10,16,26,.94); --pickink:#ece4cf;
}

/* ---------------- base ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--paper)}
body{
  font-family:'Bitter',Georgia,'Times New Roman',serif;
  background:var(--paper);color:var(--ink);
  line-height:1.75;font-size:16.5px;overflow-x:hidden;
  transition:background .3s,color .3s;
}
/* paper grain + vignette */
body::before{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    repeating-linear-gradient(0deg,transparent 0 2px,rgba(0,0,0,.014) 2px 3px),
    repeating-linear-gradient(90deg,transparent 0 3px,rgba(0,0,0,.01) 3px 4px),
    radial-gradient(ellipse at 50% 0%,rgba(255,255,255,.05),transparent 55%),
    radial-gradient(ellipse at 50% 115%,rgba(0,0,0,.07),transparent 60%);
}
html.t-bigbend body::before{
  background:
    radial-gradient(1px 1px at 12% 18%,rgba(236,228,207,.7),transparent 100%),
    radial-gradient(1px 1px at 31% 7%,rgba(236,228,207,.5),transparent 100%),
    radial-gradient(1.5px 1.5px at 47% 23%,rgba(236,228,207,.65),transparent 100%),
    radial-gradient(1px 1px at 63% 11%,rgba(236,228,207,.45),transparent 100%),
    radial-gradient(1px 1px at 78% 28%,rgba(236,228,207,.6),transparent 100%),
    radial-gradient(1.5px 1.5px at 89% 9%,rgba(236,228,207,.5),transparent 100%),
    radial-gradient(1px 1px at 22% 41%,rgba(236,228,207,.35),transparent 100%),
    radial-gradient(1px 1px at 70% 46%,rgba(236,228,207,.3),transparent 100%),
    radial-gradient(ellipse at 50% -10%,rgba(143,180,201,.07),transparent 55%);
}
html.t-honkytonk body::before{
  background:
    radial-gradient(ellipse at 18% 0%,rgba(255,79,154,.10),transparent 45%),
    radial-gradient(ellipse at 85% 8%,rgba(59,232,224,.08),transparent 40%),
    radial-gradient(ellipse at 50% 110%,rgba(255,181,46,.06),transparent 55%);
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}
img{max-width:100%}
strong{color:var(--ink)}
::selection{background:var(--accent);color:var(--paper2)}

/* ---------------- display type ---------------- */
h1,h2,h3,.disp{font-family:'Staatliches','Arial Narrow',sans-serif;font-weight:400;letter-spacing:.045em;line-height:1.08;color:var(--ink)}
html.t-honkytonk h1,html.t-honkytonk .hero .star{text-shadow:0 0 18px rgba(255,79,154,.5)}
html.t-honkytonk h2{text-shadow:0 0 12px rgba(59,232,224,.3)}

/* ---------------- fixed masthead ---------------- */
.tx-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--paper2);
  border-bottom:3px double var(--line);
  padding:9px 18px;
  display:flex;align-items:center;justify-content:center;gap:6px 18px;flex-wrap:wrap;
}
.tx-brand{font-family:'Staatliches',sans-serif;font-size:1.3rem;letter-spacing:.07em;color:var(--ink);white-space:nowrap;text-decoration:none}
.tx-brand:hover{text-decoration:none}
.tx-brand .st{color:var(--accent)}
.tx-links{display:flex;align-items:center;gap:2px 14px;flex-wrap:wrap;justify-content:center}
.tx-links a{
  font-family:'Staatliches',sans-serif;font-size:.92rem;letter-spacing:.09em;
  color:var(--ink2);text-transform:uppercase;padding:2px 2px;border-bottom:2px solid transparent;
}
.tx-links a:hover,.tx-links a[aria-current="page"]{color:var(--accent);border-bottom:2px dashed var(--accent);text-decoration:none}

/* ---------------- hero ---------------- */
.hero{padding:64px 22px 40px;text-align:center;border-bottom:3px double var(--line);position:relative;background:linear-gradient(180deg,var(--paper2),var(--paper))}
.hero .kick{font-family:'Staatliches',sans-serif;font-size:.95rem;letter-spacing:.34em;text-transform:uppercase;color:var(--accent2);display:block;margin-bottom:14px}
.hero h1{font-size:clamp(2.7rem,8vw,5.2rem);text-transform:uppercase;margin:0 auto 10px;max-width:1000px}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero .sub{font-style:italic;color:var(--ink2);font-size:clamp(1rem,1.7vw,1.18rem);max-width:680px;margin:0 auto;line-height:1.7}
.hero .star{color:var(--gold);font-size:1.5rem;letter-spacing:.7em;display:block;margin-top:18px}

/* route-marker badge (old Texas highway shield, circular) */
.rm{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  width:78px;height:78px;border:3.5px solid var(--ink);border-radius:50%;
  background:var(--paper2);box-shadow:0 0 0 3px var(--paper2),0 0 0 4.5px var(--ink);
  font-family:'Staatliches',sans-serif;color:var(--ink);line-height:1;margin-bottom:18px;
}
.rm small{font-size:.58rem;letter-spacing:.18em}
.rm b{font-size:1.5rem;font-weight:400}
.rm-sm{width:52px;height:52px;border-width:2.5px;box-shadow:0 0 0 2px var(--paper2),0 0 0 3.5px var(--ink);margin:0}
.rm-sm small{font-size:.46rem}
.rm-sm b{font-size:1.02rem}

/* ---------------- sections + dashed route dividers ---------------- */
.wrap{max-width:1060px;margin:0 auto;padding:0 22px}
.sect{padding:52px 0 44px}
.sect-head{display:flex;align-items:center;gap:16px;margin-bottom:8px;flex-wrap:wrap}
.sect h2{font-size:clamp(1.7rem,3.4vw,2.4rem);text-transform:uppercase}
.sect h2 .no{color:var(--accent)}
.sect .lede{color:var(--ink2);font-style:italic;margin:4px 0 26px;max-width:760px}
.route-div{position:relative;height:0;border-top:4px dashed var(--accent);margin:8px auto;max-width:880px}
.route-div::after{
  content:'\2605';position:absolute;left:50%;top:0;transform:translate(-50%,-58%);
  font-size:1.05rem;color:var(--gold);background:var(--paper);padding:0 16px;line-height:1;
}
html.t-honkytonk .route-div{border-top-color:var(--accent2)}

/* ---------------- stop cards (the grid) ---------------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px;margin:8px 0}
.stop{
  background:var(--card);border:1.5px solid var(--line);border-radius:6px;
  padding:20px 22px 18px;box-shadow:5px 5px 0 var(--shadow);
  transition:transform .15s,box-shadow .15s;position:relative;
}
.stop:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--shadow)}
.stop h3{font-size:1.25rem;text-transform:uppercase;color:var(--accent);margin-bottom:8px;letter-spacing:.06em}
.stop h3 a{color:inherit}
.stop p{font-size:.92rem;color:var(--ink2);line-height:1.7}
.stop .tag{font-family:'Staatliches',sans-serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent2);display:block;margin-bottom:4px}
/* theme-specific card moods */
html.t-noon .stop{box-shadow:6px 6px 0 var(--shadow);border-width:2px}
html.t-noon .stop:hover{box-shadow:9px 9px 0 var(--shadow)}
html.t-bluebonnet .stop{border-radius:16px;border-width:1px;box-shadow:0 10px 26px var(--shadow)}
html.t-bluebonnet .stop:hover{box-shadow:0 16px 34px var(--shadow)}
html.t-honkytonk .stop{border-color:var(--line);box-shadow:0 0 0 1px var(--rule),0 0 20px var(--shadow)}
html.t-honkytonk .stop:hover{box-shadow:0 0 0 1px var(--accent),0 0 26px var(--shadow)}
html.t-bigbend .stop{box-shadow:0 14px 30px var(--shadow);border-color:var(--rule)}

/* alternating band */
.band{background:var(--paper2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}

/* ---------------- long-form article pages ---------------- */
.art{max-width:760px;margin:0 auto;padding:44px 22px 60px}
.art h1{font-size:clamp(2.1rem,5.5vw,3.1rem);text-transform:uppercase;margin-bottom:10px}
.art h2{font-size:1.55rem;text-transform:uppercase;margin:38px 0 12px;padding-bottom:8px;border-bottom:3px dashed var(--rule)}
.art p{margin-bottom:16px;color:var(--ink2)}
.art ul{margin:0 0 16px 26px;color:var(--ink2)}
.art li{margin-bottom:7px}

/* ---------------- buttons ---------------- */
.btn{
  display:inline-block;font-family:'Staatliches',sans-serif;font-size:1rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--paper2);background:var(--accent);border:2px solid var(--accent);
  padding:10px 26px;border-radius:4px;box-shadow:4px 4px 0 var(--shadow);text-decoration:none;
}
.btn:hover{text-decoration:none;transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--shadow)}
.btn-ghost{background:transparent;color:var(--accent)}

/* ---------------- FAQ ---------------- */
.faq{margin-bottom:14px;background:var(--card);border:1.5px solid var(--line);border-radius:6px;overflow:hidden;box-shadow:4px 4px 0 var(--shadow)}
.faq-q{padding:16px 20px;cursor:pointer;font-family:'Staatliches',sans-serif;font-size:1.08rem;letter-spacing:.05em;display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--ink)}
.faq-q .arrow{color:var(--accent);transition:transform .2s;flex:none}
.faq.open .arrow{transform:rotate(180deg)}
.faq-a{padding:0 20px 18px;font-size:.93rem;color:var(--ink2);line-height:1.75;display:none}
.faq.open .faq-a{display:block}

/* ---------------- video ledger ---------------- */
.vid-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px;margin:18px 0}
.vid{background:var(--card);border:1.5px solid var(--line);border-radius:6px;overflow:hidden;box-shadow:5px 5px 0 var(--shadow)}
.vid iframe{width:100%;aspect-ratio:16/9;border:none;display:block;background:#000}
.vid-info{padding:13px 16px 14px;display:flex;gap:13px;align-items:flex-start}
.vid-rank{font-family:'Staatliches',sans-serif;font-size:1.5rem;color:var(--accent);border:2.5px solid var(--accent);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;flex:none;line-height:1;background:var(--paper2)}
.vid-title{font-weight:700;font-size:.95rem;line-height:1.4;color:var(--ink)}
.vid-meta{font-size:.76rem;color:var(--faded);margin-top:4px;font-style:italic}

/* ---------------- sources ledger ---------------- */
.src{background:var(--card);border:1.5px solid var(--line);border-left:6px solid var(--accent);border-radius:6px;padding:16px 20px;margin-bottom:12px;box-shadow:4px 4px 0 var(--shadow)}
.src h3{font-size:1.15rem;text-transform:uppercase;letter-spacing:.05em}
.src h3 a{color:var(--accent)}
.src .url{font-size:.76rem;color:var(--faded);letter-spacing:.03em;margin:1px 0 6px;word-break:break-all}
.src p{font-size:.92rem;color:var(--ink2);line-height:1.65}

/* ---------------- footer ---------------- */
.tx-foot{border-top:3px double var(--line);margin-top:34px;padding:30px 22px 36px;text-align:center;background:var(--paper2)}
.tx-foot .flag{font-family:'Staatliches',sans-serif;letter-spacing:.18em;text-transform:uppercase;font-size:1.02rem;color:var(--ink);margin-bottom:8px}
.tx-foot .flag .st{color:var(--accent)}
.tx-foot p{font-size:.82rem;color:var(--faded);margin-bottom:6px}
.tx-foot a{color:var(--accent2)}
.tx-foot .rule{max-width:240px;margin:0 auto 16px;border-top:4px dashed var(--rule)}

/* network strip on home */
.netstrip{text-align:center;padding:20px 22px;border-top:1px solid var(--rule);display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;background:var(--paper2)}
.netstrip .lbl{font-family:'Staatliches',sans-serif;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--faded)}
.netstrip a{font-size:.83rem;white-space:nowrap;color:var(--accent2)}

/* ---------------- theme picker ---------------- */
#tx-picker{
  position:fixed;right:14px;bottom:14px;z-index:2147483600;
  display:flex;align-items:center;gap:3px;padding:7px 10px;border-radius:999px;
  background:var(--pickbg);border:1.5px solid var(--gold);
  box-shadow:0 8px 28px rgba(0,0,0,.45);
  max-width:calc(100vw - 20px);overflow-x:auto;scrollbar-width:none;
}
#tx-picker::-webkit-scrollbar{display:none}
#tx-picker .pl{font-family:'Staatliches',sans-serif;font-size:.78rem;letter-spacing:.18em;color:var(--gold);padding:0 8px;white-space:nowrap;text-transform:uppercase}
#tx-picker button{
  cursor:pointer;white-space:nowrap;font-family:'Staatliches',sans-serif;font-size:.85rem;letter-spacing:.07em;
  color:var(--pickink);background:transparent;border:1.5px solid transparent;border-radius:999px;padding:5px 13px;line-height:1.1;
}
#tx-picker button:hover{border-color:var(--pickink)}
#tx-picker button[aria-current="true"]{background:var(--accent);border-color:var(--accent);color:#fff}
@media(max-width:620px){#tx-picker .pl{display:none}}

/* ---------------- misc ---------------- */
@media(max-width:640px){
  .grid{grid-template-columns:1fr}
  .vid-list{grid-template-columns:1fr}
  .hero{padding:44px 16px 32px}
  body{font-size:15.5px}
}
