/*
 * World Cup 2026 Travel Companion
 * Premium Design System — Stripe / Airbnb quality
 * Fonts: Inter (body), JetBrains Mono (numbers/code)
 * Architecture: CSS custom properties, light/dark themes, fluid responsive
 */


/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */

:root {
  /* Typography */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', 'Consolas', monospace;

  /* Spacing scale (4px base) */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* Border radius */
  --radius-sm: 6px;
  --radius: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-pill: 100px;

  /* Transitions */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-smooth: 350ms var(--ease-out);

  /* Layout */
  --sidebar-width: 220px;
  --sidebar-collapsed: 48px;
  --chat-width: 380px;
}


/* ==========================================================================
   2. LIGHT THEME
   ========================================================================== */

[data-theme="light"] {
  --bg-page: #f8f9fa;
  --bg-card: #ffffff;
  --bg-elevated: #ffffff;
  --bg-hover: #f1f2f4;
  --bg-input: #ffffff;
  --bg-sidebar: #ffffff;
  --bg-subtle: #f3f4f6;

  --border: #e6e6e6;
  --border-strong: #d0d0d0;

  --text-primary: #1a1a2e;
  --text-secondary: #4a4a5a;
  --text-muted: #94949e;
  --text-inverse: #ffffff;

  --accent: #635bff;
  --accent-hover: #5851db;
  --accent-subtle: rgba(99, 91, 255, 0.07);
  --accent-border: rgba(99, 91, 255, 0.18);

  --green: #0a7c42;
  --green-subtle: rgba(10, 124, 66, 0.06);
  --green-border: rgba(10, 124, 66, 0.16);
  --green-text: #0a7c42;

  --blue: #2563eb;
  --blue-subtle: rgba(37, 99, 235, 0.07);
  --blue-border: rgba(37, 99, 235, 0.16);
  --blue-text: #1d4ed8;

  --amber: #c27803;
  --amber-subtle: rgba(194, 120, 3, 0.07);
  --amber-border: rgba(194, 120, 3, 0.16);
  --amber-text: #92400e;

  --red: #dc2626;

  --shadow-xs: 0 0 0 1px rgba(0,0,0,0.04);
  --shadow-sm: 0 0 0 1px rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.04), 0 4px 16px rgba(0,0,0,0.04);
  --shadow-md: 0 0 0 1px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.06);
  --shadow-lg: 0 0 0 1px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.08), 0 16px 48px rgba(0,0,0,0.06);
  --shadow-xl: 0 0 0 1px rgba(0,0,0,0.04), 0 16px 48px rgba(0,0,0,0.1), 0 32px 64px rgba(0,0,0,0.06);
  --shadow-chat: -4px 0 24px rgba(0,0,0,0.08), -1px 0 0 rgba(0,0,0,0.06);
}


/* ==========================================================================
   3. DARK THEME
   ========================================================================== */

[data-theme="dark"] {
  --bg-page: #0a0a14;
  --bg-card: #141422;
  --bg-elevated: #1a1a2e;
  --bg-hover: #1e1e32;
  --bg-input: #141422;
  --bg-sidebar: #0e0e1a;
  --bg-subtle: #16162a;

  --border: #2a2a3e;
  --border-strong: #3a3a50;

  --text-primary: #e8e8ed;
  --text-secondary: #a0a0b0;
  --text-muted: #606070;
  --text-inverse: #0a0a14;

  --accent: #7c75ff;
  --accent-hover: #6e66f0;
  --accent-subtle: rgba(124, 117, 255, 0.1);
  --accent-border: rgba(124, 117, 255, 0.22);

  --green: #34d399;
  --green-subtle: rgba(52, 211, 153, 0.08);
  --green-border: rgba(52, 211, 153, 0.2);
  --green-text: #6ee7b7;

  --blue: #60a5fa;
  --blue-subtle: rgba(96, 165, 250, 0.08);
  --blue-border: rgba(96, 165, 250, 0.2);
  --blue-text: #93c5fd;

  --amber: #fbbf24;
  --amber-subtle: rgba(251, 191, 36, 0.08);
  --amber-border: rgba(251, 191, 36, 0.2);
  --amber-text: #fcd34d;

  --red: #f87171;

  --shadow-xs: 0 0 0 1px rgba(255,255,255,0.04);
  --shadow-sm: 0 0 0 1px rgba(255,255,255,0.04), 0 2px 8px rgba(0,0,0,0.2);
  --shadow-md: 0 0 0 1px rgba(255,255,255,0.04), 0 4px 12px rgba(0,0,0,0.3);
  --shadow-lg: 0 0 0 1px rgba(255,255,255,0.04), 0 8px 24px rgba(0,0,0,0.4);
  --shadow-xl: 0 0 0 1px rgba(255,255,255,0.04), 0 16px 48px rgba(0,0,0,0.5);
  --shadow-chat: -4px 0 24px rgba(0,0,0,0.4), -1px 0 0 rgba(255,255,255,0.04);
}


/* ==========================================================================
   4. RESET & BASE TYPOGRAPHY
   ========================================================================== */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* base additions (replacing what the legacy sheet provided) */
