:root {
  --bg: #0e0e0e;
  --surface: #161616;
  --surface2: #1c1c1c;
  --surface3: #222222;
  --border: #2c2c2c;
  --border-bright: #404040;
  --gold: #e0392d;
  --gold-dim: #992218;
  --amber: #f07030;
  --red: #ff3333;
  --green: #3ec97a;
  --blue: #5588ff;
  --text: #f0ede8;
  --text-dim: #8a8278;
  --text-muted: #484440;
  --accent: #e0392d;
  --sidebar-w: 240px;
  --header-h: 64px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.6;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;}
body::before{content:'';position:fixed;inset:0;background-image:
  radial-gradient(ellipse at 15% 0%,rgba(224,57,45,0.08) 0%,transparent 55%),
  radial-gradient(ellipse at 85% 90%,rgba(153,34,24,0.05) 0%,transparent 50%);
  pointer-events:none;z-index:0;}

/* FOCUS */

/* iOS tap highlight */
*{-webkit-tap-highlight-color:transparent;}
a,button{touch-action:manipulation;}

:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:2px;}

/* ── TOP BAR ── */
header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:300;background:rgba(14,14,14,0.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);display:flex;align-items:center;box-shadow:0 8px 32px rgba(0,0,0,0.6);}
.header-inner{width:100%;display:flex;align-items:center;padding:0 1.5rem;gap:1rem;}
.logo{font-family:'Orbitron',sans-serif;font-size:1rem;font-weight:700;color:var(--gold);letter-spacing:0.14em;white-space:nowrap;flex-shrink:0;cursor:pointer;display:flex;flex-direction:column;line-height:1.2;width:var(--sidebar-w);padding-right:1.5rem;}
.logo span{color:var(--text-muted);font-weight:400;font-size:0.6rem;letter-spacing:0.16em;margin-top:6px;font-family:'DM Mono',monospace;text-transform:uppercase;}
.header-center{flex:1;display:flex;align-items:center;gap:0.75rem;}
.header-search-btn{display:flex;align-items:center;gap:0.6rem;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:0.5rem 1rem;cursor:pointer;transition:all 0.2s;flex:1;max-width:420px;}
.header-search-btn:hover{border-color:var(--border-bright);background:var(--surface3);}
.header-search-btn span.icon{color:var(--text-muted);font-size:0.85rem;}
.header-search-btn p{font-size:0.8rem;color:var(--text-muted);flex:1;font-family:'DM Sans',sans-serif;}
.header-search-btn kbd{font-family:'IBM Plex Mono',monospace;font-size:0.58rem;color:var(--text-muted);border:1px solid var(--border);border-radius:3px;padding:1px 5px;}
.header-right{display:flex;align-items:center;gap:0.75rem;margin-left:auto;}
.hamburger{display:none;background:none;border:1px solid var(--border);border-radius:8px;color:var(--text-dim);padding:7px 12px;font-size:1rem;cursor:pointer;transition:all 0.2s;flex-shrink:0;}
.hamburger:hover{border-color:var(--gold);color:var(--gold);background:rgba(224,57,45,0.06);}

/* ── SIDEBAR NAV ── */
.sidebar{position:fixed;top:var(--header-h);left:0;bottom:0;width:var(--sidebar-w);z-index:200;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:1.75rem 0 2rem;display:flex;flex-direction:column;}
.sidebar::-webkit-scrollbar{width:3px;}
.sidebar::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px;}
.nav-section-label{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);padding:0 1.25rem 0.35rem;margin:1.5rem 0 0.35rem;border-bottom:1px solid var(--border);}
.nav-section-label:first-child{margin-top:0;}
nav{display:flex;flex-direction:column;gap:2px;padding:0 0.75rem;}
nav a{font-family:'DM Sans',sans-serif;font-size:0.875rem;font-weight:500;color:var(--text-dim);text-decoration:none;padding:0.6rem 1rem;border-radius:8px;border:none;letter-spacing:0.01em;transition:all 0.15s;white-space:nowrap;cursor:pointer;display:flex;align-items:center;gap:0.65rem;margin:0 0.5rem;}
nav a .nav-icon{font-size:1rem;width:1.4rem;text-align:center;flex-shrink:0;}
nav a:hover{color:var(--text);background:var(--surface2);}
nav a.active{color:var(--gold);background:rgba(224,57,45,0.1);font-weight:600;}
nav a.fam-link{color:var(--amber);}
nav a.fam-link:hover{background:var(--surface2);}
nav a.fam-link.active{color:var(--amber);background:rgba(240,112,48,0.08);}
#mainNav{display:flex;}

