:root{--bg: #e8e8e8;--surface: #f4f4f4;--surface-alt: #dcdcdc;--line: #b8b8b8;--ink: #2b2b2b;--ink-soft: #5a5a5a;--ink-faint: #8a8a8a;--accent: #3a3a3a;--radius: 12px;--shadow: 0 2px 8px rgba(0, 0, 0, .12);--font: "Inter", system-ui, -apple-system, "Segoe UI", "Noto Sans Thai", sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased}a{color:var(--ink)}button{font-family:inherit;cursor:pointer}.app{max-width:880px;margin:0 auto;padding:16px}.nav{display:flex;align-items:center;gap:16px;padding:8px 0 16px;border-bottom:1px solid var(--line);margin-bottom:16px}.nav .brand{font-weight:800;font-size:20px;text-decoration:none;margin-right:auto}.nav a{text-decoration:none;color:var(--ink-soft);font-weight:600;padding:6px 8px;border-radius:8px}.nav a.active{color:var(--ink);background:var(--surface-alt)}.nav .brand svg{display:block}.nav .icon-btn{padding:6px 8px;line-height:0}.app-version{text-align:center;color:var(--ink-soft);font-size:12px;font-variant-numeric:tabular-nums;opacity:.6;margin-top:4px;padding-bottom:8px}.btn{background:var(--accent);color:#f4f4f4;border:none;border-radius:999px;padding:10px 20px;font-weight:700;font-size:15px}.btn:hover{background:#222}.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}.btn.ghost:hover{background:var(--surface-alt)}.btn:disabled{opacity:.5;cursor:not-allowed}.game-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}.canvas-frame{position:relative;width:100%;max-width:800px;aspect-ratio:800 / 300;background:#d8d8d8;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);touch-action:none}.canvas-frame canvas{display:block;width:100%;height:100%}.hud{position:absolute;top:10px;left:12px;right:12px;display:flex;justify-content:space-between;font-weight:700;font-size:15px;color:var(--ink);pointer-events:none;text-shadow:0 1px 0 rgba(255,255,255,.5)}.province-label{position:absolute;top:40%;left:50%;transform:translate(-50%);font-size:22px;font-weight:800;color:var(--ink);background:#f4f4f4b3;padding:4px 14px;border-radius:999px;pointer-events:none;animation:fadeProvince 2s ease forwards}@keyframes fadeProvince{0%{opacity:0;transform:translate(-50%) translateY(6px)}15%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1}to{opacity:0}}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#e8e8e8d1;text-align:center;padding:16px;pointer-events:none}.overlay button{pointer-events:auto}.overlay h2{margin:0;font-size:26px}.overlay .dist{font-size:30px;font-weight:800}.overlay .row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.controls-row{display:flex;gap:12px;align-items:center;width:100%;max-width:800px;justify-content:space-between}.hint{color:var(--ink-faint);font-size:13px}.ad-zone{width:100%;max-width:800px;margin-top:28px;padding-top:20px;border-top:1px solid var(--line)}.ad-zone .ad-label{font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;text-align:center;margin-bottom:8px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.lb-table{width:100%;border-collapse:collapse}.lb-table th,.lb-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line)}.lb-table th{color:var(--ink-soft);font-size:13px;text-transform:uppercase;letter-spacing:.05em}.lb-table td.num{text-align:right;font-variant-numeric:tabular-nums}.lb-table tr.me{background:var(--surface-alt);font-weight:700}.province-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px}.province-cell{aspect-ratio:1;border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;text-align:center;background:var(--surface);color:var(--ink-faint);padding:4px}.province-cell.visited{background:var(--accent);color:#f4f4f4;border-color:var(--accent)}.province-cell img{width:28px;height:28px;object-fit:contain;opacity:.5}.province-cell.visited img{opacity:1;filter:invert(1)}.cosmetic-grid{display:flex;flex-wrap:wrap;gap:10px}.cosmetic-chip{border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:8px 14px;font-weight:600}.cosmetic-chip.equipped{background:var(--accent);color:#f4f4f4;border-color:var(--accent)}.cosmetic-chip.locked{opacity:.45;cursor:not-allowed}.muted{color:var(--ink-faint)}.section-title{font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin:20px 0 10px}.stat{font-size:32px;font-weight:800}.loading{color:var(--ink-faint);padding:40px;text-align:center}
