:root {
  --bg: #0c0e14;
  --panel: #161a24;
  --panel-2: #1f2533;
  --ink: #e8eaf0;
  --muted: #8b93a7;
  --accent: #f0b429;
  --line: #2a3142;
  --live: #10b981;
  --building: #3b82f6;
  --dead: #6b7280;
  --danger: #ef4444;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  line-height: 1.5;
}
a { color: inherit; text-decoration: none; }
.muted { color: var(--muted); }

/* topbar */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .5rem;
  padding: .8rem 1.2rem; background: var(--panel);
  border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 10;
}
.brand { font-size: 1.25rem; font-weight: 700; color: var(--accent); }
.topbar nav { display: flex; gap: 1rem; flex-wrap: wrap; }
.topbar nav a { color: var(--muted); }
.topbar nav a:hover { color: var(--ink); }

.wrap { max-width: 1100px; margin: 0 auto; padding: 1.2rem; }

/* flashes */
.flash { padding: .6rem .9rem; border-radius: 8px; margin-bottom: .8rem; }
.flash-ok { background: #0f2e22; color: #7ee2b8; border: 1px solid #1d5c44; }
.flash-warn { background: #3a2410; color: #f0b429; border: 1px solid #6b4a16; }

/* login */
.login-card {
  max-width: 360px; margin: 12vh auto; background: var(--panel);
  padding: 2rem; border-radius: 14px; border: 1px solid var(--line); text-align: center;
}
.login-card h1 { color: var(--accent); margin: 0; }
.login-card form { display: flex; flex-direction: column; gap: .7rem; margin-top: 1.2rem; }

/* dashboard */
.dashboard {
  display: flex; flex-wrap: wrap; gap: 1rem; align-items: center;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 1rem 1.2rem; margin-bottom: 1.2rem;
}
.stat { display: flex; flex-direction: column; min-width: 90px; }
.stat-num { font-size: 1.6rem; font-weight: 700; color: var(--accent); }
.stat-label { font-size: .8rem; color: var(--muted); }
.sync-all { margin-left: auto; }
.dash-actions { margin-left: auto; display: flex; gap: .5rem; flex-wrap: wrap; }

/* filters */
.filters { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.2rem; }
.filters input[type=search] { flex: 1 1 220px; }

/* poster grid */
.poster-grid {
  display: grid; gap: 1.1rem;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}
.poster { display: block; transition: transform .12s ease; }
.poster:hover { transform: translateY(-4px); }
.poster-img { position: relative; aspect-ratio: 2/3; border-radius: 10px; overflow: hidden;
  background: var(--panel-2); border: 1px solid var(--line); }
.poster-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.poster-meta { padding: .5rem .2rem; display: flex; flex-direction: column; }
.poster-meta strong { font-size: .95rem; }
.poster-meta .muted { font-size: .8rem; }

/* badges */
.badge { position: absolute; top: .5rem; padding: .15rem .5rem; border-radius: 99px;
  font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.badge-live { left: .5rem; background: var(--live); color: #03190f; }
.badge-building { left: .5rem; background: var(--building); color: #061226; }
.badge-dead { left: .5rem; background: var(--dead); color: #fff; }
.badge-nofront { right: .5rem; background: #000a; color: #fff; border: 1px solid #fff3; }

.badge-local { right: .5rem; background: #1e3a8a; color: #cfe0ff; }
.badge-archived { background: #4b5563; color: #fff; }

/* class sections */
.class-section { margin-bottom: 1.8rem; }
.class-section > h2 { font-size: 1.05rem; margin: 0 0 .7rem; padding-bottom: .3rem;
  border-bottom: 1px solid var(--line); }
.class-section > h2 .muted { font-size: .85rem; font-weight: 400; }

/* archived: diagonal banner + dimmed art */
.poster.is-archived .poster-img img, .poster-img.is-archived img { opacity: .45; filter: grayscale(.5); }
.archived-banner {
  position: absolute; top: 42%; left: -12%; width: 124%;
  transform: rotate(-22deg); text-align: center;
  background: rgba(190, 40, 40, .88); color: #fff;
  font-weight: 800; letter-spacing: .15em; text-transform: uppercase;
  font-size: .8rem; padding: .3rem 0; pointer-events: none;
  box-shadow: 0 2px 8px #0008;
}

.empty { text-align: center; color: var(--muted); margin-top: 3rem; }

/* detail */
.detail { display: grid; grid-template-columns: 300px 1fr; gap: 2rem; align-items: start; }
.detail-poster img { width: 100%; border-radius: 12px; border: 1px solid var(--line); }
.detail-poster form { margin-top: .7rem; }
.detail-poster .poster-img { aspect-ratio: 2/3; border-radius: 12px; overflow: hidden; position: relative; border: 1px solid var(--line); }
.detail-poster .poster-img img { width: 100%; height: 100%; object-fit: cover; border: none; }
.btn-quiet { background: var(--panel-2); color: var(--muted); border: 1px solid var(--line); width: 100%; }
.btn-quiet:hover { color: var(--ink); }
.deps { margin-top: 1.2rem; }
.deps h3 { font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); margin: 0 0 .4rem; }
.deps ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .25rem; }
.deps li { background: var(--panel-2); border: 1px solid var(--line); border-radius: 6px; padding: .3rem .55rem; font-size: .85rem; }
.frontend-note { background: #11203a; border: 1px solid #1e3a8a; color: #cfe0ff; padding: .5rem .8rem; border-radius: 8px; display: inline-block; }
.entry-form label.check { flex-direction: row; align-items: center; gap: .4rem; }
.detail-head { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.detail-head h1 { margin: 0; }
.detail-head .badge { position: static; }
.desc { color: #cfd4e0; }
.links { display: flex; gap: .6rem; flex-wrap: wrap; margin: 1rem 0; }
.about { margin: 1.2rem 0; border-top: 1px solid var(--line); padding-top: 1rem; }
.about h2 { font-size: 1rem; color: var(--muted); margin: 0 0 .5rem; text-transform: uppercase; letter-spacing: .05em; }
.about p { color: #cfd4e0; margin: 0 0 .7rem; }
.facts { display: grid; grid-template-columns: 130px 1fr; gap: .35rem 1rem; margin: 1.2rem 0; }
.facts dt { color: var(--muted); }
.facts dd { margin: 0; }
.tag { font-size: .7rem; background: var(--panel-2); border: 1px solid var(--line);
  padding: .05rem .4rem; border-radius: 6px; color: var(--muted); }

/* checklist */
.checklist { margin-top: 1.5rem; border-top: 1px solid var(--line); padding-top: 1rem; }
.add-item { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: .8rem; }
.add-item input[type=text] { flex: 1 1 200px; }
.items { list-style: none; padding: 0; margin: 0; }
.item { display: flex; align-items: center; gap: .6rem; padding: .45rem 0;
  border-bottom: 1px solid var(--line); }
.item.done .item-text { text-decoration: line-through; color: var(--muted); }
.item-text { flex: 1; }
.prio-high { border-left: 3px solid var(--danger); padding-left: .5rem; }
.prio-tag-high { color: #fca5a5; border-color: #7f1d1d; }
.prio-tag-med { color: #fcd34d; }
.due { font-size: .8rem; color: var(--muted); }
.check, .del { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 1rem; }
.check:hover { color: var(--live); }
.del:hover { color: var(--danger); }

/* forms */
input, textarea, select, button {
  font: inherit; color: var(--ink); background: var(--panel-2);
  border: 1px solid var(--line); border-radius: 8px; padding: .5rem .7rem;
}
input::placeholder, textarea::placeholder { color: #5b6478; }
button { background: var(--accent); color: #1a1300; border: none; font-weight: 700; cursor: pointer; }
button:hover { filter: brightness(1.08); }
button.danger, .danger { background: var(--danger); color: #fff; }
.btn { display: inline-block; background: var(--panel-2); border: 1px solid var(--line);
  padding: .5rem .8rem; border-radius: 8px; font-weight: 600; }
.btn:hover { border-color: var(--accent); }
.btn-launch { background: #0f2e22; border-color: #1d5c44; color: #7ee2b8; }
.btn-launch:hover { border-color: var(--live); }

.entry-form { display: flex; flex-direction: column; gap: 1rem; max-width: 680px; }
.entry-form label { display: flex; flex-direction: column; gap: .3rem; font-size: .85rem; color: var(--muted); }
.entry-form label input, .entry-form label textarea, .entry-form label select { color: var(--ink); }
.entry-form .row { display: flex; gap: 1rem; flex-wrap: wrap; }
.entry-form .row label { flex: 1 1 140px; }
.form-actions { display: flex; gap: .8rem; align-items: center; }

.settings-card { background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 1.2rem; margin-bottom: 1.2rem; max-width: 640px; }
.settings-card input[type=password] { width: 100%; margin-bottom: .8rem; }
.ok-text { color: var(--live); } .warn-text { color: var(--accent); }

@media (max-width: 720px) {
  .detail { grid-template-columns: 1fr; }
  .detail-poster { max-width: 240px; }
}