/* ── MOBILE DRAWER ── */
.mobile-nav{display:none;position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:rgba(14,14,14,0.99);z-index:250;padding:1.5rem;overflow-y:auto;flex-direction:column;gap:0.4rem;-webkit-overflow-scrolling:touch;}
.mobile-nav.open{display:flex;}
.mobile-nav a{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:500;letter-spacing:0.01em;color:var(--text-dim);text-decoration:none;padding:0.85rem 1.1rem;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all 0.15s;background:var(--surface);}
.mobile-nav a:hover,.mobile-nav a.mob-active{color:var(--gold);border-color:rgba(224,57,45,0.3);background:rgba(224,57,45,0.06);}
.mobile-nav a.fam-link{color:var(--amber);}

/* ── MAIN CONTENT AREA ── */
.app-body{display:flex;flex-direction:column;padding-top:var(--header-h);min-height:100vh;}
main{margin-left:var(--sidebar-w);flex:1;padding:2.5rem 3rem 4rem;position:relative;z-index:1;max-width:1400px;width:100%;}

/* ── SEARCH OVERLAY ── */
.search-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:500;align-items:flex-start;justify-content:center;padding-top:100px;}
.search-overlay.open{display:flex;}
.search-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:90%;max-width:620px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,0.9);}
.search-input-wrap{display:flex;align-items:center;gap:0.6rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);}
.search-input-wrap span{color:var(--text-muted);font-size:1rem;}
.search-input-wrap input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:'DM Sans',sans-serif;font-size:1rem;}
.search-input-wrap input::placeholder{color:var(--text-muted);}
.search-close{background:none;border:none;color:var(--text-muted);font-size:0.75rem;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:3px 7px;border:1px solid var(--border);border-radius:3px;}
.search-results{padding:0.5rem;max-height:420px;overflow-y:auto;}
.search-result{padding:0.8rem 1rem;border-radius:8px;cursor:pointer;border-bottom:1px solid var(--border);transition:background 0.12s;margin:2px 4px;}
.search-result:hover,.search-result.sr-selected{background:var(--surface2);border-color:transparent;}
.search-result:last-child{border-bottom:none;}
.sr-title{font-family:'DM Sans',sans-serif;font-size:0.9rem;color:var(--text);letter-spacing:0.01em;font-weight:600;}
.sr-section{font-family:'IBM Plex Mono',monospace;font-size:0.58rem;color:var(--text-muted);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:2px;}
.sr-snippet{font-size:0.72rem;color:var(--text-dim);margin-top:3px;line-height:1.45;}
.search-empty{padding:1.25rem;text-align:center;color:var(--text-muted);font-size:0.8rem;}
.search-hint{padding:0.85rem 1.1rem;font-family:'IBM Plex Mono',monospace;font-size:0.58rem;color:var(--text-muted);letter-spacing:0.08em;}

/* ── PAGE LAYOUT ── */
.page{display:none;}
.page.active{display:block;}
.page-search{display:none;}

/* ── PAGE HEADER ── */
.page-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;position:relative;}
.page-header h1{font-family:'Orbitron',sans-serif;font-size:1.75rem;font-weight:700;color:var(--text);letter-spacing:0.06em;line-height:1.1;}
.page-header p{font-size:0.78rem;color:var(--text-muted);margin-top:0.3rem;font-family:'DM Mono',monospace;letter-spacing:0.04em;}

/* ── SECTION LABEL ── */
.section-label{font-family:'DM Mono',monospace;font-size:0.7rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:0.85rem;margin-top:2rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0.5rem;}
.section-label::before{content:'';display:block;width:3px;height:14px;background:var(--gold);border-radius:2px;flex-shrink:0;}

/* ── GRID ── */
.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;}
.qr-grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1rem;}

/* ── CARDS ── */
.qr-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all 0.2s;position:relative;}
.qr-card:hover{border-color:var(--border-bright);box-shadow:0 4px 24px rgba(0,0,0,0.4);transform:translateY(-1px);}
.qr-card-header{background:var(--surface2);padding:0.9rem 1.1rem;display:flex;align-items:center;gap:0.65rem;border-bottom:1px solid var(--border);}
.qr-card-header .icon{font-size:1rem;}
.qr-card-header h3{font-family:'DM Sans',sans-serif;font-size:0.875rem;color:var(--text);letter-spacing:0.01em;font-weight:600;}
.qr-card-body{padding:1.1rem 1.1rem;}

