:root{--bg: #0f172a;--surface: #1e293b;--surface2: #273549;--border: #334155;--accent: #6366f1;--accent-hover: #4f46e5;--accent-dim: rgba(99, 102, 241, .15);--text: #f1f5f9;--text-muted: #94a3b8;--success: #22c55e;--error: #f87171;--card-shadow: 0 4px 16px rgba(0, 0, 0, .4);--radius: 10px;--radius-sm: 6px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}.error-msg{color:var(--error);font-size:.875rem;margin-top:.25rem}.back-link{color:var(--text-muted);text-decoration:none;margin-top:1rem;display:block}.back-link:hover{color:var(--text)}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:.6rem 1.25rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:background .15s}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;color:var(--text-muted)}input[type=text],input[type=password]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;padding:.55rem .75rem;outline:none;transition:border-color .15s;width:100%}input:focus{border-color:var(--accent)}.status-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:100vh}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.home-page{min-height:100vh;display:flex;flex-direction:column}.home-header{text-align:center;padding:4rem 1rem 2rem}.home-header .logo{font-size:3rem;display:block;margin-bottom:.5rem}.home-header h1{font-size:2rem;font-weight:700}.home-header p{color:var(--text-muted);margin-top:.4rem}.home-main{display:flex;justify-content:center;padding:1rem 1rem 4rem}.create-room-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:480px;display:flex;flex-direction:column;gap:1.25rem}.create-room-form h2{font-size:1.2rem}.deck-type-fieldset{border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem}.deck-type-fieldset legend{font-size:.875rem;color:var(--text-muted);padding:0 .25rem}.radio-label{flex-direction:row;align-items:flex-start;gap:.6rem;cursor:pointer;color:var(--text);font-size:.95rem}.radio-label input{margin-top:.2rem;accent-color:var(--accent);flex-shrink:0}.radio-label span{display:flex;flex-direction:column}.radio-label small{color:var(--text-muted);font-size:.8rem}.password-section{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{flex-direction:row;align-items:center;gap:.5rem;color:var(--text);font-size:.9rem;cursor:pointer}.checkbox-label input{accent-color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:400px}.modal h2{margin-bottom:.25rem}.room-name-label{color:var(--text-muted);font-size:.9rem;margin-bottom:1.25rem}.join-form{display:flex;flex-direction:column;gap:1rem}.room-page{display:flex;flex-direction:column;min-height:100vh}.room-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.logo-link{text-decoration:none;font-size:1.5rem}.room-title{flex:1;min-width:0}.room-title h1{font-size:1.1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-badge{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.copy-btn{white-space:nowrap;flex-shrink:0}.room-layout{display:flex;flex:1;overflow:hidden}.room-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;padding:1.25rem 1rem}.room-main{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.story-area{display:flex;flex-direction:column;gap:.6rem}.story-form{display:flex;gap:.5rem}.story-form input{flex:1}.lock-notice{font-size:.82rem;color:#f59e0b;padding:.4rem .6rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-sm)}.image-hint{font-size:.78rem;color:var(--text-muted);padding-left:.25rem}.story-image-wrap{position:relative;align-self:flex-start;max-width:100%}.story-image{display:block;max-width:100%;max-height:420px;border-radius:var(--radius-sm);border:1px solid var(--border);object-fit:contain}.clear-image-btn{position:absolute;top:.4rem;right:.4rem;background:#000000a6;color:#fff;border:none;border-radius:50%;width:1.5rem;height:1.5rem;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.clear-image-btn:hover{background:#000000d9}.participant-list-section h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.75rem}.participant-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.participant{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem .6rem;border-radius:var(--radius-sm);font-size:.875rem}.participant.me{background:var(--accent-dim)}.participant-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.you-tag{color:var(--text-muted);font-size:.8rem}.mod-tag{color:#fbbf24;margin-left:.25rem}.participant-actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.make-host-btn{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:.1rem .25rem;border-radius:3px;opacity:0;transition:opacity .15s,color .15s}.participant:hover .make-host-btn{opacity:1}.make-host-btn:hover{color:#fbbf24}.vote-status{font-size:.875rem;font-weight:600;min-width:2rem;text-align:right}.vote-status.voted{color:var(--success)}.vote-status.waiting{color:var(--text-muted)}.card-deck-section h3{font-size:.9rem;font-weight:600;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.voted-badge{color:var(--success);font-size:.85rem}.card-deck{display:flex;flex-wrap:wrap;gap:.6rem}.card{width:64px;height:88px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1.3rem;font-weight:700;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s,transform .1s;box-shadow:var(--card-shadow)}.card:hover:not(.disabled){border-color:var(--accent);background:var(--accent-dim);transform:translateY(-3px)}.card.selected{border-color:var(--accent);background:var(--accent-dim);color:#a5b4fc;transform:translateY(-5px)}.card.disabled{cursor:default}.vote-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.vote-results h3{font-size:.9rem;font-weight:600;margin-bottom:1rem}.results-tally{display:flex;flex-direction:column;gap:.6rem}.tally-row{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.tally-card{width:2.5rem;text-align:center;font-weight:700;font-size:1rem}.tally-bar-wrap{flex:1;background:var(--surface2);border-radius:99px;height:10px;overflow:hidden}.tally-bar{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease}.tally-count{width:6rem;text-align:right;color:var(--text-muted)}.average{margin-top:1rem;font-size:.9rem;color:var(--text-muted)}.average strong{color:var(--text)}.room-controls{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.btn-lock{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-lock:hover{background:var(--border);color:var(--text)}.btn-lock--locked{color:#f59e0b;border-color:#f59e0b;background:#f59e0b1a}.btn-lock--locked:hover{background:#f59e0b33}.room-controls .btn-primary{min-width:160px}@media (max-width: 600px){.room-layout{flex-direction:column}.room-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border)}.card{width:52px;height:72px;font-size:1.1rem}}
