:root{--ink: #16181d;--ink-soft: #3b4048;--muted: #6b7280;--paper: #f4f1ea;--paper-2: #ece7dc;--line: #d8d2c4;--accent: #1f3a63;--accent-2: #2f5d62;--danger: #8a2b22;--ok: #2c5d34;--radius: 10px;--shadow: 0 1px 2px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.06)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{margin:0;font-weight:700}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:24px;padding:0 20px;height:56px;background:var(--ink);color:#f4f1ea;position:sticky;top:0;z-index:20}.brand{font-weight:800;letter-spacing:.3px;font-size:17px}.brand-mark{color:#d7c9a0;margin-right:4px}.brand-live{color:#9fb6c7;font-weight:600}.topnav{display:flex;gap:6px;margin-left:8px}.topnav a{color:#c9cdd4;padding:7px 12px;border-radius:8px;font-size:14px}.topnav a:hover{background:#ffffff14;text-decoration:none}.topnav a.active{background:#ffffff29;color:#fff}.topuser{margin-left:auto;display:flex;align-items:center;gap:12px}.topuser-email{color:#aeb4bd;font-size:13px}.content{flex:1;max-width:1080px;width:100%;margin:0 auto;padding:28px 20px 64px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px}.page-title{font-size:26px}.page-subtitle{margin:4px 0 0;color:var(--muted);font-size:14px}.page-actions{display:flex;gap:10px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;border-radius:9px;padding:9px 15px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,opacity .12s;line-height:1.1}.btn:disabled{opacity:.55;cursor:default}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#16305a}.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}.btn-ghost:hover:not(:disabled){background:var(--paper-2)}.btn-danger{background:transparent;border-color:#d9b4ae;color:var(--danger)}.btn-danger:hover:not(:disabled){background:#f6e9e7}.btn-sm{padding:5px 10px;font-size:13px}.topbar .btn-ghost{border-color:#ffffff40;color:#eee}.topbar .btn-ghost:hover:not(:disabled){background:#ffffff1f}.field{display:block;margin-bottom:14px}.field-label{display:block;font-size:13px;color:var(--ink-soft);margin-bottom:6px;font-weight:600}.input,select.input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1f3a631f}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.list{display:flex;flex-direction:column;gap:10px}.row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:9px;background:#fff}.row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.row-title{font-weight:600}.row-sub{font-size:13px;color:var(--muted)}.tag{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;border-radius:999px;background:var(--paper-2);color:var(--ink-soft)}.tag-master{background:#e7eef7;color:var(--accent)}.tag-owner{background:#efe7d8;color:#7a5c1e}.banner{padding:10px 13px;border-radius:9px;font-size:14px;margin-bottom:14px;border:1px solid}.banner-error{background:#f7eae8;border-color:#e2bcb5;color:var(--danger)}.banner-ok{background:#e9f2ea;border-color:#b9d5be;color:var(--ok)}.banner-info{background:#eaf0f6;border-color:#bdd0e3;color:var(--accent)}.spinner{padding:40px;text-align:center;color:var(--muted)}.empty{padding:32px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:var(--radius);background:#fff6}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#fbf8f1,var(--paper))}.auth-card{width:100%;max-width:380px}.auth-brand{text-align:center;margin-bottom:20px}.auth-brand .mark{font-size:30px;color:var(--accent)}.auth-brand h1{font-size:22px;margin-top:6px}.auth-brand p{color:var(--muted);font-size:13px;margin:4px 0 0}.auth-switch{text-align:center;margin-top:14px;font-size:14px;color:var(--muted)}.block{width:100%}.mt{margin-top:14px}.muted{color:var(--muted)}.stack{display:flex;flex-direction:column;gap:16px}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.map-stage{position:relative;width:100%;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}.map-doc svg{display:block;width:100%;height:auto}.map-fog{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;touch-action:none}.play{display:flex;flex-direction:column;gap:14px}.play-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:9px}.play-bar .sep{width:1px;height:22px;background:var(--line)}.seg{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.seg button{border:none;background:#fff;padding:7px 12px;font-size:13px;font-weight:600;cursor:pointer;color:var(--ink-soft)}.seg button.on{background:var(--accent);color:#fff}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);display:inline-block}.live-off{background:var(--muted)}.invite-box{display:flex;gap:8px;align-items:center}.invite-box input{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.swatch{width:24px;height:24px;border-radius:50%;border:1px solid rgba(0,0,0,.2);cursor:pointer;padding:0;outline-offset:2px}@media (max-width: 680px){.topbar{gap:10px;padding:0 12px}.brand{font-size:15px}.topnav{gap:2px;margin-left:2px}.topnav a{padding:7px 9px;font-size:13px}.topuser-email{display:none}.content{padding:18px 14px 56px}.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-actions{flex-wrap:wrap}.page-title{font-size:21px}.grid{grid-template-columns:1fr}.between,.row{flex-wrap:wrap}.auth-wrap{padding:40px 16px 16px;align-items:flex-start}}@media (max-width: 420px){.topnav a{padding:6px 7px;font-size:12px}.play-bar{gap:8px}}