body { line-height: 1.6; }
a { color: var(--accent); }
h1,h2,h3,h4 { line-height: 1.25; letter-spacing: -0.02em; }


/* ================= WC26 LIVE REDESIGN (mobile-first) ================= */
/* ============================================================
   WC26 LIVE — mobile-first shell. Reuses existing :root tokens.
   Accent additions for World-Cup flavor:
   ============================================================ */
:root{
  --pitch: #0a7c42;            /* football pitch green */
  --pitch-bright: #16c172;
  --electric: #7c75ff;        /* matches existing --accent (dark) */
  --hot: #ff5a36;             /* energetic call-to-action */
  --appbar-h: 56px;
  --bottomnav-h: 64px;
  --safe-b: env(safe-area-inset-bottom, 0px);
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;}
body.app{
  background:var(--bg-page);
  color:var(--text-primary);
  font-family:var(--font-sans);
  -webkit-font-smoothing:antialiased;
  padding-bottom:calc(var(--bottomnav-h) + var(--safe-b));
}

/* ---------- TOP APP BAR ---------- */
.appbar{
  position:sticky;top:0;z-index:50;
  height:var(--appbar-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
  background:color-mix(in srgb, var(--bg-page) 88%, transparent);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--border);
}
.appbar-brand{font-weight:800;letter-spacing:-.03em;font-size:1.15rem;display:flex;align-items:center;gap:6px;}
.brand-26{color:var(--electric);}
.brand-live{font-size:.55rem;font-weight:700;letter-spacing:.12em;color:#fff;background:var(--hot);padding:2px 6px;border-radius:4px;}
.countdown-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:100px;
  background:var(--bg-card);border:1px solid var(--border);
  text-decoration:none;color:var(--text-secondary);
}
.chip-dot{width:8px;height:8px;border-radius:50%;background:var(--pitch-bright);box-shadow:0 0 0 0 var(--pitch-bright);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,193,114,.5);}70%{box-shadow:0 0 0 7px rgba(22,193,114,0);}100%{box-shadow:0 0 0 0 rgba(22,193,114,0);}}
.chip-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);}
.chip-value{font-family:var(--font-mono);font-weight:700;font-size:.85rem;color:var(--text-primary);}

/* ---------- SCREENS ---------- */
.screens{padding:12px 14px 24px;max-width:680px;margin:0 auto;}
.screen{display:none;animation:fade .25s ease;}
.screen.active{display:block;}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.screen-title{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin:6px 0 16px;}
.model-badge{font-family:var(--font-mono);font-size:.55rem;color:var(--electric);border:1px solid var(--accent-border);padding:2px 7px;border-radius:100px;vertical-align:middle;}

/* ---------- NOW STRIP ---------- */
.now-strip{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:10px;
  background:linear-gradient(135deg,var(--pitch) 0%, #0c6a3a 100%);
  color:#eafff3;border-radius:16px;padding:14px 16px;margin-bottom:14px;
}
.now-kicker{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;opacity:.8;}
.now-place,.now-game{font-weight:700;font-size:.92rem;line-height:1.3;overflow-wrap:anywhere;}

/* ---------- ARRIVAL NUDGE ---------- */
.nudge{
  display:flex;align-items:center;gap:12px;position:relative;
  background:var(--bg-card);border:1px solid var(--accent-border);
  border-left:4px solid var(--hot);border-radius:14px;padding:12px 30px 12px 14px;margin-bottom:14px; /* right padding clears the absolute ✕ */
}
.nudge-emoji{font-size:1.6rem;}
.nudge-body{flex:1;min-width:0;overflow-wrap:anywhere;display:flex;flex-direction:column;font-size:.85rem;}
.nudge-body strong{font-size:.92rem;}
.nudge-cta{flex-shrink:0;background:var(--hot);color:#fff;border:none;border-radius:100px;padding:8px 16px;font-weight:700;min-height:40px;}
.nudge-x{position:absolute;top:6px;right:8px;background:none;border:none;color:var(--text-muted);font-size:1.1rem;}

/* ---------- FEED ---------- */
.feed-list{display:flex;flex-direction:column;gap:18px;}
.post{background:var(--bg-card);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);}
.post.optimistic{opacity:.6;}
.post-head{display:flex;align-items:center;gap:8px;padding:12px 14px 10px;}
.post-author{font-weight:700;font-size:.82rem;padding:2px 10px;border-radius:100px;}
.author-mike{background:var(--accent-subtle);color:var(--electric);}
.author-ryan{background:rgba(22,193,114,.14);color:var(--pitch-bright);}
.post-context{font-size:.72rem;color:var(--text-muted);}
.post-time{margin-left:auto;font-size:.72rem;color:var(--text-muted);font-family:var(--font-mono);}
.post-media img,.post-media video{width:100%;display:block;background:var(--bg-subtle);max-height:78vh;object-fit:cover;}
.post-caption{padding:12px 14px;font-size:.9rem;line-height:1.5;color:var(--text-secondary);}
.post-actions{display:flex;gap:8px;padding:0 14px 14px;}
.post-react{background:var(--bg-subtle);border:1px solid var(--border);border-radius:100px;padding:6px 14px;font-size:.85rem;min-height:40px;}
.post-uploading{padding:10px 14px;font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:8px;}
.spin{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--electric);border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* voice post */
.voice-player{display:flex;align-items:center;gap:12px;padding:14px;}
.voice-play{width:44px;height:44px;border-radius:50%;border:none;background:var(--electric);color:#fff;font-size:1rem;flex-shrink:0;}
.voice-wave{flex:1;height:24px;border-radius:6px;background:repeating-linear-gradient(90deg,var(--border) 0 3px,transparent 3px 6px);}
.voice-dur{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);}

/* ---------- CAPTURE FAB ---------- */
.fab-capture{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:calc(var(--bottomnav-h)/2 + var(--safe-b) - 6px);
  z-index:60;width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle at 30% 25%,var(--pitch-bright),var(--pitch));
  color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(10,124,66,.5); /* no halo ring — it mismatched the nav surface it straddles */
  cursor:pointer;transition:transform .15s var(--ease-out);
}
.fab-capture:active{transform:translateX(-50%) scale(.92);}