/* ── TABLE ── */
.data-table{width:100%;border-collapse:collapse;font-size:0.85rem;}
.data-table th{font-family:'DM Mono',monospace;font-size:0.72rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--text-muted);padding:0.65rem 0.75rem;text-align:left;border-bottom:1px solid var(--border);background:transparent;font-weight:500;}
.data-table td{padding:0.55rem 0.65rem;border-bottom:1px solid rgba(42,42,42,0.5);color:var(--text);font-size:0.8rem;vertical-align:top;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:var(--surface2);}

/* ── TAGS ── */
.tag{display:inline-block;font-family:'DM Mono',monospace;font-size:0.72rem;padding:2px 10px;border-radius:20px;letter-spacing:0.02em;font-weight:500;}
.tag-gold{background:rgba(224,57,45,0.15);color:var(--gold);border:1px solid rgba(224,57,45,0.3);}
.tag-green{background:rgba(57,201,122,0.12);color:var(--green);border:1px solid rgba(57,201,122,0.25);}
.tag-red{background:rgba(224,85,85,0.12);color:var(--red);border:1px solid rgba(224,85,85,0.25);}
.tag-blue{background:rgba(224,57,45,0.12);color:var(--blue);border:1px solid rgba(224,57,45,0.25);}
.tag-amber{background:rgba(255,160,64,0.12);color:var(--amber);border:1px solid rgba(255,160,64,0.25);}

/* ── EXPANDABLE ── */
.expandable{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:0.6rem;overflow:hidden;transition:all 0.2s;}
.expandable:hover{border-color:var(--border-bright);box-shadow:0 4px 20px rgba(0,0,0,0.3);}
.expand-trigger{width:100%;background:none;border:none;padding:1rem 1.1rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left;gap:0.5rem;}
.expand-trigger:hover{background:var(--surface2);}
.et-left{display:flex;align-items:center;gap:0.75rem;}
.et-icon{font-size:1rem;flex-shrink:0;}
.expand-trigger h3{font-family:'DM Sans',sans-serif;font-size:0.95rem;color:var(--text);letter-spacing:0.01em;font-weight:600;}
.et-sub{font-family:'IBM Plex Mono',monospace;font-size:0.62rem;color:var(--text-dim);letter-spacing:0.03em;display:block;margin-top:2px;}
.expand-arrow{font-family:'IBM Plex Mono',monospace;font-size:0.7rem;color:var(--text-muted);transition:transform 0.2s;flex-shrink:0;}
.expandable.open{border-color:rgba(224,57,45,0.2);box-shadow:0 4px 24px rgba(0,0,0,0.3);}.expandable.open .expand-arrow{transform:rotate(90deg);}
.expand-content{display:none;padding:0.5rem 1.1rem 1.2rem;border-top:1px solid var(--border);}
.expandable.open .expand-content{display:block;}

/* ── ALERTS ── */
.alert{padding:0.85rem 1rem;border-radius:10px;font-size:0.875rem;margin:0.75rem 0;display:flex;gap:0.65rem;align-items:flex-start;line-height:1.6;}
.alert-icon{flex-shrink:0;font-size:0.9rem;margin-top:1px;}
.alert-gold{background:rgba(224,57,45,0.08);border-left:3px solid var(--gold);}
.alert-red{background:rgba(224,85,85,0.08);border-left:3px solid var(--red);}
.alert-green{background:rgba(57,201,122,0.08);border-left:3px solid var(--green);}
.alert-amber{background:rgba(255,160,64,0.08);border-left:3px solid var(--amber);}
.alert-blue{background:rgba(224,57,45,0.08);border-left:3px solid var(--blue);}

/* ── STAT ROWS ── */
.stat-row{display:flex;align-items:flex-start;gap:0.6rem;padding:0.45rem 0;border-bottom:1px solid rgba(42,42,42,0.4);font-size:0.8rem;}
.stat-row:last-child{border-bottom:none;}
.stat-label{color:var(--text-muted);width:145px;flex-shrink:0;font-size:0.8rem;padding-top:1px;font-family:'DM Mono',monospace;}
.stat-value{color:var(--text);font-family:'DM Mono',monospace;font-size:0.82rem;}
.stat-note{color:var(--text-muted);font-size:0.68rem;margin-left:auto;text-align:right;flex-shrink:0;}

