/* ───────────────────────────────────────────────────────────────────────────
   The Big Mads Go West — Journey Tracker
   Arcanum & Crow design system: ink / antique gold / parchment,
   Times + Helvetica + Courier, brutalist chrome, crows for warmth.
   ─────────────────────────────────────────────────────────────────────────── */

/* OPTIONAL exact web fonts. Uncomment after running tools/fetch_fonts.sh and
   placing the woff2 files in /fonts. Without these, the system stack below
   (Times New Roman / Arial / Courier New) is used — same field-manual intent.
@font-face{font-family:'Tinos';src:url('/fonts/tinos-regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Tinos';src:url('/fonts/tinos-bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Arimo';src:url('/fonts/arimo-regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Arimo';src:url('/fonts/arimo-bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Cousine';src:url('/fonts/cousine-regular.woff2') format('woff2');font-weight:400;font-display:swap}
*/

:root{
  --ink:#16161d; --ink-soft:#2a2a35; --ink-lite:#4a4a55;
  --gold:#b08d4c; --gold-deep:#8c6f3b; --gold-lite:#d4b87a;
  --parchment:#f4efe4; --cream:#faf7f0; --muted:#6a6a72;
  --serif:'Tinos','Times New Roman',Times,serif;
  --sans:'Arimo',Arial,Helvetica,sans-serif;
  --mono:'Cousine','Courier New',monospace;
  --shadow-hard:5px 5px 0 var(--gold);
  --shadow-hard-ink:4px 4px 0 var(--ink);
  --hdr-h:54px;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:var(--serif); color:var(--ink); background:var(--cream);
  -webkit-text-size-adjust:100%; overflow:hidden;
}
button{font-family:var(--sans);cursor:pointer}
a{color:var(--gold-deep)}

.kicker{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;
  font-size:11px;color:var(--gold-deep);font-weight:700}
.diamond{color:var(--gold)}
.diamond::before{content:"\25C6"}

/* ── App shell ──────────────────────────────────────────────────────────── */
#app{display:flex;flex-direction:column;height:100%}

header.field-header{
  height:var(--hdr-h); flex:0 0 auto; background:var(--ink); color:var(--cream);
  display:flex; align-items:center; gap:12px; padding:0 14px;
  border-bottom:3px solid var(--gold); position:relative; z-index:30;
}
header .crow-perch{width:40px;height:34px;color:var(--cream);flex:0 0 auto}
header .titles{display:flex;flex-direction:column;line-height:1;min-width:0}
header .titles .t-main{font-family:var(--serif);font-weight:700;font-size:17px;
  letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
header .titles .t-sub{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-lite);margin-top:3px}
header .spacer{flex:1 1 auto}
header .hdr-status{font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  color:var(--gold-lite);text-align:right;white-space:nowrap}
header .hdr-status .leg-now{color:var(--cream);font-size:12px}

/* ── Body: map + panel ──────────────────────────────────────────────────── */
.body-row{flex:1 1 auto;display:flex;min-height:0;position:relative}
#map{flex:1 1 auto;min-width:0;background:var(--parchment)}
.maplibregl-ctrl-attrib{font-family:var(--sans);font-size:9px}

/* Panel (legend + gallery) */
aside.panel{
  flex:0 0 320px; background:var(--parchment); border-left:3px solid var(--ink);
  display:flex; flex-direction:column; overflow:hidden; z-index:20;
}
.panel-tabs{display:flex;border-bottom:2px solid var(--ink);flex:0 0 auto}
.panel-tabs button{
  flex:1; background:var(--cream); border:none; border-right:2px solid var(--ink);
  padding:9px 6px; font-family:var(--mono); text-transform:uppercase;
  letter-spacing:.1em; font-size:10px; font-weight:700; color:var(--ink-lite);
}
.panel-tabs button:last-child{border-right:none}
.panel-tabs button[aria-selected="true"]{background:var(--ink);color:var(--gold-lite)}
.panel-body{flex:1 1 auto;overflow-y:auto;padding:12px}