/* ---------- BOTTOM NAV ---------- */
.bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:55;
  height:calc(var(--bottomnav-h) + var(--safe-b));
  padding-bottom:var(--safe-b);
  display:flex;align-items:center;justify-content:space-around;
  background:var(--bg-sidebar);border-top:1px solid var(--border);
}
.bn-spacer{width:64px;flex:0 0 64px;}
.bn-item{flex:1;background:none;border:none;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;min-height:52px;}
.bn-item.active{color:var(--electric);}
.bn-ico{font-size:1.15rem;line-height:1;}
.bn-lbl{font-size:.6rem;font-weight:600;}

/* ---------- SHEETS (caption / passcode) ---------- */
.sheet-scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:90;}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:100;background:var(--bg-card);border-radius:20px 20px 0 0;padding:14px 18px calc(20px + var(--safe-b));border-top:1px solid var(--border);box-shadow:0 -8px 30px rgba(0,0,0,.4);animation:slideup .28s var(--ease-out);max-width:680px;margin:0 auto;}
@keyframes slideup{from{transform:translateY(100%);}to{transform:none;}}
.sheet-grip{width:40px;height:4px;border-radius:4px;background:var(--border-strong);margin:0 auto 12px;}
.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.sheet-skip{background:none;border:none;color:var(--text-muted);font-weight:600;min-height:40px;}
.sheet-thumb{width:56px;height:56px;border-radius:12px;object-fit:cover;display:block;margin:0 0 10px;} /* no float — presets/textarea stay full width */
.sheet-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);padding:12px 14px;font-family:var(--font-sans);font-size:.95rem;min-height:48px;outline:none;}
.sheet-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle);}
.sheet-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:12px 0;}
.voice-rec{background:var(--bg-subtle);border:1px solid var(--border);border-radius:100px;padding:10px 16px;font-weight:600;min-height:44px;}
.voice-rec.recording{background:var(--hot);color:#fff;border-color:var(--hot);}
.who-toggle{display:flex;background:var(--bg-subtle);border-radius:100px;padding:3px;}
.who{border:none;background:none;border-radius:100px;padding:8px 16px;font-weight:700;color:var(--text-muted);min-height:38px;}
.who.active{background:var(--electric);color:#fff;}
.sheet-save{width:100%;background:var(--electric);color:#fff;border:none;border-radius:14px;padding:14px;font-weight:700;font-size:1rem;min-height:52px;}
.lock-sheet .lock-title{display:block;font-size:1.05rem;margin-bottom:4px;}
.lock-sub{color:var(--text-muted);font-size:.85rem;margin:0 0 14px;}
.lock-err{color:var(--red);font-size:.82rem;margin:8px 0 0;text-align:left;} /* sits under the input it refers to */
.lock-sheet .sheet-save{margin-top:12px;}

/* ---------- ROUTE RAIL ---------- */
.route-rail{display:flex;flex-direction:column;gap:0;}
.route-stop{display:flex;align-items:center;gap:14px;padding:0 0 0 4px;position:relative;}
.route-node{width:16px;height:16px;border-radius:50%;background:var(--bg-card);border:3px solid var(--border-strong);z-index:1;}
.route-stop::before{content:'';position:absolute;left:11px;top:0;bottom:0;width:2px;background:var(--border);}
.route-stop:first-child::before{top:50%;}
.route-stop:last-child::before{bottom:50%;}
.route-city{font-weight:700;padding:14px 0;}
.route-stop.done .route-node{background:var(--pitch-bright);border-color:var(--pitch-bright);}
.route-stop.current .route-node{background:var(--hot);border-color:var(--hot);box-shadow:0 0 0 4px rgba(255,90,54,.25);}

/* ---------- SCHEDULE / CHIPS ---------- */
.sched-filters{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px;margin-bottom:8px;-webkit-overflow-scrolling:touch;}
.chip-btn{flex:0 0 auto;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:8px 16px;font-size:.82rem;font-weight:600;color:var(--text-secondary);min-height:40px;}
.chip-btn.active{background:var(--electric);color:#fff;border-color:var(--electric);}

/* ---------- COMPANION CHAT ---------- */
#companion{display:none;}
#companion.active{display:flex;flex-direction:column;height:100%;} /* the app-shell scroller bounds it on all widths */
.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:10px;padding:6px 0;}
.chat-message{max-width:88%;min-width:0;overflow-wrap:anywhere;padding:10px 14px;border-radius:16px;font-size:.9rem;line-height:1.5;}
.chat-message.user{align-self:flex-end;background:var(--electric);color:#fff;border-bottom-right-radius:6px;}
.chat-message.assistant{align-self:flex-start;background:var(--bg-subtle);border:1px solid var(--border);border-bottom-left-radius:6px;}
.chat-form{display:flex;gap:8px;padding-top:8px;}
.chat-form textarea{flex:1;resize:none;background:var(--bg-input);border:1px solid var(--border);border-radius:14px;color:var(--text-primary);padding:12px 14px;font-size:.95rem;max-height:120px;}
.chat-send{background:var(--electric);color:#fff;border:none;border-radius:14px;padding:0 20px;font-weight:700;min-height:48px;}

/* ============================================================
   RESPONSIVE — tablet/desktop: nav moves to a left rail,
   feed centers, FAB sits bottom-right.
   ============================================================ */
@media (min-width:860px){
  /* symmetric padding: the rail reserves the left 84px, a matching 84px on the
     right keeps the centered column TRULY viewport-centered (was 42px off) */
  body.app{padding-bottom:0;padding-left:84px;padding-right:84px;}
  .bottomnav{flex-direction:column;top:0;bottom:0;left:0;right:auto;width:84px;height:100vh;border-top:none;border-right:1px solid var(--border);justify-content:flex-start;gap:4px;padding-top:80px;}
  .bn-spacer{display:none;}
  .bn-item{flex:0 0 auto;padding:12px 0;min-height:60px;border-radius:12px;margin:0 8px;}
  .bn-item.active{background:var(--accent-subtle);}
  .bn-ico{font-size:1.35rem;}
  .bn-lbl{font-size:.62rem;}
  /* body padding already clears the rail — the old extra 100px pushed the brand to ~184px */
  .appbar{padding-left:16px;}
  .fab-capture{left:auto;right:28px;bottom:28px;transform:none;width:60px;height:60px;}
  .fab-capture:active{transform:scale(.92);}
  .screens{max-width:720px;}
  /* desktop sheet keeps its centering transform THROUGH the slide-up animation */
  .sheet{max-width:520px;left:50%;transform:translateX(-50%);border-radius:20px;bottom:24px;animation:slideup-centered .28s var(--ease-out);}
}
@keyframes slideup-centered{from{transform:translate(-50%,100%);}to{transform:translate(-50%,0);}}


/* ============================================================
   WC26 LIVE — component styles for the redesigned screens
   (appended after the mobile shell; reuses :root tokens)
   ============================================================ */
.appbar-actions{display:flex;align-items:center;gap:8px;}
.brand-wc{color:var(--text-primary);}
.icon-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:50%;width:38px;height:38px;font-size:1rem;line-height:1;color:var(--text-primary);display:flex;align-items:center;justify-content:center;}
.icon-btn:active{transform:scale(.92);}

.post-title{padding:10px 14px 0;font-weight:700;font-size:.95rem;}
.post-del{margin-left:6px;background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;}
.voice-player audio{width:100%;}

/* ---- itinerary leg cards ---- */
.legs{display:flex;flex-direction:column;gap:14px;}
.leg-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:14px;}
.leg-top{display:flex;align-items:center;gap:12px;}
.leg-ico{font-size:1.5rem;line-height:1;}
.leg-titles{flex:1;min-width:0;}
.leg-titles h3{margin:0;font-size:1rem;font-weight:700;letter-spacing:-.01em;}
.leg-date{font-size:.74rem;color:var(--text-muted);font-family:var(--font-mono);}
.leg-flags{display:flex;gap:6px;flex-shrink:0;}
.flag{font-size:.6rem;font-weight:700;padding:3px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.05em;}
.flag-home{background:var(--accent-subtle);color:var(--electric);}
.flag-free{background:rgba(22,193,114,.14);color:var(--pitch-bright);}
.leg-game{margin:12px 0 0;padding:10px 12px;background:var(--bg-subtle);border-radius:10px;font-size:.84rem;border-left:3px solid var(--pitch-bright);}
.leg-tabs{display:flex;gap:6px;margin:12px 0 10px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.leg-tab{flex:0 0 auto;background:var(--bg-subtle);border:1px solid var(--border);border-radius:100px;padding:7px 14px;font-size:.78rem;font-weight:600;color:var(--text-secondary);min-height:38px;}
.leg-tab.active{background:var(--electric);color:#fff;border-color:var(--electric);}
.leg-tab-content{display:none;}
.leg-tab-content.active{display:block;}
.booking{background:var(--bg-subtle);border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:8px;}
.booking-route{font-weight:700;font-size:.9rem;}
.booking-info{font-size:.82rem;color:var(--text-secondary);margin-top:4px;line-height:1.5;}
.booking-conf{font-size:.74rem;color:var(--text-muted);margin-top:6px;font-family:var(--font-mono);}
.muted{color:var(--text-muted);font-size:.85rem;}
.leg-notes{width:100%;min-height:90px;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);padding:10px;font-family:var(--font-sans);font-size:.9rem;}

/* ---- city guide ---- */
.city-guide{display:flex;flex-direction:column;gap:14px;margin-top:4px;}
.guide-sec h4{margin:0 0 8px;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);}
.guide-item{font-size:.85rem;line-height:1.5;margin-bottom:6px;color:var(--text-secondary);}
.guide-item strong{color:var(--text-primary);}
.guide-tips{margin:0;padding-left:18px;font-size:.85rem;color:var(--text-secondary);line-height:1.6;}

/* ---- schedule ---- */
.schedule-date-group{margin-bottom:18px;}
.schedule-date-header{font-weight:700;font-size:.9rem;margin-bottom:10px;color:var(--text-secondary);}
.schedule-date-cards{display:flex;flex-direction:column;gap:10px;}
.schedule-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px 14px;}
.schedule-card.attending{border-color:var(--pitch-bright);background:linear-gradient(135deg,rgba(22,193,114,.10),transparent);}
.sc-label{font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);}
.sc-teams{font-weight:700;font-size:.95rem;margin:4px 0;}
.sc-venue{font-size:.77rem;color:var(--text-muted);}
.sc-time{font-size:.8rem;color:var(--text-secondary);margin-top:4px;font-family:var(--font-mono);}
.sc-badge{margin-top:8px;display:inline-block;font-size:.7rem;font-weight:700;color:var(--pitch-bright);}

/* ---- route rail extra ---- */
.route-when{margin-left:auto;font-size:.7rem;color:var(--text-muted);font-family:var(--font-mono);}
.route-stop{cursor:pointer;}

.typing{color:var(--text-muted);font-style:italic;}

/* override old flex body layout */
body.app{display:block;}

/* ================= WC26 polish pass ================= */
/* empty feed state (pre-trip / no posts) */
.feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:46vh;padding:24px 8px 70px;text-align:center;color:var(--text-muted);font-size:.95rem;}
.empty-card{max-width:380px;width:100%;text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:18px;padding:30px 24px;}
.empty-emoji{font-size:2.3rem;margin-bottom:10px;}
.empty-card h3{margin:0 0 8px;font-size:1.1rem;font-weight:700;}
.empty-card p{margin:0 0 16px;color:var(--text-secondary);font-size:.9rem;line-height:1.55;}
.empty-count{display:inline-block;font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--pitch-bright);background:rgba(22,193,114,.12);border:1px solid rgba(22,193,114,.28);padding:7px 15px;border-radius:100px;}