/* ── FORMATION BAR ── */
.formation-bar{display:flex;height:28px;border-radius:8px;overflow:hidden;margin:0.5rem 0;}
.fb-inf{background:rgba(224,57,45,0.5);border-right:1px solid var(--bg);}
.fb-cav{background:rgba(255,160,64,0.4);border-right:1px solid var(--bg);}
.fb-arc{background:rgba(224,57,45,0.3);}
.formation-bar div{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.9);font-size:0.62rem;font-family:'IBM Plex Mono',monospace;letter-spacing:0.03em;min-width:20px;}

/* ── PHASE TIMELINE ── */
.phase-timeline{display:flex;flex-direction:column;gap:0;}
.phase-block{display:flex;gap:1rem;}
.phase-line{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:20px;}
.phase-dot{width:10px;height:10px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:7px;border:2px solid var(--bg);}
.phase-connector{width:2px;background:var(--border);flex:1;min-height:14px;}
.phase-content{padding-bottom:1.25rem;flex:1;min-width:0;}
.phase-title{font-family:'DM Sans',sans-serif;font-size:0.95rem;color:var(--text);letter-spacing:0.01em;margin-bottom:0.25rem;font-weight:700;}
.phase-meta{font-family:'DM Mono',monospace;font-size:0.75rem;color:var(--text-dim);margin-bottom:0.5rem;}

/* ── GEN TABS ── */
.gen-tabs{display:flex;gap:0.4rem;margin-bottom:1rem;flex-wrap:wrap;}
.gen-tab{font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:500;padding:6px 16px;border:1px solid var(--border);border-radius:20px;background:none;color:var(--text-dim);cursor:pointer;letter-spacing:0.01em;transition:all 0.15s;}
.gen-tab:hover{border-color:var(--border-bright);color:var(--text);background:var(--surface2);}
.gen-tab.active{background:rgba(224,57,45,0.1);border-color:var(--gold);color:var(--gold);font-weight:600;}
.gen-panel{display:none;}
.gen-panel.active{display:block;}

/* ── HERO CHIPS ── */
.hero-lineup{display:flex;gap:0.4rem;flex-wrap:wrap;margin:0.5rem 0;}
.hero-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:0.78rem;font-family:'DM Mono',monospace;display:flex;align-items:center;}
.hero-chip.inf{border-left:3px solid var(--blue);}
.hero-chip.cav{border-left:3px solid var(--gold);}
.hero-chip.arc{border-left:3px solid var(--red);}

/* ── HOME GRID ── */
.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem;}
.home-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.5rem 1.25rem;cursor:pointer;transition:all 0.22s;text-decoration:none;display:block;position:relative;overflow:hidden;}
.home-card:hover{border-color:var(--border-bright);background:var(--surface2);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,0.5);}
.home-card .hc-icon{font-size:2rem;margin-bottom:0.75rem;display:block;}
.home-card h3{font-family:'DM Sans',sans-serif;font-size:0.95rem;color:var(--text);letter-spacing:0.01em;margin-bottom:0.3rem;font-weight:700;}
.home-card p{font-size:0.82rem;color:var(--text-muted);line-height:1.5;font-family:'DM Sans',sans-serif;}
.home-card.p1{border-top:2px solid var(--gold);}
.home-card.p2{border-top:2px solid var(--gold-dim);}

/* ── GOOGLE TRANSLATE ── */
#google_translate_element{flex-shrink:0;}
#google_translate_element .goog-te-gadget{font-family:'IBM Plex Mono',monospace!important;font-size:0!important;color:transparent!important;}
#google_translate_element .goog-te-gadget span{display:none;}
#google_translate_element select.goog-te-combo{background:var(--surface2);border:1px solid var(--border-bright);border-radius:5px;color:var(--text-dim);font-family:'IBM Plex Mono',monospace;font-size:0.62rem;padding:5px 8px;cursor:pointer;outline:none;letter-spacing:0.06em;transition:border-color 0.15s;}
#google_translate_element select.goog-te-combo:hover{border-color:var(--gold-dim);color:var(--gold);}
.goog-te-banner-frame{display:none!important;}
body{top:0!important;}

/* ── POWER GRID ── */
.power-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}

