:root{--bg:#140f12;--bg-mid:#1c1519;--bg-dark:#0e0b0d;--bg-card:#21171c;--bg-sidebar:#191417;--accent:#b84c6a;--accent-hover:#d45f7e;--gold:#d4b06a;--text:#f1e7eb;--text-muted:#b69aa5;--text-faint:#7a5f6a;--border:#f1e7eb14;--radius:12px;--font-serif:"Playfair Display", Georgia, serif;--font-sans:"Inter", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);min-height:100vh;font-size:15px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.btn{border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-size:.9rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{border:1.5px solid var(--border);color:var(--text-muted);background:0 0}.btn-ghost:hover{border-color:var(--text-muted);color:var(--text)}.input{background:var(--bg-dark);border:1.5px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:.7rem 1rem;font-size:.95rem;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-faint)}.error-msg{color:var(--accent);margin-top:.4rem;font-size:.85rem}.auth-wrap{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-nav{padding:.75rem 1.5rem;position:fixed;top:0;left:0;right:0}.auth-nav-back{color:var(--text-muted);font-size:.875rem;text-decoration:none}.auth-nav-back:hover{color:var(--accent)}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;padding:2.5rem 2rem}.auth-logo{border:2px solid var(--gold);width:48px;height:48px;font-family:var(--font-serif);color:var(--gold);border-radius:50%;justify-content:center;align-items:center;margin-bottom:1.5rem;font-size:1.4rem;display:flex}.auth-title{font-family:var(--font-serif);margin-bottom:.25rem;font-size:1.6rem}.auth-sub{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.auth-form{flex-direction:column;gap:1rem;margin-top:1.5rem;display:flex}.auth-label{color:var(--text-muted);flex-direction:column;gap:.35rem;font-size:.85rem;display:flex}.auth-hint{color:var(--text-muted);font-size:.85rem}.auth-link{color:var(--accent)}.auth-link:hover{text-decoration:underline}.auth-error{color:var(--accent);font-size:.85rem}.ob-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.ob-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:560px;padding:2.5rem 2rem;position:relative;overflow:hidden}.ob-progress{background:var(--border);height:3px;position:absolute;top:0;left:0;right:0}.ob-progress-bar{background:var(--accent);height:100%;transition:width .4s}.ob-step{color:var(--text-faint);margin-top:.5rem;margin-bottom:.75rem;font-size:.8rem}.ob-question{font-family:var(--font-serif);margin-bottom:.4rem;font-size:1.6rem}.ob-sub{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.ob-options{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.ob-option{background:var(--bg-dark);border:1.5px solid var(--border);text-align:left;color:var(--text);border-radius:10px;flex-direction:column;gap:.2rem;padding:1rem 1.2rem;transition:all .15s;display:flex}.ob-option:hover{border-color:var(--text-faint)}.ob-option.selected{border-color:var(--accent);background:#b84c6a14}.ob-option-label{font-weight:500}.ob-option-desc{color:var(--text-muted);font-size:.82rem}.ob-option-sm{flex-direction:row;align-items:center;padding:.75rem 1rem}.ob-consent{color:var(--text-muted);cursor:pointer;align-items:flex-start;gap:.75rem;font-size:.88rem;line-height:1.5;display:flex}.ob-consent input{accent-color:var(--accent);flex-shrink:0;width:16px;height:16px;margin-top:3px}.ob-required{color:var(--accent)}.ob-next{width:100%}.home{max-width:860px;margin:0 auto;padding:2.5rem 2rem}.home-header{margin-bottom:2rem}.home-title{font-family:var(--font-serif);font-size:1.8rem}.home-sub{color:var(--text-muted);margin-top:.25rem}.home-rooms{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:2.5rem;display:grid}.room-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:flex-start;gap:1rem;padding:1.5rem;transition:all .15s;display:flex;position:relative}.room-card:hover:not(.room-soon){border-color:var(--accent);transform:translateY(-2px)}.room-soon{opacity:.55;cursor:default}.room-icon{flex-shrink:0;font-size:1.8rem}.room-title{margin-bottom:.25rem;font-weight:600}.room-desc{color:var(--text-muted);font-size:.85rem;line-height:1.5}.room-badge{color:var(--text-faint);background:#ffffff0f;border-radius:4px;padding:.15rem .5rem;font-size:.7rem;position:absolute;top:.75rem;right:.75rem}.home-feed-placeholder{border:1.5px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--text-faint);padding:3rem 2rem}.feed-icon{margin-bottom:.75rem;font-size:2rem}.feed-text{font-size:.95rem;line-height:1.7}.feed-text span{color:var(--text-muted)}.admin{max-width:1000px;margin:0 auto;padding:2rem}.admin-loading{text-align:center;color:var(--text-muted);padding:3rem}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.admin-header-right{align-items:center;gap:.75rem;display:flex}.admin-dev-link{font-size:.82rem;padding:.35rem .9rem!important}.admin-title{font-family:var(--font-serif);font-size:1.6rem}.admin-msg{color:var(--gold);background:#d4b06a1a;border-radius:6px;padding:.3rem .75rem;font-size:.85rem}.admin-tabs{border-bottom:1px solid var(--border);gap:.5rem;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.admin-tab{color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:.4rem .75rem;font-size:.9rem}.admin-tab:hover{color:var(--text);background:#ffffff0a}.admin-tab.active{color:var(--text);background:#b84c6a1f}.admin-section{overflow-x:auto}.admin-new-invite{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.admin-new-invite .input{max-width:360px}.admin-table{border-collapse:collapse;width:100%;font-size:.88rem}.admin-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.6rem .75rem;font-weight:500}.admin-table td{vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:.75rem}.admin-table tr:hover td{background:#ffffff05}.admin-select{background:var(--bg-dark);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:.25rem .5rem;font-size:.85rem}.admin-copy{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:6px;padding:.25rem .6rem;font-size:.82rem}.admin-copy:hover{color:var(--text);border-color:var(--text-faint)}.admin-del{color:var(--text-faint);background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:.9rem}.admin-del:hover{color:var(--accent);background:#b84c6a1a}.studio-list{max-width:900px;margin:0 auto;padding:2rem}.studio-loading{text-align:center;color:var(--text-muted);padding:3rem}.studio-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.studio-title{font-family:var(--font-serif);font-size:1.8rem}.studio-sub{color:var(--text-muted);margin-top:.2rem;font-size:.9rem}.studio-new{background:var(--bg-card);border:1.5px solid var(--accent);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem;display:flex}.studio-new .input{max-width:360px}.studio-empty{text-align:center;color:var(--text-muted);border:1.5px dashed var(--border);border-radius:var(--radius);padding:4rem 2rem}.studio-empty-icon{margin-bottom:1rem;font-size:2.5rem}.studio-empty p:last-child{margin-top:.25rem}.studio-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.studio-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:1rem;padding:1.25rem;transition:all .15s;display:flex;position:relative}.studio-card:hover{border-color:var(--accent);transform:translateY(-2px)}.studio-card-icon{flex-shrink:0;font-size:1.8rem}.studio-card-info{flex:1;min-width:0}.studio-card-name{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.studio-card-date{color:var(--text-faint);margin-top:.2rem;font-size:.78rem}.studio-card-del{color:var(--text-faint);opacity:0;background:0 0;border:none;border-radius:4px;padding:.3rem;transition:opacity .15s}.studio-card:hover .studio-card-del{opacity:1}.studio-card-del:hover{color:var(--accent);background:#b84c6a1a}.outline{max-width:780px}.outline-empty{text-align:center;color:var(--text-muted);border:1.5px dashed var(--border);border-radius:var(--radius);margin-bottom:1.5rem;padding:4rem 2rem}.outline-part{border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden}.outline-part-header{background:var(--bg-card);border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:.9rem 1.1rem;display:flex}.outline-part-num{color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;font-size:.75rem}.outline-part-title{font-family:var(--font-serif);flex:1;font-size:1.05rem;font-weight:600}.outline-chapters{flex-direction:column;gap:.5rem;padding:.75rem 1rem 1rem;display:flex}.outline-chapter{border:1px solid var(--border);border-radius:8px;overflow:hidden}.outline-chapter-header{background:var(--bg-mid);align-items:center;gap:.6rem;padding:.6rem .9rem;display:flex}.outline-chapter-num{color:var(--accent);min-width:1.8rem;font-size:.7rem;font-weight:600}.outline-chapter-title{flex:1;font-size:.95rem;font-weight:500}.outline-scenes{flex-direction:column;gap:.35rem;padding:.5rem .75rem .75rem 2.5rem;display:flex}.outline-scene{border:1px solid #0000;border-radius:6px;transition:border-color .15s}.outline-scene.expanded{border-color:var(--border)}.outline-scene-row{align-items:center;gap:.5rem;padding:.4rem .6rem;display:flex}.outline-scene-num{color:var(--text-faint);min-width:1.6rem;font-size:.68rem}.outline-scene-title{color:var(--text-muted);flex:1;font-size:.88rem}.outline-scene-title.inline-edit:hover{color:var(--text)}.outline-scene-expand{color:var(--text-faint);background:0 0;border:none;padding:.2rem .4rem;font-size:.75rem}.outline-scene-expand:hover{color:var(--text-muted)}.outline-scene-detail{flex-direction:column;gap:.4rem;padding:.5rem .6rem .75rem;display:flex}.outline-toggle{color:var(--text-faint);background:0 0;border:none;border-radius:4px;padding:.15rem .3rem;font-size:.75rem}.outline-toggle:hover{color:var(--text-muted)}.outline-del{color:var(--text-faint);opacity:0;background:0 0;border:none;border-radius:4px;padding:.2rem .35rem;font-size:.8rem;transition:opacity .15s}.outline-part-header:hover .outline-del,.outline-chapter-header:hover .outline-del,.outline-scene-row:hover .outline-del{opacity:1}.outline-del:hover{color:var(--accent);background:#b84c6a1a}.outline-add-part{border-radius:var(--radius);border:1.5px dashed var(--border);width:100%;color:var(--text-muted);background:0 0;margin-top:.5rem;padding:.7rem;font-size:.88rem;transition:all .15s;display:block}.outline-add-part:hover{border-color:var(--accent);color:var(--accent)}.outline-add-chapter,.outline-add-scene{color:var(--text-faint);background:0 0;border:none;border-radius:5px;margin-top:.15rem;padding:.3rem .5rem;font-size:.8rem}.outline-add-chapter:hover,.outline-add-scene:hover{color:var(--accent);background:#b84c6a14}.outline-label{color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem;font-size:.75rem}.outline-pov{margin-bottom:.25rem}.outline-summary{resize:vertical}.inline-edit{cursor:text;border-radius:4px;margin:-.1rem -.3rem;padding:.1rem .3rem;transition:background .15s}.inline-edit:hover{background:#f1e7eb0f}@media (width<=768px){.outline{max-width:100%}.outline-scenes{padding-left:1.25rem}.outline-part-header,.outline-chapter-header{padding:.6rem .75rem}}.inline-edit-input{background:var(--bg-dark);border:1.5px solid var(--accent);color:var(--text);border-radius:6px;outline:none;padding:.15rem .5rem;font-family:inherit}.chars{gap:0;height:100%;margin:-2rem;display:flex}.chars-list{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:.4rem;width:260px;padding:1.25rem 1rem;display:flex;overflow-y:auto}.chars-list-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.chars-heading{font-family:var(--font-serif);font-size:1rem}.chars-add{padding:.4rem .9rem!important;font-size:.8rem!important}.chars-empty{color:var(--text-faint);padding:.5rem 0;font-size:.85rem}.chars-item{cursor:pointer;border-radius:8px;align-items:center;gap:.75rem;padding:.6rem .75rem;transition:background .15s;display:flex}.chars-item:hover{background:var(--bg-mid)}.chars-item.active{background:var(--bg-card);border:1px solid var(--border)}.chars-item-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.chars-item-name{font-size:.9rem;font-weight:500}.chars-item-role{color:var(--text-faint);margin-top:.1rem;font-size:.75rem}.chars-panel{flex:1;padding:2rem;overflow-y:auto}.chars-panel-empty{height:100%;color:var(--text-faint);justify-content:center;align-items:center;font-size:.9rem;display:flex}.char-form{flex-direction:column;gap:.75rem;max-width:560px;display:flex}.char-form-header{align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.char-form-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.2rem;font-weight:700;display:flex}.char-name-input{flex:1;font-size:1.1rem;font-weight:600}.char-del{opacity:1!important}.char-summary{resize:vertical}@media (width<=768px){.chars{flex-direction:column;margin:-1rem}.chars-list{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:220px;padding:.75rem}.chars-panel{padding:1rem}.chars-panel-empty{min-height:80px}}.notes{flex-direction:column;gap:1rem;display:flex}.notes-header{justify-content:space-between;align-items:center;display:flex}.notes-heading{font-family:var(--font-serif);font-size:1.4rem}.notes-add{background:var(--accent);color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.4rem;line-height:1;transition:background .15s;display:flex}.notes-add:hover{background:var(--accent-hover)}.notes-tags-filter{flex-wrap:wrap;gap:.4rem;display:flex}.notes-tag{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:20px;padding:.2rem .6rem;font-size:.75rem;transition:all .15s}.notes-tag:hover{border-color:var(--accent);color:var(--accent)}.notes-tag.active{background:var(--accent);border-color:var(--accent);color:#fff}.notes-empty{text-align:center;color:var(--text-faint);border:1.5px dashed var(--border);border-radius:var(--radius);padding:3rem;font-size:.9rem}.notes-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));align-items:start;gap:1rem;display:grid}.note-card{border:1.5px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.6rem;padding:.9rem;transition:border-color .15s;display:flex}.note-card:hover{border-color:#f1e7eb33}.note-card-header{justify-content:space-between;align-items:center;display:flex}.note-colors{gap:.3rem;display:flex}.note-color-dot{border:1.5px solid #0000;border-radius:50%;width:14px;height:14px;padding:0;transition:transform .15s}.note-color-dot:hover{transform:scale(1.2)}.note-color-dot.active{border-color:var(--text-muted)}.note-del{color:var(--text-faint);opacity:0;background:0 0;border:none;border-radius:4px;padding:.2rem .35rem;font-size:.8rem;transition:opacity .15s}.note-card:hover .note-del{opacity:1}.note-del:hover{color:var(--accent)}.note-text{width:100%;min-height:80px;color:var(--text);font-family:var(--font-sans);resize:vertical;background:0 0;border:none;outline:none;font-size:.9rem;line-height:1.6}.note-text::placeholder{color:var(--text-faint)}.note-tags-input{border:none;border-top:1px solid var(--border);width:100%;color:var(--text-faint);background:0 0;outline:none;padding:.4rem 0 0;font-size:.75rem}.note-tags-input::placeholder{color:var(--text-faint)}.note-tags{flex-wrap:wrap;gap:.3rem;display:flex}.note-tag-chip{color:var(--accent);background:#b84c6a1a;border-radius:20px;padding:.1rem .45rem;font-size:.7rem}@media (width<=768px){.notes-grid{grid-template-columns:1fr 1fr}}.se{background:var(--bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.se-loading{height:100vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.se-header{background:var(--bg-sidebar);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex}.se-back{color:var(--text-muted);white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:.35rem .75rem;font-size:.85rem}.se-back:hover{background:var(--bg-mid);color:var(--text)}.se-title{font-family:var(--font-serif);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1.1rem;overflow:hidden}.se-save-status{color:var(--text-faint);white-space:nowrap;font-size:.75rem}.se-body{flex:1;display:flex;overflow:hidden}.se-nav{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:.25rem;width:140px;padding:1rem .75rem;display:flex}.se-nav-btn{color:var(--text-muted);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.6rem;padding:.6rem .75rem;font-size:.85rem;transition:all .15s;display:flex}.se-nav-btn:hover{background:var(--bg-mid);color:var(--text)}.se-nav-btn.active{background:var(--bg-card);color:var(--text);font-weight:500}.se-content{flex:1;padding:2rem;overflow-y:auto}@media (width<=768px){.se-header{gap:.5rem;padding:.6rem 1rem}.se-title{font-size:.95rem}.se-save-status{display:none}.se-body{flex-direction:column-reverse}.se-nav{border-right:none;border-top:1px solid var(--border);flex-direction:row;flex-shrink:0;gap:0;width:100%;padding:0}.se-nav-btn{white-space:nowrap;border-radius:0;flex-direction:column;flex:1;justify-content:center;gap:.2rem;padding:.5rem .25rem .6rem;font-size:.68rem}.se-nav-btn span:first-child{font-size:1.2rem}.se-nav-btn.active{color:var(--accent);border-top:2px solid var(--accent);background:0 0}.se-content{padding:1rem}}.shell{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.shell-sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;height:100vh;padding:1.5rem 1rem;display:flex;position:sticky;top:0;overflow-y:auto}.shell-logo{align-items:center;gap:.6rem;margin-bottom:1.5rem;padding:.25rem .5rem;display:flex}.shell-logo-mark{border:1.5px solid var(--gold);width:36px;height:36px;font-family:var(--font-serif);color:var(--gold);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.shell-logo-name{font-family:var(--font-serif);color:var(--text);font-size:1.1rem}.shell-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.shell-nav-item{color:var(--text-muted);border-radius:10px;align-items:center;gap:.75rem;padding:.65rem .75rem;font-size:.9rem;transition:all .15s;display:flex;position:relative}.shell-nav-item:hover{color:var(--text);background:#ffffff0a}.shell-nav-item.active{color:var(--text);background:#b84c6a1f}.shell-nav-item.active .shell-nav-icon{filter:none}.shell-nav-item.soon{opacity:.5;cursor:default}.shell-nav-icon{text-align:center;width:22px;font-size:1.1rem}.shell-nav-label{flex:1}.shell-soon{color:var(--text-faint);background:#ffffff0f;border-radius:4px;padding:.1rem .4rem;font-size:.7rem}.shell-divider{background:var(--border);height:1px;margin:.75rem .5rem}.shell-user{border-top:1px solid var(--border);align-items:center;gap:.6rem;margin-top:auto;padding:.75rem .5rem;display:flex}.shell-avatar{border:1.5px solid var(--accent);width:34px;height:34px;color:var(--accent);background:#b84c6a33;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.shell-user-info{flex:1;min-width:0}.shell-user-email{color:var(--text-muted);truncate:ellipsis;white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;display:block;overflow:hidden}.shell-badge{color:var(--gold);background:#d4b06a1f;border-radius:4px;padding:.1rem .4rem;font-size:.68rem}.shell-logout{color:var(--text-faint);background:0 0;border:none;border-radius:6px;padding:.25rem;font-size:1rem}.shell-logout:hover{color:var(--text);background:#ffffff0d}.shell-main{min-height:100vh;overflow-y:auto}@media (width<=768px){.shell{grid-template-rows:1fr auto;grid-template-columns:1fr}.shell-sidebar{border-right:none;border-top:1px solid var(--border);z-index:100;flex-direction:row;height:auto;padding:.5rem 1rem;position:fixed;inset:auto 0 0}.shell-logo,.shell-user,.shell-divider,.shell-soon{display:none}.shell-nav{flex-direction:row;justify-content:space-around;gap:0}.shell-nav-item{flex-direction:column;gap:.2rem;padding:.4rem .6rem;font-size:.7rem}.shell-nav-item.soon{display:none}.shell-main{padding-bottom:5rem}}