/* the capture FAB overlapped the chat input — hide it on the Companion screen */
body.on-companion .fab-capture{display:none;}
#companion.active{padding-bottom:8px;}

/* desktop: a touch wider so content isn't a thin ribbon in a void */
@media (min-width:860px){
  .screens{max-width:860px;}
  .feed-empty{padding-top:48px;}
}

/* CRITICAL: ensure [hidden] always wins over class display:flex/grid (fixes the empty nudge box showing over the feed) */
[hidden]{display:none !important;}

/* ================= Mobile feel: tap feedback + no horizontal drag ================= */
*{-webkit-tap-highlight-color:rgba(0,0,0,0);}
html,body{overflow-x:hidden;max-width:100%;}
body{overscroll-behavior-x:none;}
button,.bn-item,.leg-tab,.chip-btn,.icon-btn,.nudge-cta,.sheet-save,.sheet-skip,.post-react,.who,.voice-rec,.chat-send,.feed-more{
  touch-action:manipulation;
  transition:transform .1s var(--ease-out), opacity .1s ease, background .15s ease;
}
button:active,.bn-item:active,.leg-tab:active,.chip-btn:active,.nudge-cta:active,.sheet-save:active,.post-react:active,.who:active,.voice-rec:active,.chat-send:active,.feed-more:active{
  transform:scale(.95);opacity:.8;
}
.icon-btn{width:44px;height:44px;font-size:1.1rem;}
.icon-btn:active{transform:scale(.9);}
.leg-tab{min-height:44px;padding:9px 16px;}
.chip-btn{min-height:44px;}
/* keep the horizontally-scrolling chip rows working under overflow-x rules */
.sched-filters,.leg-tabs{touch-action:pan-x pan-y;}