/* ── PASSWORD GATE ── */
.pw-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:55vh;gap:1.5rem;text-align:center;}
.pw-icon{font-size:3rem;opacity:0.3;}
.pw-gate h2{font-family:'Orbitron',sans-serif;font-size:1.2rem;color:var(--text);letter-spacing:0.08em;font-weight:700;}
.pw-gate p{font-size:0.8rem;color:var(--text-dim);max-width:320px;line-height:1.65;}
.pw-form{display:flex;gap:0.6rem;}
.pw-input{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:0.65rem 1rem;color:var(--text);font-family:'DM Mono',monospace;font-size:0.85rem;letter-spacing:0.1em;width:190px;outline:none;transition:border-color 0.2s;}
.pw-input:focus{border-color:var(--gold);}
.pw-btn{background:rgba(224,57,45,0.13);border:1px solid var(--gold);border-radius:6px;color:var(--gold);font-family:'IBM Plex Mono',monospace;font-size:0.76rem;padding:0.6rem 1.2rem;cursor:pointer;letter-spacing:0.1em;transition:all 0.15s;}
.pw-btn:hover{background:rgba(224,57,45,0.22);}
.pw-error{color:var(--red);font-size:0.72rem;font-family:'IBM Plex Mono',monospace;height:1rem;}

/* ── PROSE ── */
.prose p{font-size:0.9rem;line-height:1.75;color:var(--text);margin-bottom:0.6rem;}
.prose ul{padding-left:1.1rem;margin-bottom:0.5rem;}
.prose li{font-size:0.88rem;line-height:1.7;color:var(--text);margin-bottom:0.3rem;}
.prose strong{color:var(--text);font-weight:700;}
.prose p:last-child{margin-bottom:0;}

/* ── DAY GRID ── */
.day-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0.4rem;margin:0.65rem 0;}
.day-cell{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:0.6rem 0.3rem;text-align:center;transition:border-color 0.15s;}
.day-num{font-family:'DM Sans',sans-serif;font-size:0.9rem;color:var(--text);margin-bottom:0.2rem;font-weight:700;}
.day-action{font-size:0.6rem;color:var(--text-dim);line-height:1.35;}
.day-save{font-size:0.58rem;color:var(--red);margin-top:4px;line-height:1.35;}

/* ── DIVIDER ── */
hr.divider{border:none;border-top:1px solid var(--border);margin:1.25rem 0;}

/* ── CODE ── */
code{font-family:'DM Mono',monospace;font-size:0.78rem;background:var(--surface2);border:1px solid var(--border);padding:3px 8px;border-radius:6px;color:var(--amber);}

/* ── FOOTER ── */
footer{margin-left:var(--sidebar-w);border-top:1px solid var(--border);padding:1.5rem 3rem;font-family:'DM Mono',monospace;font-size:0.72rem;color:var(--text-muted);letter-spacing:0.06em;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0.5rem;background:var(--surface);}

/* ── BACK TO TOP ── */
#back-to-top{position:fixed;bottom:5.5rem;right:1.5rem;z-index:800;width:40px;height:40px;border-radius:12px;background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-size:1rem;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all 0.2s;box-shadow:0 4px 16px rgba(0,0,0,0.4);}
#back-to-top:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);box-shadow:0 0 15px rgba(224,57,45,0.25);}
#back-to-top.visible{display:flex;}

/* ── RESPONSIVE ── */

/* ════════════════════════════════════════════
   TABLET  (≤900px)
════════════════════════════════════════════ */
@media(max-width:900px){
  /* layout */
  .sidebar{display:none;}
  #mainNav{display:none;}
  .hamburger{display:flex;align-items:center;justify-content:center;}
  .logo{width:auto;font-size:1.25rem;}
  .header-inner{padding:0 1rem;}
  .header-search-btn{max-width:none;}
  main{margin-left:0;padding:1.5rem 1.25rem 5rem;}
  footer{margin-left:0;padding:1rem 1.25rem 2rem;font-size:0.5rem;letter-spacing:0.1em;}

  /* hero */
  .hero-banner{margin-left:0;width:100%;height:300px;}
  .hero-title{font-size:3.5rem;}
  .hero-overlay::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(224,57,45,0.012) 2px,rgba(224,57,45,0.012) 4px);pointer-events:none;z-index:1;}
