:root {
  --bg: #efe4cc;
  --paper: #f6edd9;
  --paper-2: #ead9ba;
  --text: #392c1f;
  --muted: #77654e;
  --line: rgba(85, 58, 31, 0.22);
  --accent: #9c6b31;
  --accent-2: #6f4723;
  --shadow: rgba(54, 35, 17, 0.16);
}
:root.dark {
  --bg: #17120e;
  --paper: #211912;
  --paper-2: #2a2118;
  --text: #eadcc4;
  --muted: #b49d7d;
  --line: rgba(234, 220, 196, 0.18);
  --accent: #c59455;
  --accent-2: #e0b878;
  --shadow: rgba(0, 0, 0, 0.34);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at 20% 10%, rgba(156, 107, 49, 0.12), transparent 28rem),
    radial-gradient(circle at 80% 20%, rgba(156, 107, 49, 0.10), transparent 26rem),
    var(--bg);
  color: var(--text);
  font-family: Georgia, "Times New Roman", serif;
}
.grain { position: fixed; inset: 0; pointer-events: none; opacity: .18; background-image: linear-gradient(90deg, rgba(120,80,40,.08) 1px, transparent 1px), linear-gradient(rgba(120,80,40,.06) 1px, transparent 1px); background-size: 42px 42px; mask-image: radial-gradient(circle, black, transparent 80%); }
.progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: var(--accent); z-index: 20; }
.site-header { position: sticky; top: 0; z-index: 10; display: flex; align-items: center; justify-content: space-between; gap: 1rem; max-width: 1220px; margin: 0 auto; padding: 1.1rem 1.25rem; backdrop-filter: blur(12px); }
.logo { color: var(--text); text-decoration: none; font-size: 1.45rem; font-weight: 700; letter-spacing: .04em; }
.nav { display: flex; gap: 1rem; align-items: center; }
.nav a, .theme-toggle, .tab, .card-link, .modal a { color: var(--accent-2); text-decoration: none; font-weight: 700; }
.nav a { font-size: .94rem; opacity: .9; }
.nav a:hover, .card:hover .card-link { color: var(--accent); }
.theme-toggle { width: 2.4rem; height: 2.4rem; border: 1px solid var(--line); border-radius: 50%; background: color-mix(in srgb, var(--paper) 70%, transparent); cursor: pointer; }
.section { max-width: 1220px; margin: 0 auto; padding: 2rem 1.25rem; }
.hero { display: grid; grid-template-columns: 1fr 220px; align-items: center; gap: 2rem; padding-top: 4rem; }
.eyebrow { margin: 0 0 .75rem; color: var(--accent); font-size: .78rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 1rem; font-size: clamp(2.6rem, 7vw, 5.2rem); line-height: .95; letter-spacing: -.04em; }
h1 span { color: var(--muted); font-size: .55em; }
.intro, .card p, .classic-item p, .modal p { color: var(--muted); font-size: 1.05rem; line-height: 1.65; }
.compass-mark { display: grid; place-items: center; opacity: .8; }
.compass-mark svg { width: min(220px, 55vw); height: auto; }
.compass-mark circle { fill: none; stroke: var(--accent); stroke-width: 2; opacity: .55; }
.compass-mark path { fill: var(--accent); opacity: .75; }
.toolbar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 1rem 0; }
.tabs { display: flex; gap: .5rem; flex-wrap: wrap; }
.tab { border: 1px solid var(--line); border-radius: 12px; background: color-mix(in srgb, var(--paper) 75%, transparent); padding: .7rem .95rem; cursor: pointer; font-family: inherit; }
.tab.active { background: var(--accent); color: var(--paper); border-color: var(--accent); }
.search { display: flex; align-items: center; gap: .75rem; color: var(--muted); }
.search input { width: min(360px, 52vw); border: 1px solid var(--line); border-radius: 12px; background: var(--paper); color: var(--text); padding: .75rem .9rem; font: inherit; outline: none; }
.character-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: .85rem; align-items: stretch; }
.character-card { display: grid; grid-template-columns: 74px minmax(0, 1fr); gap: .9rem; align-items: center; min-height: 108px; padding: .75rem; border: 1px solid var(--line); border-radius: 12px; background: color-mix(in srgb, var(--paper) 86%, transparent); box-shadow: 0 12px 34px var(--shadow); color: var(--text); cursor: pointer; transition: transform .2s ease, border-color .2s ease; }
.character-card:hover { transform: translateY(-3px); border-color: var(--accent); }
.portrait { width: 70px; height: 70px; border-radius: 9px; border: 1px solid var(--line); display: grid; place-items: center; overflow: hidden; background: var(--paper-2); color: var(--accent); font-weight: 700; font-size: 1.4rem; }
.portrait img { width: 100%; height: 100%; object-fit: cover; }
.character-card h3 { margin: 0 0 .2rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 1.15rem; }
.meta { margin: 0; color: var(--text); font-size: .95rem; }
.hp { margin: .35rem 0 0; color: var(--accent); font-size: .9rem; }
.classic-list { border: 1px solid var(--line); border-radius: 16px; overflow: hidden; background: color-mix(in srgb, var(--paper) 86%, transparent); box-shadow: 0 18px 60px var(--shadow); }
.classic-item { display: grid; grid-template-columns: 1fr auto; gap: 1rem; padding: 1.1rem 1.25rem; border-bottom: 1px solid var(--line); }
.classic-item:last-child { border-bottom: none; }
.classic-item h3 { margin-bottom: .25rem; }
.status { color: var(--accent); font-weight: 700; white-space: nowrap; }
.modal { width: min(720px, calc(100vw - 2rem)); border: 1px solid var(--line); border-radius: 18px; background: var(--paper); color: var(--text); box-shadow: 0 30px 100px rgba(0,0,0,.45); padding: 0; }
.modal::backdrop { background: rgba(0,0,0,.55); backdrop-filter: blur(3px); }
.modal-close { position: absolute; right: .8rem; top: .6rem; border: 0; background: transparent; color: var(--muted); font-size: 2rem; cursor: pointer; }
.modal-body { display: grid; grid-template-columns: 120px 1fr; gap: 1.25rem; padding: 2rem; }
.modal .portrait { width: 120px; height: 120px; }
.modal h2 { margin: 0 2rem .25rem 0; font-size: 2rem; }
.modal-tags { display: flex; gap: .5rem; flex-wrap: wrap; margin: .85rem 0; }
.modal-tags span { border: 1px solid var(--line); border-radius: 999px; padding: .35rem .6rem; color: var(--muted); }
.footer { max-width: 1220px; margin: 0 auto; padding: 2rem 1.25rem 3rem; display: flex; justify-content: space-between; color: var(--muted); border-top: 1px solid var(--line); }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
@media (max-width: 980px) { .character-grid { grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); } }
@media (max-width: 720px) { .nav { display: none; } .hero { grid-template-columns: 1fr; padding-top: 2rem; } .compass-mark { display: none; } .toolbar { align-items: stretch; flex-direction: column; } .search { align-items: stretch; flex-direction: column; gap: .4rem; } .search input { width: 100%; } .character-grid { grid-template-columns: 1fr; } .character-card { min-height: 104px; } .modal-body { grid-template-columns: 1fr; } .footer { flex-direction: column; gap: .45rem; } }