/* ================= Feed day grouping + load more ================= */
.feed-day{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:14px 0 0;} /* shares the card gutter exactly */
.feed-day:first-child{margin-top:0;}
.feed-more{display:block;margin:18px auto 0;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:12px 30px;color:var(--text-secondary);font-weight:600;min-height:48px;}
.post-ai{color:var(--text-muted);font-style:italic;}

/* ================= iOS horizontal-drag kill switch ================= */
/* iOS pans sideways whenever ANY element overflows, ignoring overflow-x:hidden.
   pan-y means the page itself can only scroll vertically; rows that need to
   scroll sideways (filter chips, leg tabs) re-enable pan-x for themselves. */
body{touch-action:pan-y pinch-zoom;}

/* never let flex/grid children force the layout wider than the screen */
.appbar > *,.appbar-actions > *,.now-strip > div,.post-head > *{min-width:0;}
.appbar-brand{flex-shrink:1;min-width:0;overflow:hidden;white-space:nowrap;} /* brand clips last instead of pushing icons out */
.countdown-chip{min-width:0;overflow:hidden;}
.chip-value{white-space:nowrap;}
img,video{max-width:100%;height:auto;}

/* small phones / large iOS text: compress the appbar instead of overflowing */
@media (max-width:430px){
  .appbar{padding:0 10px;gap:6px;}
  .appbar-actions{gap:6px;}
  .chip-label{display:none;}
  .countdown-chip{padding:6px 10px;gap:6px;}
  .icon-btn{width:40px;height:40px;}
}