.hero-overlay{/* hud tint */padding:1.5rem 1.5rem 2rem;}
  .hero-sub{font-size:0.9rem;letter-spacing:0.2em;}

  /* grids */
  .home-grid{grid-template-columns:repeat(2,1fr);gap:0.75rem;}
  .qr-grid{grid-template-columns:1fr;}
  .qr-grid-2{grid-template-columns:1fr;}
  .power-grid{grid-template-columns:1fr;}
  .day-grid{grid-template-columns:repeat(4,1fr);}

  /* page header */
  .page-header h1{font-size:2rem;}
  .page-header{margin-bottom:1.25rem;padding-bottom:0.9rem;}

  /* cards */
  .qr-card-header h3{font-size:0.9rem;}
  .expand-trigger h3{font-size:1rem;}

  /* chat */
  #fam-chat{bottom:1rem;right:0.5rem;left:0.5rem;width:auto;max-width:none;}

  /* tables - allow horizontal scroll */
  .data-table{font-size:0.76rem;}
  .data-table th,.data-table td{padding:0.45rem 0.5rem;}

  /* gen tabs */
  .gen-tabs{gap:0.3rem;}
  .gen-tab{font-size:0.62rem;padding:5px 10px;}
}

/* ════════════════════════════════════════════
   PHONE  (≤480px)
════════════════════════════════════════════ */
@media(max-width:480px){
  /* layout */
  :root{--header-h:56px;}
  main{padding:1rem 0.9rem 5rem;}
  .header-inner{padding:0 0.75rem;gap:0.5rem;}
  .logo{font-size:1.1rem;letter-spacing:0.14em;}
  .logo span{font-size:0.44rem;letter-spacing:0.18em;}
  .header-search-btn{padding:0.4rem 0.65rem;}
  .header-search-btn p{font-size:0.7rem;}
  .header-search-btn kbd{display:none;}

  /* hero */
  .hero-banner{height:240px;}
  .hero-title{font-size:2.6rem;letter-spacing:0.1em;}
  .hero-eyebrow{font-size:0.55rem;letter-spacing:0.25em;}
  .hero-sub{font-size:0.78rem;letter-spacing:0.15em;margin-top:0.4rem;}
  .hero-overlay{padding:1rem 1rem 1.5rem;}
  .hero-scroll{position:absolute;z-index:2;display:none;}

  /* grids */
  .home-grid{grid-template-columns:repeat(2,1fr);gap:0.6rem;}
  .day-grid{grid-template-columns:repeat(2,1fr);}

  /* page header */
  .page-header h1{font-size:1.7rem;}
  .page-header p{font-size:0.62rem;}
  .section-label{font-size:0.54rem;letter-spacing:0.18em;margin-top:1.25rem;}

  /* cards */
  .home-card{padding:1rem 0.85rem;}
  .home-card h3{font-size:1rem;letter-spacing:0.1em;}
  .home-card p{font-size:0.72rem;}
  .home-card .hc-icon{font-size:1.5rem;margin-bottom:0.4rem;}
  .qr-card-header{padding:0.6rem 0.85rem;}
  .qr-card-header h3{font-size:0.85rem;}
  .qr-card-body{padding:0.85rem 0.85rem;}
  .expand-trigger{padding:0.75rem 0.9rem;}
  .expand-trigger h3{font-size:0.95rem;}
  .expand-content{padding:0.75rem 0.9rem 0.9rem;}

  /* tables — horizontal scroll container */
  .data-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -0.9rem;padding:0 0.9rem;}
  .data-table{min-width:420px;font-size:0.74rem;}
  .data-table th,.data-table td{padding:0.4rem 0.5rem;white-space:nowrap;}

  /* stat rows */
  .stat-row{flex-wrap:wrap;gap:0.25rem;}
  .stat-label{width:100%;font-size:0.68rem;color:var(--text-muted);}
  .stat-value{font-size:0.78rem;}
  .stat-note{margin-left:0;text-align:left;}

  /* formation bar */
  .formation-bar{height:32px;}
  .formation-bar div{font-size:0.6rem;}

  /* alerts */
  .alert{font-size:0.8rem;padding:0.6rem 0.75rem;}

  /* hero chips */
  .hero-lineup{gap:0.3rem;}
  .hero-chip{font-size:0.68rem;padding:3px 8px;}

  /* prose */
  .prose p,.prose li{font-size:0.82rem;}

  /* pw gate */
  .pw-form{flex-direction:column;align-items:center;gap:0.5rem;}
  .pw-input{width:100%;max-width:260px;}
  .pw-btn{width:100%;max-width:260px;text-align:center;}

  /* gen tabs scroll */
  .gen-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px;}
  .gen-tab{flex-shrink:0;}

  /* phase timeline tighter */
  .phase-content{padding-bottom:0.9rem;}
  .phase-title{font-size:0.9rem;}

  /* mobile nav drawer */
  .mobile-nav{padding:1rem;}
  .mobile-nav a{font-size:1rem;padding:0.8rem 1rem;}

  /* footer */
  footer{font-size:0.5rem;letter-spacing:0.1em;padding:1rem 0.9rem 2rem;text-align:center;}

  /* back to top — move left of FAB */
  #back-to-top{bottom:5rem;right:1rem;width:36px;height:36px;font-size:0.9rem;}
}

