*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafaf8;--surface:#fff;--surface-2:#f7f6f1;--text:#1a1917;--text-muted:#6b6960;--text-hint:#a8a49c;--border:#0000001a;--border-subtle:#0000000f;--danger:#dc2626;--radius:10px;--radius-sm:6px;--radius-lg:16px;--genre-accent:#6b7280;--genre-bg:#f3f4f6}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,sans-serif;line-height:1.5}.app{max-width:880px;margin:0 auto;padding:24px 20px 64px}.loading{height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.app-header{text-align:center;margin-bottom:32px}.app-header h1{letter-spacing:-.01em;color:var(--text);font-family:Georgia,Times New Roman,serif;font-size:1.5rem;font-weight:500}.subtitle-row{justify-content:center;align-items:center;gap:10px;margin-top:4px;display:flex}.subtitle{color:var(--text-hint);font-size:.85rem}.install-btn{color:var(--text);cursor:pointer;background:0 0;border:.5px solid #00000026;border-radius:12px;padding:3px 10px;font-size:12px;transition:background .15s}.install-btn:hover{background:var(--surface-2)}.save-status{height:1.2em;margin-top:8px;font-size:.8rem}.status-offline{color:#92400e}.status-saving{color:var(--text-muted)}.status-saved{color:var(--text-hint)}.profile-summary{color:var(--text-muted);justify-content:center;gap:16px;margin-bottom:32px;font-size:.85rem;display:flex}.editor-section{margin-bottom:36px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-header h2{font-size:1.1rem;font-weight:600}.empty-hint{color:var(--text-hint);padding:16px 0;font-size:.9rem}.card-list{flex-direction:column;gap:12px;display:flex}.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:16px}.card-editing{border:1.5px solid var(--text)}.card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.card-desc{color:var(--text-muted);margin-bottom:8px;font-size:.9rem}.card-actions{gap:8px;margin-top:10px;display:flex}.tag-row{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.tag{background:var(--surface-2);color:var(--text-muted);border-radius:var(--radius-sm);border:.5px solid var(--border-subtle);padding:4px 10px;font-size:11px}.tag-context{color:#3d6b50;background:#f0f7f4}.badge{background:var(--surface-2);color:var(--text-muted);border-radius:var(--radius-sm);padding:2px 8px;font-size:11px}.philosophy-list{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.philosophy-item{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;display:flex}.philosophy-text{flex:1;font-size:.9rem}.philosophy-actions{flex-shrink:0;gap:6px;display:flex}.philosophy-edit{flex:1;align-items:center;gap:6px;display:flex}.philosophy-edit input{flex:1}.add-row{gap:8px;display:flex}.add-row input{flex:1}.form{flex-direction:column;gap:12px;display:flex}.form label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:.85rem;font-weight:500;display:flex}.hint{color:var(--text-hint);font-size:.8rem;font-weight:400}.form-actions{gap:8px;margin-top:4px;display:flex}input,textarea{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:8px 10px;font-family:inherit;font-size:.9rem;transition:border-color .15s}input:focus,textarea:focus{border-color:var(--text)}textarea{resize:vertical}.btn{background:var(--genre-accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 16px;font-size:.85rem;font-weight:500;transition:opacity .15s}.btn:hover{opacity:.85}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-sm{padding:4px 10px;font-size:12px}.btn-ghost{color:var(--text);background:0 0;border:.5px solid #00000026}.btn-ghost:hover{background:var(--surface-2);opacity:1}.btn-danger{color:var(--danger);background:0 0;border:.5px solid #00000026}.btn-danger:hover{opacity:1;background:#fee2e2}.api-key-status{align-items:center;gap:8px;display:flex}.api-key-set{color:#059669;font-size:.85rem}.api-key-form{gap:8px;display:flex}.api-key-form input{flex:1}.dna-section{border-top:.5px solid var(--border);margin-top:36px;padding-top:24px}.dna-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.btn-generate{background:var(--text);padding:12px 24px;font-size:.95rem}.btn-generate:hover{opacity:.85}.dna-loading{color:var(--text-muted);align-items:center;gap:12px;margin-top:20px;font-size:.9rem;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--text);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dna-error{border-radius:var(--radius);color:#991b1b;background:#fef2f2;border:.5px solid #fecaca;margin-top:16px;padding:12px;font-size:.9rem}.signature-theme{color:var(--text-muted);margin-bottom:22px;font-family:Georgia,Times New Roman,serif;font-size:1rem;font-style:italic;line-height:1.7}.tab-nav{border-bottom:.5px solid var(--border);-webkit-overflow-scrolling:touch;gap:2px;margin-bottom:24px;display:flex;overflow-x:auto}.tab-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-size:.85rem;font-weight:500;transition:color .15s,border-color .15s}.tab-btn:hover:not(:disabled){color:var(--text)}.tab-active{color:var(--text);border-bottom-color:var(--text)}.tab-disabled{opacity:.35;cursor:not-allowed}.stale-banner{border-radius:var(--radius);color:#92400e;background:#fffbeb;border:.5px solid #f59e0b;flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:16px;padding:10px 16px;font-size:.85rem;display:flex}.dna-success{border-radius:var(--radius);color:#166534;background:#f0fdf4;border:.5px solid #86efac;flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px;padding:12px;font-size:.9rem;display:flex}.link-btn{color:var(--text);font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.genre-grid-compact{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}.genre-tile{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;color:var(--text);padding:12px;font-family:inherit;transition:border-color .15s}.genre-tile:hover{border-color:#00000040}.genre-tile-active{border:1.5px solid var(--text)}.tile-top{justify-content:space-between;align-items:baseline;margin-bottom:2px;display:flex}.tile-name{font-size:.85rem;font-weight:600}.tile-pct{font-size:.9rem;font-weight:700}.tile-sub{color:var(--text-hint);margin-bottom:6px;font-size:11px;display:block}.tile-bar{background:var(--surface-2);border-radius:2px;height:4px;overflow:hidden}.tile-bar-fill{background:var(--text-hint);border-radius:2px;height:100%;transition:width .3s}.overview-layout{grid-template-columns:1fr 1fr;align-items:flex-start;gap:20px;display:grid}@media (width<=640px){.overview-layout{grid-template-columns:1fr}}.radar-container{justify-content:center;display:flex}.radar-svg{width:260px;height:260px}.radar-label{fill:var(--text-hint);font-size:10px}.genre-detail{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);margin-top:22px;padding:28px 32px}.detail-header{flex-wrap:wrap;align-items:baseline;gap:10px;margin-bottom:12px;display:flex}.detail-header h3{font-family:Georgia,Times New Roman,serif;font-size:1.15rem;font-weight:500}.detail-sub{color:var(--text-hint);font-size:.8rem}.detail-match{color:var(--genre-accent);margin-left:auto;font-size:.9rem;font-weight:700}.detail-why{color:var(--text-muted);margin-bottom:14px;font-size:.9rem;line-height:1.6}.detail-themes{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.pill{background:var(--genre-bg);color:var(--genre-accent);border-radius:var(--radius-sm);padding:4px 10px;font-size:11px}.detail-prompt{border-left:2px solid var(--border);background:var(--surface-2);color:var(--text-muted);border-radius:0 9px 9px 0;margin:0 0 14px;padding:14px 20px;font-family:Georgia,Times New Roman,serif;font-size:14px;font-style:italic;line-height:1.9}.detail-comps{flex-wrap:wrap;gap:6px;margin-top:14px;display:flex}.comp-tag{color:var(--text-muted);border-radius:var(--radius-sm);border:.5px solid var(--border-subtle);background:#f4f2ec;padding:4px 10px;font-size:11px}.blend-tab h2{margin-bottom:8px;font-family:Georgia,Times New Roman,serif;font-weight:500}.blend-intro{color:var(--text-muted);margin-bottom:20px;font-size:.9rem}.blend-hint{color:var(--text-hint);text-align:center;padding:20px 0;font-size:.85rem}.blend-result{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);margin-top:4px;padding:28px 32px}.blend-result-header{margin-bottom:8px}.blend-pair{color:var(--text-hint);text-transform:uppercase;letter-spacing:.08em;font-size:10px}.blend-result-title{margin-bottom:4px;font-family:Georgia,Times New Roman,serif;font-size:1.1rem;font-weight:500}.blend-result-tag{color:var(--text-muted);margin-bottom:14px;font-size:.9rem}.blend-seed-block{background:var(--surface-2);border-radius:9px;margin-bottom:14px;padding:16px 18px;font-size:.85rem;line-height:1.5}.blend-seed-block strong{letter-spacing:.08em;color:var(--text-hint);text-transform:uppercase;margin-bottom:6px;font-size:10px;display:block}.plot-tab h2{margin-bottom:12px;font-family:Georgia,Times New Roman,serif;font-weight:500}.plot-controls{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.plot-controls label{letter-spacing:.08em;color:var(--text-hint);text-transform:uppercase;flex-direction:column;gap:4px;font-size:10px;font-weight:600;display:flex}select{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;padding:8px 10px;font-family:inherit;font-size:.9rem}select:focus{border-color:var(--text)}.plot-seed-premise{background:var(--surface-2);border-radius:9px;margin-bottom:16px;padding:16px 18px;font-size:.85rem;line-height:1.5}.plot-seed-premise strong{letter-spacing:.08em;color:var(--text-hint);text-transform:uppercase;margin-bottom:6px;font-size:10px;display:block}.plot-actions{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.plot-display{margin-top:24px}.plot-logline{border-left:2px solid var(--border);background:var(--surface-2);color:var(--text-muted);border-radius:0 9px 9px 0;margin:0 0 22px;padding:14px 20px;font-family:Georgia,Times New Roman,serif;font-size:14px;font-style:italic;line-height:1.9}.plot-characters{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px;display:grid}@media (width<=540px){.plot-characters{grid-template-columns:1fr}}.character-card{background:var(--surface-2);border-radius:var(--radius);padding:16px 18px}.character-card h4{letter-spacing:.08em;color:var(--text-hint);text-transform:uppercase;margin-bottom:10px;font-size:10px;font-weight:600}.char-name{margin-bottom:6px;font-weight:600}.char-detail{margin-bottom:4px;font-size:.85rem}.char-label{color:var(--text-hint)}.acts-grid{flex-direction:column;gap:12px;margin-bottom:22px;display:flex}.act-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:16px}.act-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.act-number{background:var(--genre-accent);color:#fff;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;font-size:10px;font-weight:700}.act-beats{counter-reset:beat;padding:0;list-style:none}.act-beats li{border-bottom:.5px solid var(--border-subtle);counter-increment:beat;padding:6px 0 6px 24px;font-size:.85rem;line-height:1.5;position:relative}.act-beats li:before{content:counter(beat) ".";color:var(--text-hint);font-size:.8rem;position:absolute;left:0}.act-beats li:last-child{border-bottom:none}.plot-question{border-left:2px solid var(--border);background:var(--surface-2);color:var(--text-muted);border-radius:0 9px 9px 0;margin:0;padding:14px 20px;font-family:Georgia,Times New Roman,serif;font-size:14px;font-style:italic;line-height:1.9}.session-tab h2{margin-bottom:16px;font-family:Georgia,Times New Roman,serif;font-weight:500}.session-controls{background:var(--surface-2);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;padding:16px 18px;display:flex}.session-controls select{flex:none}.session-timer{align-items:center;gap:10px;display:flex}.timer-display{color:var(--text);font-variant-numeric:tabular-nums;min-width:48px;font-size:1.4rem;font-weight:700}.timer-btns{gap:4px;display:flex}.stat{text-align:center;margin-left:auto}.stat-value{color:var(--text);font-size:1.4rem;font-weight:700;line-height:1;display:block}.stat-label{letter-spacing:.08em;color:var(--text-hint);text-transform:uppercase;font-size:10px}.session-prompt-hint{background:var(--surface-2);color:var(--text-muted);border-radius:9px;margin-bottom:22px;padding:16px 18px;font-family:Georgia,Times New Roman,serif;font-size:14px;font-style:italic;line-height:1.7}.session-prompt-hint strong{color:var(--text);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;font-family:system-ui,-apple-system,sans-serif;font-size:10px;font-style:normal;display:block}.scene-cards{margin-bottom:24px}.scene-cards-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.scene-cards-header h3{font-size:1rem}.scene-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:14px}.scene-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.scene-number{letter-spacing:.08em;color:var(--text-hint);text-transform:uppercase;font-size:10px;font-weight:600}.scene-textarea{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);resize:vertical;outline:none;padding:10px;font-family:Georgia,Times New Roman,serif;font-size:.95rem;line-height:1.7}.scene-textarea:focus{border-color:var(--text)}.session-notes h3{margin-bottom:8px;font-size:1rem}.notes-textarea{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);resize:vertical;outline:none;padding:12px;font-family:inherit;font-size:.9rem;line-height:1.5}.notes-textarea:focus{border-color:var(--text)}.skeleton-container{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.skeleton-header{margin-bottom:24px}.skeleton-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:24px;display:grid}.skeleton-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:14px}.skeleton-detail{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:10px;padding:28px 32px;display:flex}.skeleton-line{background:linear-gradient(90deg, var(--surface-2) 25%, #eeeee8 50%, var(--surface-2) 75%);background-size:200% 100%;border-radius:6px;height:12px;animation:1.5s infinite shimmer}.skeleton-bar{background:linear-gradient(90deg, var(--surface-2) 25%, #eeeee8 50%, var(--surface-2) 75%);background-size:200% 100%;border-radius:2px;height:4px;margin-top:8px;animation:1.5s infinite shimmer}.skeleton-wide{width:60%}.skeleton-narrow{width:35%}.skeleton-full{width:100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