/* ============ App-shell scrolling: the DOCUMENT never scrolls ============ */
/* iOS lets position:fixed bars "float" while the document scrolls/bounces.
   Solution: freeze the page; only main.screens scrolls internally. The bottom
   nav/FAB stay fixed against a viewport that never moves. */
html, body { height: 100%; overflow: hidden; overscroll-behavior: none; }
body.app { padding-bottom: 0; }
main.screens {
  height: calc(100vh - var(--appbar-h));   /* fallback */
  height: calc(100dvh - var(--appbar-h));  /* tracks iOS dynamic toolbars */
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;          /* bounce stays inside the scroller */
  max-width: none;
  padding-bottom: calc(var(--bottomnav-h) + var(--safe-b) + 28px);
}
/* content column centering moves from .screens to each screen */
.screen { max-width: 680px; margin-left: auto; margin-right: auto; }
@media (min-width: 860px) {
  main.screens { max-width: none; }
  .screen { max-width: 860px; }
}

/* keyboard-aware shell: --vvh is kept in sync with window.visualViewport, so the
   scroller (and the chat input pinned at its bottom) shrinks above the iOS keyboard */
main.screens { height: calc(var(--vvh, 100dvh) - var(--appbar-h)); }

/* the scroller itself must forbid horizontal panning — when overflow-y:auto was
   added, overflow-x silently computed to auto, creating a NEW sideways scroller.
   Locking it here (the element that actually owns scrolling) ends the drift. */
main.screens { overflow-x: hidden; touch-action: pan-y pinch-zoom; }

/* ================= Story feed: leg chapters + compact attached voice ================= */
.feed-chapter{margin:24px 0 6px;padding:14px 16px;background:linear-gradient(135deg,rgba(124,117,255,.16),rgba(22,193,114,.10));border:1px solid var(--accent-border);border-radius:14px;}
.feed-chapter:first-child{margin-top:0;}
.fc-title{font-weight:800;font-size:1.02rem;letter-spacing:-.01em;}
.fc-sub{font-size:.78rem;color:var(--text-secondary);margin-top:3px;line-height:1.4;}
.post-voice-row{display:flex;align-items:center;gap:8px;padding:8px 14px 0;}
.post-voice-row .pv-ico{font-size:.95rem;flex-shrink:0;}
.post-voice-row audio{width:100%;height:34px;}

/* ================= Alignment pass + new story components ================= */
/* voice pill: a proper contained pill, aligned to the card's 14px gutter */
.post-voice-row{display:flex;align-items:center;gap:10px;margin:10px 14px 0;padding:6px 10px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:100px;}
.post-voice-row .pv-ico{flex-shrink:0;line-height:1;font-size:.95rem;}
.post-voice-row audio{flex:1;min-width:0;height:32px;display:block;}

/* reactions + share: consistent card footer row */
/* one row always — worst case it pans sideways instead of orphaning the share arrow */
.post-reactions{display:flex;align-items:center;gap:8px;padding:10px 14px 12px;flex-wrap:nowrap;overflow-x:auto;touch-action:pan-x pan-y;scrollbar-width:none;}
.post-reactions::-webkit-scrollbar{display:none;}
.rx-btn{flex:0 0 auto;background:var(--bg-subtle);border:1px solid var(--border);border-radius:100px;padding:6px 12px;font-size:.9rem;color:var(--text-secondary);min-height:44px;display:inline-flex;align-items:center;gap:5px;}
.rx-btn span{font-family:var(--font-mono);font-size:.74rem;font-weight:700;color:var(--text-primary);}
.rx-btn.mine{border-color:var(--pitch-bright);background:rgba(22,193,114,.12);}
.rx-btn.rx-share{margin-left:auto;font-size:1rem;color:var(--text-muted);}

/* chapter covers + recap */
.feed-chapter.has-cover{background-size:cover;background-position:center;min-height:110px;display:flex;flex-direction:column;justify-content:flex-end;border-color:rgba(255,255,255,.14);text-shadow:0 1px 3px rgba(0,0,0,.6);}
.fc-recap{margin-top:8px;font-size:.85rem;line-height:1.55;color:var(--text-primary);font-style:italic;opacity:.95;}
.fc-recap-btn{margin-top:10px;align-self:flex-start;background:rgba(124,117,255,.18);border:1px solid var(--accent-border);border-radius:100px;padding:7px 14px;font-size:.76rem;font-weight:700;color:var(--text-primary);min-height:36px;}