/* ════════════════════════════════════════════
   TINY PHONES  (≤360px)
════════════════════════════════════════════ */
@media(max-width:360px){
  main{padding:0.85rem 0.75rem 5rem;}
  .hero-banner{height:200px;}
  .hero-title{font-size:2.1rem;}
  .home-grid{grid-template-columns:1fr;}
  .page-header h1{font-size:1.5rem;}
  .hamburger{padding:5px 9px;}
}

/* ════════════════════════════════════════════
   TOUCH / iOS OVERRIDES
════════════════════════════════════════════ */
@media(hover:none) and (pointer:coarse){
  /* remove hover transforms on touch — prevents sticky hover state */
  .home-card:hover{transform:none;}
  .qr-card:hover{box-shadow:none;border-color:var(--border);}
  nav a:hover{background:none;border-left-color:transparent;color:var(--text-dim);}
  /* enlarge tap targets */
  nav a{padding:0.75rem 0.9rem;}
  .expand-trigger{min-height:52px;}
  .gen-tab{min-height:38px;display:inline-flex;align-items:center;}
  .mobile-nav a{min-height:52px;display:flex;align-items:center;}
  /* remove text-size-adjust */
  body{-webkit-text-size-adjust:100%;text-size-adjust:100%;}
}

/* safe area for notched iPhones */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  footer{padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));}
  .mobile-nav{padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));}
  #fam-chat{bottom:calc(1rem + env(safe-area-inset-bottom));}
}
/* ── HERO BANNER ── */
.hero-banner{
  margin-left:var(--sidebar-w);
  position:relative;width:calc(100% - var(--sidebar-w));
  height:500px;overflow:hidden;
  border-bottom:none;
  flex-shrink:0;
  box-shadow:0 4px 0 var(--lava),0 8px 0 rgba(204,34,0,0.3),0 16px 40px rgba(0,0,0,0.8);
}
.hero-banner::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent 0%,var(--gold-dim) 20%,var(--gold) 50%,var(--gold-dim) 80%,transparent 100%);
  animation:ember-line 3s ease-in-out infinite;
}
@keyframes ember-line{/* cyber-pulse */
  0%,100%{opacity:0.5;}
  50%{opacity:1;box-shadow:0 0 20px var(--gold);}
}
.hero-img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 20%;
  display:block;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,30,60,0.25) 0%,rgba(14,14,14,0.2) 40%,rgba(14,14,14,0.94) 100%);
  display:flex;flex-direction:column;
  align-items:flex-start;justify-content:flex-end;
  padding:2.5rem 3rem;
}
.hero-eyebrow{
  font-family:'IBM Plex Mono',monospace;font-size:0.7rem;
  letter-spacing:0.3em;text-transform:uppercase;
  color:var(--amber);margin-bottom:0.5rem;opacity:0.9;
}
.hero-title{
  font-family:'Cinzel',serif;font-size:4.5rem;font-weight:700;
  color:#fff;letter-spacing:0.1em;line-height:1;
  text-shadow:0 0 40px rgba(224,57,45,0.8),0 4px 20px rgba(0,0,0,0.9);
}
.hero-sub{
  font-family:'IBM Plex Sans',sans-serif;font-size:1rem;
  color:var(--amber);margin-top:0.5rem;letter-spacing:0.15em;
  text-shadow:0 2px 8px rgba(0,0,0,0.8);
}
.hero-scroll{position:absolute;z-index:2;
  position:absolute;bottom:1.25rem;right:2rem;
  font-family:'IBM Plex Mono',monospace;font-size:0.6rem;
  letter-spacing:0.2em;color:rgba(255,160,64,0.6);
  animation:pulse-scroll 2s ease-in-out infinite;
}
@keyframes pulse-scroll{0%,100%{opacity:0.6;transform:translateY(0);}50%{opacity:1;transform:translateY(3px);}}
@media(max-width:900px){
  .hero-banner{margin-left:0;width:100%;height:280px;}
  .hero-title{font-size:2.8rem;}
  .hero-overlay{padding:1.5rem;}
}
@media(max-width:480px){
  .hero-banner{height:220px;}
  .hero-title{font-size:2rem;}
}

