*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0c0e;--surface: #11151a;--raised: #1a2128;--border: rgba(120,200,180,.1);--border-hi: rgba(120,200,180,.22);--accent: #4ec9b0;--accent-dim: rgba(78,201,176,.14);--accent-hi: rgba(78,201,176,.3);--warn: #ffb454;--error: #ff6b6b;--text-1: #e6ecef;--text-2: #9aaab2;--text-3: #5a6670;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--shadow: 0 4px 24px rgba(0,0,0,.5)}html,body{height:100%;background:var(--bg);color:var(--text-1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior:none}#root{min-height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:4px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{background:var(--accent);color:#0a0c0e;border:none;padding:8px 14px;border-radius:var(--r-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}button:hover{background:#5fdcc1}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:transparent;color:var(--text-2);border:1px solid var(--border-hi)}button.ghost:hover{background:var(--accent-dim);color:var(--text-1)}button.danger{background:transparent;color:var(--error);border:1px solid var(--error)}button.danger:hover{background:#ff6b6b1a}input,textarea,select{background:var(--surface);color:var(--text-1);border:1px solid var(--border-hi);border-radius:var(--r-sm);padding:8px 12px;font-size:14px;font-family:inherit;width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}label{display:block;color:var(--text-2);font-size:13px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;justify-content:space-between}.app-header .brand{font-size:18px;font-weight:700;color:var(--accent)}.app-header .brand small{color:var(--text-3);font-size:12px;font-weight:400;margin-left:8px}.app-header nav{display:flex;gap:16px;align-items:center}.app-header nav a{color:var(--text-2);font-size:14px}.app-header nav a.active,.app-header nav a:hover{color:var(--text-1);text-decoration:none}.app-header .user{color:var(--text-3);font-size:13px}.page{padding:20px;max-width:1200px;margin:0 auto;width:100%;flex:1}.page h1{font-size:24px;margin-bottom:6px;color:var(--text-1)}.page .sub{color:var(--text-2);margin-bottom:24px;font-size:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px}.row{display:flex;gap:12px;align-items:center}.col{display:flex;flex-direction:column;gap:12px}.empty{text-align:center;color:var(--text-3);padding:40px 20px}.empty h2{color:var(--text-2);margin-bottom:8px;font-size:18px}.error{background:#ff6b6b1a;color:var(--error);border:1px solid var(--error);border-radius:var(--r-sm);padding:10px 14px;margin:10px 0;font-size:14px}.warn{background:#ffb4541a;color:var(--warn);border:1px solid var(--warn);border-radius:var(--r-sm);padding:10px 14px;font-size:13px}.chip-editor{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.category{background:var(--raised);border-radius:var(--r-md);padding:12px}.category .cat-label{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-weight:600}.chips{display:flex;flex-wrap:wrap;gap:6px;min-height:28px;margin-bottom:8px}.chip{display:inline-flex;align-items:center;gap:6px;background:var(--accent-dim);color:var(--text-1);padding:4px 8px;border-radius:14px;font-size:13px}.chip button{background:none;color:var(--text-2);padding:0 2px;font-size:16px;line-height:1;cursor:pointer;font-weight:400}.chip button:hover{color:var(--text-1);background:none}.category input{font-size:13px;padding:6px 10px}.sprite-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1100px}.sprite{background:#fff;background-image:linear-gradient(45deg,#c8c8c8 25%,transparent 25%),linear-gradient(-45deg,#c8c8c8 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#c8c8c8 75%),linear-gradient(-45deg,transparent 75%,#c8c8c8 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;border-radius:var(--r-sm);overflow:hidden}.sprite img{width:100%;height:auto;display:block}.sprite .label{background:var(--accent);color:#0a0c0e;padding:4px 10px;font-size:12px;font-weight:600;text-transform:capitalize}.sprite.placeholder{aspect-ratio:832 / 1216;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12px;background:var(--raised)}.progress-bar{height:6px;background:var(--surface);border-radius:3px;overflow:hidden}.progress-bar .fill{height:100%;background:var(--accent);transition:width .3s}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.char-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:border .15s,transform .15s}.char-card:hover{border-color:var(--accent);transform:translateY(-2px)}.char-card .thumb{aspect-ratio:832 / 1216;background:#fff;background-image:linear-gradient(45deg,#c8c8c8 25%,transparent 25%),linear-gradient(-45deg,#c8c8c8 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#c8c8c8 75%),linear-gradient(-45deg,transparent 75%,#c8c8c8 75%);background-size:12px 12px;background-position:0 0,0 6px,6px -6px,-6px 0px;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12px}.char-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.char-card .meta{padding:10px 12px}.char-card .meta .name{font-weight:600;font-size:14px;color:var(--text-1)}.char-card .meta .status{color:var(--text-3);font-size:12px;margin-top:2px}textarea{min-height:80px;resize:vertical}.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.story-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;cursor:pointer;transition:border .15s,transform .15s}.story-card:hover{border-color:var(--accent);transform:translateY(-2px)}.story-card .name{font-weight:600;font-size:15px;color:var(--text-1)}.story-card .premise{color:var(--text-2);font-size:13px;margin:6px 0 10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.story-card .counts{color:var(--text-3);font-size:12px}.vis{font-size:11px;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.vis-private{background:var(--raised);color:var(--text-3)}.vis-public{background:var(--accent-dim);color:var(--accent)}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}.picker-grid.loc{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.picker-card .meta{font-size:12px;padding:4px 6px}.picker-card{background:var(--raised);border:2px solid transparent;border-radius:var(--r-sm);overflow:hidden;cursor:pointer;transition:border .15s}.picker-card:hover{border-color:var(--border-hi)}.picker-card.on{border-color:var(--accent)}.picker-card .thumb{aspect-ratio:832 / 1216;background:#1a1f24;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:11px}.picker-card .thumb.loc{aspect-ratio:1216 / 832}.picker-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.picker-card .meta{padding:6px 8px;font-size:13px;color:var(--text-1);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-stage{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;overflow:hidden;display:flex;flex-direction:column;-webkit-user-select:none;user-select:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.play-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;background-color:var(--raised)}.play-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0000 50%,#00000080)}.play-sprite{position:absolute;bottom:0;left:50%;transform:translate(-50%);height:88vh;max-width:95vw;object-fit:contain;object-position:bottom;filter:drop-shadow(0 6px 20px rgba(0,0,0,.6));animation:spriteIn .18s ease-out}@keyframes spriteIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.play-cg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;animation:cgIn .35s ease-out}@keyframes cgIn{0%{opacity:0}to{opacity:1}}.play-cg-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0000008c;color:var(--accent);padding:8px 16px;border-radius:var(--r-md);font-size:13px;letter-spacing:.06em;z-index:2}.play-hud{position:absolute;top:12px;left:12px;right:12px;display:flex;justify-content:space-between;align-items:center;pointer-events:none;z-index:5;font-size:12px;color:var(--text-2);text-shadow:0 1px 3px rgba(0,0,0,.8)}.play-hud a{pointer-events:auto;background:#00000073;padding:4px 10px;border-radius:12px;color:var(--text-1)}.play-hud-meta{background:#00000073;padding:4px 10px;border-radius:12px;font-family:monospace}.play-dialogue{position:absolute;bottom:0;left:0;right:0;background:#080a0ceb;border-top:1px solid var(--border-hi);padding:16px 20px 24px;min-height:24vh;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.play-speaker{color:var(--accent);font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}.play-text{color:var(--text-1);font-size:17px;line-height:1.5;min-height:60px}.play-tap{position:absolute;bottom:6px;right:16px;font-size:11px;color:var(--text-3);opacity:.6;animation:tapPulse 1.6s infinite}@keyframes tapPulse{0%,to{opacity:.3}50%{opacity:.8}}.play-choices{position:absolute;bottom:0;left:0;right:0;background:#080a0ceb;border-top:1px solid var(--border-hi);padding:16px 20px 24px;display:flex;flex-direction:column;gap:10px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.play-choice{background:var(--surface);color:var(--text-1);border:1px solid var(--border-hi);padding:14px 16px;font-size:15px;font-weight:500;text-align:left;border-radius:var(--r-sm);cursor:pointer;transition:border .15s,background .15s}.play-choice:hover{border-color:var(--accent);background:var(--raised)}.play-choice.custom{font-style:italic;color:var(--text-2);border-style:dashed}.play-status,.play-status-inline{color:var(--text-2);text-align:center;padding:20px}.play-status{margin:auto}.play-custom-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:20px;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.play-custom-box{background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--r-md);padding:20px;width:100%;max-width:400px}@media (min-aspect-ratio: 3/4){.play-stage{max-width:min(420px,56vh);margin:0 auto;box-shadow:0 0 0 100vmax #000c}}.loc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.loc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.loc-card .thumb{aspect-ratio:1216 / 832;background:var(--raised);display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12px}.loc-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.loc-card .meta{padding:10px 12px}.loc-card .meta .name{font-weight:600;font-size:14px;color:var(--text-1)}.loc-card .meta .desc{color:var(--text-3);font-size:12px;margin-top:2px}