/* LIVE state + shared-post highlight */
.live-now{color:#ff5a36;font-weight:800;animation:livepulse 1.6s ease-in-out infinite;}
@keyframes livepulse{0%,100%{opacity:1;}50%{opacity:.55;}}
.post-highlight{outline:2px solid var(--accent);outline-offset:2px;}

/* failed uploads must look different from in-flight ones (bright outdoor glance) */
.post.failed{opacity:1;border-left:3px solid #ff5a36;}

/* ================= Maximum delight pack ================= */
/* Today card: today's travel + stay at a glance (travel mode) */
/* color hierarchy: --hot is reserved for the actionable nudge; informational cards use the accent palette */
.today-card{margin:0 0 14px;padding:14px 16px;background:linear-gradient(135deg,var(--accent-subtle),rgba(22,193,114,.08));border:1px solid var(--accent-border);border-radius:16px;}
.tc-kicker{font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--electric);margin-bottom:8px;}
.tc-row{margin-bottom:10px;font-size:.92rem;}
.tc-row strong{font-weight:700;}
.tc-detail{font-size:.8rem;color:var(--text-secondary);margin-top:2px;line-height:1.45;}
.tc-conf{font-family:var(--font-mono);font-size:.74rem;color:var(--pitch-bright);margin-top:3px;}
.tc-nav{display:inline-block;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:9px 16px;font-size:.82rem;font-weight:700;color:var(--text-primary);text-decoration:none;min-height:40px;}

/* offline queue banner */
.queue-banner{margin:0 0 12px;padding:11px 14px;background:var(--amber-subtle);border:1px solid var(--amber-border);border-radius:12px;font-size:.82rem;font-weight:600;color:var(--text-primary);cursor:pointer;}

/* appbar author chip */
.author-chip{font-weight:800;font-size:.95rem;color:var(--electric);border-color:var(--accent-border);}
.author-chip.ryan{color:var(--pitch-bright);border-color:rgba(22,193,114,.4);}

/* caption preset chips */
.cap-presets{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:10px;touch-action:pan-x pan-y;}
.cap-chip{flex:0 0 auto;background:var(--bg-subtle);border:1px solid var(--border);border-radius:100px;padding:8px 14px;font-size:.8rem;font-weight:600;color:var(--text-secondary);min-height:40px;}

/* match-day stadium link */
.stadium-link{display:inline-block;margin:4px 0 0 8px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom;color:#eafff3;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.3);border-radius:100px;padding:3px 10px;font-size:.74rem;font-weight:700;text-decoration:none;}

/* travel mode adds two extra appbar chips — shed decorations early on small phones */
@media (max-width:430px){
  body.travel .brand-live{display:none;}
  body.travel .countdown-chip{display:none;} /* the now-strip carries the countdown */
}

/* undo toast (soft delete) */
.undo-toast{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(var(--bottomnav-h) + var(--safe-b) + 14px);z-index:120;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:10px 18px;font-size:.86rem;box-shadow:0 6px 24px rgba(0,0,0,.5);display:flex;align-items:center;gap:12px;}
.undo-toast button{background:var(--accent);color:#fff;border:none;border-radius:100px;padding:6px 16px;font-weight:700;min-height:36px;}

/* ================= Appbar overflow-proofing =================
   The bar clips internally and sheds elements as the screen narrows —
   it is structurally incapable of exceeding the viewport (the cause of
   the off-center/horizontal-drift regressions). */
.appbar{overflow:hidden;gap:8px;}
.appbar > *{min-width:0;}
.appbar-actions{flex-shrink:1;min-width:0;}
.countdown-chip{flex:0 1 auto;min-width:0;overflow:hidden;white-space:nowrap;}
@media (max-width:480px){
  .brand-live{display:none;}
  .chip-label{display:none;}
  .appbar{padding:0 10px;}
  .appbar-actions{gap:6px;}
  .icon-btn{width:40px;height:40px;}
}
@media (max-width:380px){
  .countdown-chip{display:none;} /* tiny phones: the now-strip carries the countdown */
  .rx-btn{padding:6px 10px;}
}

/* ================= Adversarial review fixes (3-track panel) ================= */

/* --- notch / status-bar safe area: in standalone PWA (black-translucent) the
   appbar content must clear the iOS status bar, and the scroller shrinks to match */
:root{ --safe-t: env(safe-area-inset-top, 0px); }
.appbar{ height:calc(var(--appbar-h) + var(--safe-t)); padding-top:var(--safe-t); }
main.screens{ height:calc(var(--vvh, 100dvh) - var(--appbar-h) - var(--safe-t)); }

/* --- horizontal chip scrollers: right-edge fade so off-screen chips are discoverable */
.sched-filters,.leg-tabs,.cap-presets{
  scroll-padding-right:14px;
  -webkit-mask-image:linear-gradient(90deg,#000 90%,transparent);
  mask-image:linear-gradient(90deg,#000 90%,transparent);
}
.sched-filters > :last-child,.leg-tabs > :last-child,.cap-presets > :last-child{margin-right:10px;}

/* --- defensive: long city names can never widen the route rail or post header */
.route-stop{min-width:0;}
.route-city{min-width:0;overflow-wrap:anywhere;}
.post-head{flex-wrap:nowrap;}
.post-context{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.post-time,.post-del{flex-shrink:0;}

/* --- feed media: respect the DYNAMIC viewport (vh overshoots on iOS) and leave
   room for caption + reactions without a scroll */
.post-media img,.post-media video{max-height:70vh;}
.post-media img,.post-media video{max-height:70dvh;}

/* ================= Desktop treatment (>=860px): the itinerary & schedule
   were rendering at mobile altitude inside the wide column ================= */
@media (min-width:860px){
  /* itinerary: two-up leg cards — each lands at ~phone width where the design shines */
  .legs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;} /* default stretch: side-by-side cards equal height per row */
  .leg-card{padding:18px 20px;}
  .leg-titles h3{font-size:1.05rem;}
  /* schedule: tile grid instead of a tall stack of near-empty full-width bars */
  .schedule-date-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;}
  /* route rail: cap the node→city→date span so the date isn't a viewport away */
  .route-rail{max-width:520px;}
  /* feed photos: contain instead of cover so portrait shots aren't hard-cropped */
  .post-media img,.post-media video{max-height:60vh;object-fit:contain;background:var(--bg-subtle);}
  /* the nav is a left rail here — don't reserve bottom-nav space in the scroller
     (it left ~100px of dead air under the chat input) */
  main.screens{padding-bottom:24px;}
}

/* upper tablet band: ease the column from 680 to 860 instead of snapping */
@media (min-width:680px) and (max-width:859px){
  .screen{max-width:760px;}
}

/* ================= iOS auto-zoom kill switch =================
   Any focusable text control under 16px makes iOS ZOOM the page on focus —
   the zoom then sticks (even across the login reload): content shifted right,
   cut off, fixed bars floating on pan. 16px everywhere = no zoom, ever.
   (The travel view logs in through the auto-focused passcode input, which is
   why only Mike & Ryan ever saw it.) */
.sheet-input,
.chat-form textarea,
.leg-notes,
input, textarea, select{font-size:16px;}

/* keyboard-aware bottom sheets: with auto-zoom suppressed, iOS no longer
   "rescues" a covered input — so lift the sheet above the keyboard ourselves.
   The layout viewport (100dvh) stays full-height under the iOS keyboard while
   --vvh (visualViewport, kept live by syncVvh) shrinks: the difference IS the
   keyboard height. On Android the layout viewport shrinks too → lift = 0. */
@media (max-width:859px){
  .sheet{
    bottom:max(0px, calc(100dvh - var(--vvh, 100dvh)));
    transition:bottom .22s ease;
  }
}

/* ================= Desktop scale-up (Mike's 1900px feedback) =================
   Problems at large widths: scrollbar floated 84px from the window edge (body
   padding), content column too narrow, phone-scale type/cards swimming in space. */
@media (min-width:860px){
  :root{--appbar-h:64px;}
  /* centering padding moves from body INTO the scroller — the scrollbar now sits
     at the true window edge where every desktop app puts it */
  body.app{padding-left:0;padding-right:0;}
  main.screens{padding-left:calc(84px + 24px);padding-right:calc(84px + 24px);}
  .appbar{padding-left:calc(84px + 24px);padding-right:24px;}
  .appbar-brand{font-size:1.35rem;}
  .countdown-chip{padding:8px 16px;}
  /* slim, themed scrollbar */
  main.screens{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;}
  main.screens::-webkit-scrollbar{width:10px;}
  main.screens::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:8px;}
  main.screens::-webkit-scrollbar-track{background:transparent;}
  /* room to breathe: wide screens get a wide column; the feed stays readable */
  .screen{max-width:1000px;}
  #feed{max-width:780px;}
  .screen-title{font-size:1.9rem;margin:14px 0 22px;}
  /* schedule: bigger tiles, denser grid */
  .schedule-date-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;}
  .schedule-card{padding:16px 18px;}
  .sc-teams{font-size:1.05rem;}
  .schedule-date-header{font-size:1rem;margin-bottom:12px;}
  .sched-filters{gap:10px;padding-bottom:14px;}
  .chip-btn{font-size:.88rem;padding:10px 20px;}
  /* journey: scale the cards to match */
  .leg-titles h3{font-size:1.15rem;}
  .leg-tab{font-size:.85rem;}
  .booking-route{font-size:.98rem;}
  .route-city{font-size:1.05rem;}
  /* hero strip + feed type up a notch */
  .now-strip{padding:18px 20px;}
  .now-place,.now-game{font-size:1.05rem;}
  .post-caption{font-size:.95rem;}
}

/* two-tap delete confirm: armed state is unmissably red */
.post-del.confirming{background:var(--hot);color:#fff;border-radius:100px;padding:4px 12px;font-size:.78rem;font-weight:700;min-height:32px;}