/* Legend rows */
.legend-row{
  display:grid;grid-template-columns:26px 18px 1fr auto;align-items:center;gap:8px;
  padding:8px;border:2px solid var(--ink);background:var(--cream);
  margin-bottom:8px;box-shadow:var(--shadow-hard-ink);transition:transform .08s;
}
.legend-row:hover{transform:translate(-1px,-1px)}
.legend-row:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}
.legend-row.is-active{background:var(--ink);color:var(--cream)}
.legend-row.is-active .lg-name{color:var(--cream)}
.legend-row.is-done{opacity:.92}
.lg-roman{font-family:var(--serif);font-weight:700;font-size:16px;text-align:center;
  color:var(--gold-deep)}
.legend-row.is-active .lg-roman{color:var(--gold-lite)}
.lg-swatch{height:6px;border-radius:0;width:100%}
.lg-name{font-family:var(--serif);font-size:13px;line-height:1.15}
.lg-miles{font-family:var(--mono);font-size:10px;color:var(--muted)}
.legend-row.is-active .lg-miles{color:var(--gold-lite)}
.lg-daytrip .lg-roman{color:var(--muted)}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gal-item{border:2px solid var(--ink);background:var(--ink);position:relative;
  aspect-ratio:1;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-hard-ink)}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block}
.gal-item .gal-meta{position:absolute;left:0;right:0;bottom:0;background:rgba(22,22,29,.82);
  color:var(--cream);font-family:var(--mono);font-size:8.5px;padding:3px 4px;
  letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.empty-state{text-align:center;color:var(--ink-lite);padding:26px 10px}
.empty-state .crow{width:70px;height:60px;color:var(--ink-soft);margin:0 auto 10px}
.empty-state p{font-family:var(--serif);font-style:italic;font-size:14px;margin:0}

/* ── Floating actions ───────────────────────────────────────────────────── */
.fab-stack{position:absolute;right:18px;bottom:20px;display:flex;flex-direction:column;
  gap:10px;z-index:25;align-items:flex-end}
.btn{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-weight:700;
  font-size:12px;border:3px solid var(--ink);padding:11px 16px;background:var(--gold);
  color:var(--ink);box-shadow:var(--shadow-hard-ink);display:inline-flex;align-items:center;
  gap:8px;transition:transform .08s;
}
.btn:hover{transform:translate(-1px,-1px)}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.btn.btn-ink{background:var(--ink);color:var(--gold-lite)}
.btn.btn-quiet{background:var(--cream);font-size:10px;padding:8px 12px}
.btn .b-crow{width:18px;height:16px;color:currentColor}
.btn[disabled]{opacity:.5;pointer-events:none}

.driver-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--cream);
  border:3px solid var(--ink);box-shadow:var(--shadow-hard-ink);padding:7px 11px;
  font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em}
.driver-toggle.on{background:var(--ink);color:var(--gold-lite)}
.dot{width:9px;height:9px;border:2px solid var(--ink);background:var(--cream)}
.driver-toggle.on .dot{background:#6bbf6b;border-color:var(--gold-lite);
  box-shadow:0 0 0 0 rgba(107,191,107,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(107,191,107,.6)}
  70%{box-shadow:0 0 0 7px rgba(107,191,107,0)}100%{box-shadow:0 0 0 0 rgba(107,191,107,0)}}

/* ── Map markers ────────────────────────────────────────────────────────── */
.photo-marker{width:34px;height:34px;color:var(--ink);transition:transform .12s}
.photo-marker:hover{transform:scale(1.15)}
.photo-marker.hop{animation:hop .5s ease}
@keyframes hop{0%{transform:translateY(0)}30%{transform:translateY(-12px) rotate(-6deg)}
  60%{transform:translateY(0)}75%{transform:translateY(-4px)}100%{transform:translateY(0)}}
