:root {
  --bg: #070b18;
  --bg2: #0c1226;
  --card: #111935;
  --card2: #15204340;
  --line: #25356b;
  --text: #eaf0ff;
  --muted: #93a3d0;
  --accent: #f4cf5a;      /* crown gold */
  --accent2: #5aa9ff;     /* keyblade blue */
  --tier-endgame: #ff7bd0;
  --tier-mastery: #c4b6ff;
  --tier-check: #6fe0c8;
  --danger: #ff7b6b;
  --warn: #ffcf5c;
  --done: #5fd08a;
  --radius: 12px;
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: radial-gradient(1000px 380px at 50% -120px, #182a5e, #070b18 70%);
  color: var(--text);
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  padding: 16px;
}
#app { max-width: min(1100px, 96vw); margin: 0 auto; }
.loading, .error { padding: 48px 16px; color: var(--muted); text-align: center; }
.error code { background: #000; padding: 1px 5px; border-radius: 4px; color: var(--accent2); }
a { color: var(--accent); }
.muted { color: var(--muted); }
.small { font-size: 12px; }

/* header */
.app-header { margin-bottom: 14px; }
.title-row { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.app-header h1 { font-size: 20px; margin: 0; letter-spacing: .2px; }
.subtitle { color: var(--accent); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; }
.scope { color: var(--muted); font-size: 12px; margin-top: 4px; }
.note { color: var(--muted); font-size: 12px; margin-top: 6px; border-left: 2px solid var(--accent2); padding-left: 9px; }
.note b { color: var(--accent2); }

/* countdown */
.countdown { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; background: linear-gradient(180deg, #12204a, #0c1530); border: 1px solid #2c4490; border-radius: var(--radius); padding: 10px 14px; margin: 12px 0; }
.countdown .big { font-size: 22px; font-weight: 800; font-variant-numeric: tabular-nums; color: var(--accent); }
.countdown input { background: var(--bg2); border: 1px solid var(--line); color: var(--text); padding: 6px 9px; border-radius: 8px; }
.countdown.live { border-color: var(--accent); }

/* meters */
.meters { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-top: 12px; }
@media (max-width: 720px) { .meters { grid-template-columns: 1fr; } }
.progress-block { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 10px 12px; }
.progress-block.overall { grid-column: 1 / -1; }
.progress-row { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 6px; }
.progress-label { color: var(--muted); }
.progress-num { color: var(--text); font-variant-numeric: tabular-nums; font-weight: 700; }
.progress { height: 9px; background: #050a18; border-radius: 99px; overflow: hidden; }
.progress .bar { height: 100%; background: linear-gradient(90deg, #b8932f, var(--accent)); border-radius: 99px; transition: width .25s ease; }
.progress.blue .bar { background: linear-gradient(90deg, #2f6aae, var(--accent2)); }

.minigrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 8px; margin-top: 10px; }
.stat { background: var(--card2); border: 1px solid var(--line); border-radius: 10px; padding: 7px 10px; font-size: 12px; display: flex; justify-content: space-between; align-items: center; gap: 6px; }
.stat .v { font-variant-numeric: tabular-nums; font-weight: 700; }
.stat.full { border-color: var(--done); color: var(--done); }

/* controls */
.controls { display: flex; flex-wrap: wrap; gap: 10px 14px; align-items: center; margin: 16px 0 6px; }
.toggle { display: inline-flex; gap: 6px; align-items: center; color: var(--muted); font-size: 13px; cursor: pointer; }
.controls-right { display: flex; gap: 8px; align-items: center; margin-left: auto; flex-wrap: wrap; }
.search { background: var(--bg2); border: 1px solid var(--line); color: var(--text); padding: 7px 11px; border-radius: 8px; min-width: 180px; }
.btn { background: var(--card2); border: 1px solid var(--line); color: var(--text); border-radius: 8px; padding: 7px 12px; cursor: pointer; font-weight: 600; font-size: 13px; }
.btn:hover { border-color: var(--accent); }
.btn.danger { color: var(--danger); }
.sync-row { display: flex; justify-content: flex-end; min-height: 14px; margin-top: 2px; }
.sync-status { font-size: 11px; color: var(--accent2); font-variant-numeric: tabular-nums; }

/* "up next" focus banner */
.focus { background: linear-gradient(180deg, #15224c, #101a38); border: 1px solid var(--accent2); border-radius: var(--radius); padding: 12px 14px; margin: 12px 0 18px; }
.focus .lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--accent2); font-weight: 700; }
.focus .ttl { font-size: 16px; font-weight: 700; margin: 3px 0; }
.focus .where { color: var(--muted); font-size: 13px; }
.focus a { cursor: pointer; }

/* phases */
.phase { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); margin: 12px 0; overflow: hidden; }
.phase.complete { opacity: .62; }
.phase.tier-endgame { border-color: #7a3a66; }
.phase.tier-check { border-color: #2c5d59; }
.phase-head { display: flex; align-items: center; gap: 10px; padding: 12px 14px; cursor: pointer; flex-wrap: wrap; }
.phase-head h2 { font-size: 15px; margin: 0; flex: 1; min-width: 180px; }
.era { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; padding: 2px 8px; border-radius: 99px; white-space: nowrap; background: #122a4a; color: var(--accent2); border: 1px solid #2c557b; }
.era.endgame { background: #3a1430; color: var(--tier-endgame); border-color: #7a3a66; }
.era.mastery { background: #241f44; color: var(--tier-mastery); border-color: #4c4288; }
.era.check { background: #10302c; color: var(--tier-check); border-color: #2c6b62; }
.era.finale { background: #3a2a12; color: var(--accent); border-color: #6b531e; }
.phase-count { font-size: 12px; color: var(--muted); font-variant-numeric: tabular-nums; white-space: nowrap; }
.phase-blurb { padding: 0 14px 8px; color: var(--muted); font-size: 12.5px; }
.phase-body { padding: 4px 10px 12px; }
.caret { color: var(--muted); transition: transform .15s ease; }
.phase.collapsed .caret { transform: rotate(-90deg); }
.phase.collapsed .phase-body, .phase.collapsed .phase-blurb { display: none; }

/* steps */
.step { border: 1px solid var(--line); border-radius: 10px; margin: 8px 4px; background: #0d1530; }
.step.done { opacity: .55; }
.step.missable { border-color: #6b4f1e; }
.step-head { display: flex; gap: 8px; align-items: baseline; padding: 9px 12px 4px; }
.step-head .stitle { font-weight: 700; font-size: 14px; flex: 1; }
.step-loc { color: var(--accent2); font-size: 12px; }
.step-do { padding: 0 12px 6px; color: var(--muted); font-size: 12.5px; }
.missable-flag { display: inline-block; background: #3a2a12; color: var(--warn); border: 1px solid #6b4f1e; font-size: 10.5px; font-weight: 700; padding: 1px 7px; border-radius: 99px; text-transform: uppercase; letter-spacing: .4px; }
.missable-note { padding: 0 12px 6px; color: var(--warn); font-size: 12px; }
.tip { margin: 2px 12px 8px; padding: 8px 10px; background: #0e1f3a; border: 1px solid #2c4d86; border-left: 3px solid var(--accent2); border-radius: 8px; color: #cfe0ff; font-size: 12.5px; line-height: 1.55; }
.tip-lbl { color: var(--accent2); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; margin-right: 4px; }

/* items */
.items { list-style: none; margin: 0; padding: 2px 8px 8px; }
.item { display: flex; align-items: center; gap: 10px; padding: 6px 6px; border-radius: 8px; }
.item:hover { background: #131e40; }
.item label { display: flex; align-items: center; gap: 10px; cursor: pointer; flex: 1; }
.item input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--accent); flex: none; }
.item .cat-pill { font-size: 10px; color: var(--muted); border: 1px solid var(--line); border-radius: 99px; padding: 0 7px; white-space: nowrap; }
.item.checked .txt { text-decoration: line-through; color: var(--muted); }
.item .verify { font-size: 10px; color: #c79a3a; border: 1px dashed #6b531e; border-radius: 99px; padding: 0 6px; }

footer { color: var(--muted); font-size: 11.5px; text-align: center; margin: 26px 0 10px; line-height: 1.7; }
.flash { position: fixed; left: 50%; bottom: 22px; transform: translateX(-50%); background: var(--accent); color: #1c1405; padding: 9px 16px; border-radius: 99px; font-weight: 700; font-size: 13px; box-shadow: 0 6px 20px #0008; opacity: 0; transition: opacity .2s; pointer-events: none; }
.flash.show { opacity: 1; }
