:root{--bg: #f4f2ec;--card: #ffffff;--ink: #1c1d1a;--muted: #6b6f66;--line: #e3e0d6;--accent: #4a5c28;--accent-ink: #ffffff;--danger: #b3322b;--ok: #2f7d4f;--warn: #b07a1e;--radius: 14px}*{box-sizing:border-box}body,html,#root{margin:0;height:100%}body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px}.brand{font-weight:800;font-size:20px;letter-spacing:-.5px}.brand span{color:var(--accent);font-weight:700}.muted{color:var(--muted)}.hint{color:var(--muted);font-size:13px}code{background:#eceae2;padding:1px 5px;border-radius:5px;font-size:12px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px}.btn{border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s,opacity .15s}.btn:hover{filter:brightness(.97)}.btn:disabled{opacity:.5;cursor:default}.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.btn.danger{background:#fff;color:var(--danger);border-color:#e6c4c1}.btn.ghost{background:transparent}.login-wrap{min-height:100%;display:grid;place-items:center;padding:24px}.login-card{width:340px;display:flex;flex-direction:column;gap:12px}.login-card input{border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:15px}.login-card .brand{font-size:26px}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:20px;padding:14px 24px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}.tabs{display:flex;gap:6px;margin-left:8px;flex:1}.tab{border:none;background:transparent;color:var(--muted);padding:8px 14px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer}.tab.active{background:#ecefe1;color:var(--accent)}.content{padding:24px;max-width:1100px;width:100%;margin:0 auto}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.spot{display:flex;flex-direction:column;gap:12px}.spot-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.spot-head h3{margin:0;font-size:17px}.chip{background:#ecefe1;color:var(--accent);font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}.desc{margin:0;color:#45463f;font-size:14px;line-height:1.45}.meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin:0}.meta dt{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em}.meta dd{margin:0;font-size:14px}.meta a{color:var(--accent)}.ok{color:var(--ok);font-weight:600}.warn{color:var(--warn);font-weight:600}.actions{display:flex;gap:10px;margin-top:auto}.actions .btn{flex:1}.player{width:100%;margin-top:2px}.uploader{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.uploader input[type=file]{font-size:13px;flex:1;min-width:160px}.state{padding:48px;text-align:center;color:var(--muted)}.state .emoji{font-size:32px;margin-bottom:8px}.alert{background:#fbeceb;color:var(--danger);border:1px solid #e6c4c1;border-radius:10px;padding:10px 12px;font-size:14px}.empty .emoji{opacity:.8}