.live-crow{width:38px;height:38px;color:var(--ink);filter:drop-shadow(2px 2px 0 var(--gold));
  animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.fly-crow{width:30px;height:30px;color:var(--gold-deep);
  filter:drop-shadow(1px 1px 0 rgba(22,22,29,.25))}

/* maplibre popup themed */
.maplibregl-popup-content{
  background:var(--cream);border:3px solid var(--ink);border-radius:0;
  box-shadow:var(--shadow-hard);padding:0;font-family:var(--serif);max-width:240px}
.maplibregl-popup-tip{border-top-color:var(--ink)!important}
.maplibregl-popup-close-button{font-size:18px;color:var(--ink);padding:0 6px}
.pop img{width:100%;display:block;border-bottom:2px solid var(--ink);max-height:180px;object-fit:cover}
.pop .pop-body{padding:9px 11px}
.pop .pop-cap{font-size:14px;line-height:1.3;margin:0 0 5px}
.pop .pop-meta{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;color:var(--muted);
  text-transform:uppercase}
.pop .pop-actions{display:flex;gap:6px;margin-top:8px}
.pop .pop-actions button{font-family:var(--mono);font-size:9px;text-transform:uppercase;
  letter-spacing:.06em;border:2px solid var(--ink);background:var(--cream);padding:4px 7px}
.pop .pop-actions button.danger{background:var(--ink);color:var(--gold-lite)}

/* ── Login gate / modals ────────────────────────────────────────────────── */
.scrim{position:fixed;inset:0;background:rgba(22,22,29,.86);display:flex;
  align-items:center;justify-content:center;z-index:100;padding:20px}
.scrim[hidden]{display:none}
.card{
  background:var(--cream);border:3px solid var(--ink);box-shadow:var(--shadow-hard);
  max-width:380px;width:100%;padding:26px 24px;text-align:center}
.card .crow-seal{width:84px;height:74px;color:var(--ink);margin:0 auto 4px}
.card h1{font-family:var(--serif);font-weight:700;font-size:26px;margin:6px 0 2px}
.card .sub{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:18px}
.card .rule{height:0;border-top:1px solid var(--gold);border-bottom:1px solid var(--gold);
  width:120px;margin:14px auto;opacity:.8}
.card label{display:block;text-align:left;font-family:var(--mono);font-size:10px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink-lite);margin:0 0 5px}
.card input{width:100%;font-family:var(--serif);font-size:16px;padding:11px 12px;
  border:2px solid var(--ink);background:var(--parchment);border-radius:0;margin-bottom:14px}
.card input:focus{outline:3px solid var(--gold-lite);outline-offset:1px}
.card .btn{width:100%;justify-content:center}
.card .err{color:#9a3b3b;font-family:var(--sans);font-size:12px;min-height:16px;margin-top:8px}
.card .hint{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--muted);margin-top:14px}

/* ── Loading crow ───────────────────────────────────────────────────────── */
.loader{position:fixed;inset:0;background:var(--ink);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;z-index:200;color:var(--cream)}
.loader[hidden]{display:none}
.loader .spin-crow{width:84px;height:84px;color:var(--cream)}
.loader .spin-crow .wing-l{transform-origin:44px 46px;animation:flapL 0.5s ease-in-out infinite}
.loader .spin-crow .wing-r{transform-origin:56px 46px;animation:flapR 0.5s ease-in-out infinite}
@keyframes flapL{0%,100%{transform:rotate(0)}50%{transform:rotate(16deg)}}
@keyframes flapR{0%,100%{transform:rotate(0)}50%{transform:rotate(-16deg)}}
.loader .l-text{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-lite)}

/* ── Banner (demo basemap / offline) ────────────────────────────────────── */
.banner{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:28;
  background:var(--ink);color:var(--cream);border:2px solid var(--gold);
  font-family:var(--mono);font-size:10px;letter-spacing:.05em;padding:6px 12px;
  box-shadow:var(--shadow-hard);display:flex;gap:10px;align-items:center;max-width:90%}
.banner[hidden]{display:none}
.banner button{background:none;border:none;color:var(--gold-lite);font-weight:700;cursor:pointer}
.banner.offline{border-color:#c98a3a}

/* idle peek crow */
.peek-crow{position:absolute;right:-46px;bottom:90px;width:60px;height:52px;color:var(--ink-soft);
  z-index:24;pointer-events:none;transition:right .6s cubic-bezier(.2,.8,.2,1)}
.peek-crow.show{right:6px}

/* ── Mobile ─────────────────────────────────────────────────────────────── */
@media (max-width:760px){
  :root{--hdr-h:48px}
  .body-row{flex-direction:column}
  aside.panel{flex:0 0 auto;height:42vh;border-left:none;border-top:3px solid var(--ink);
    order:2;transition:height .25s}
  aside.panel.collapsed{height:42px}
  #map{order:1;min-height:0}
  .gallery-grid{grid-template-columns:1fr 1fr 1fr}
  header .titles .t-sub{display:none}
  .fab-stack{right:12px;bottom:calc(42vh + 12px)}
  .peek-crow{display:none}
}

/* ── Reduced motion ─────────────────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