/* ── ACCENT DETAILS ── */


.data-table td{padding:0.7rem 0.75rem;border-bottom:1px solid var(--border);color:var(--text);font-size:0.875rem;vertical-align:top;line-height:1.5;}
.prose p{font-size:0.85rem;line-height:1.7;color:var(--text);margin-bottom:0.5rem;font-family:'Exo 2',sans-serif;}
.prose li{font-size:0.84rem;line-height:1.65;color:var(--text);margin-bottom:0.25rem;font-family:'Exo 2',sans-serif;}
.prose strong{color:var(--gold);font-weight:700;}
.stat-label{color:var(--text-dim);width:140px;flex-shrink:0;font-size:0.76rem;padding-top:1px;font-family:'Share Tech Mono',monospace;}
.stat-value{color:var(--text);font-family:'Share Tech Mono',monospace;font-size:0.76rem;}
.alert{padding:0.75rem 1rem;border-radius:0;font-size:0.84rem;margin:0.65rem 0;display:flex;gap:0.6rem;align-items:flex-start;line-height:1.55;font-family:'Rajdhani',sans-serif;font-weight:500;}
.et-sub{font-family:'DM Mono',monospace;font-size:0.72rem;color:var(--text-dim);letter-spacing:0.01em;display:block;margin-top:2px;}
code{font-family:'Share Tech Mono',monospace;font-size:0.74rem;background:var(--surface2);border:1px solid var(--border);padding:2px 6px;border-radius:0;color:var(--amber);}

/* ── HUD ACCENT EXTRAS ── */
.alert{font-family:'Exo 2',sans-serif;}
.stat-row{border-bottom:1px solid rgba(20,32,53,0.7);}
.day-cell{background:var(--surface2);border:1px solid var(--border);border-radius:4px;}
.day-action{font-family:'Exo 2',sans-serif;font-size:0.62rem;}
.hero-chip.inf{border-left:3px solid var(--blue);}
.hero-chip.arc{border-left:3px solid var(--red);}
/* glow pulse on active page nav item */


/* subtle corner accent on cards */

/* search overlay bg */
.search-overlay{background:rgba(14,14,14,0.9);}
/* inline strong in tables */
td strong{color:var(--gold);}
/* pw btn */
.pw-btn{font-family:'Space Mono',monospace;border-radius:3px;}
/* back to top */
#back-to-top{border-radius:3px;}

/* ── POLISH EXTRAS ── */
.qr-card-header .icon{font-size:1.1rem;}
.stat-row{padding:0.55rem 0;}
hr.divider{border-top:1px solid var(--border);margin:1.5rem 0;}
.sr-snippet{font-family:'DM Sans',sans-serif;font-size:0.82rem;color:var(--text-dim);margin-top:4px;line-height:1.5;}
.sr-section{font-family:'DM Mono',monospace;font-size:0.65rem;color:var(--text-muted);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:2px;}
.search-hint{font-family:'DM Mono',monospace;font-size:0.7rem;color:var(--text-muted);}
.expand-arrow{font-family:'DM Mono',monospace;font-size:0.75rem;color:var(--text-muted);transition:transform 0.22s;flex-shrink:0;}
.day-action{font-family:'DM Sans',sans-serif;font-size:0.65rem;}
.day-save{font-family:'DM Sans',sans-serif;font-size:0.62rem;}
.alert{font-family:'DM Sans',sans-serif;}
.alert-icon{font-size:1rem;}
.section-label{font-weight:500;}
/* Remove inline text-size overrides in extra CSS */
td strong{color:var(--text);font-weight:700;}
/* Mobile nav section */
@media(max-width:900px){
  main{padding:1.75rem 1.5rem 5rem;}
  .page-header h1{font-size:1.4rem;}
}
@media(max-width:480px){
  main{padding:1.25rem 1rem 5rem;}
  .page-header h1{font-size:1.2rem;}
  footer{font-size:0.65rem;letter-spacing:0.04em;}
  .qr-card{border-radius:10px;}
  .expandable{border-radius:10px;}
  .home-card{border-radius:12px;}
  .mobile-nav a{border-radius:10px;}
}