*{box-sizing:border-box;margin:0;padding:0}body{font-family:Georgia,Times New Roman,serif;background:#faf8f5;color:#2c2c2c;line-height:1.7;-webkit-font-smoothing:antialiased}.container{max-width:640px;margin:0 auto;padding:20px;min-height:100vh}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-page h1{font-size:2rem;margin-bottom:8px;color:#8b4513}.login-page .subtitle{font-size:.95rem;color:#888;margin-bottom:32px;font-style:italic}.login-page input{width:280px;padding:12px 16px;font-size:1.1rem;font-family:inherit;border:2px solid #ddd;border-radius:8px;margin-bottom:16px;text-align:center}.login-page input:focus{outline:none;border-color:#8b4513}.btn{padding:12px 32px;font-size:1rem;font-family:inherit;background:#8b4513;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn:hover{background:sienna}.btn:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:transparent;color:#8b4513;border:2px solid #8b4513}.btn-secondary:hover{background:#8b45130d}.welcome-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;text-align:center}.welcome-page h1{font-size:2rem;color:#8b4513;margin-bottom:24px}.welcome-body{max-width:480px;font-size:1.05rem;line-height:1.8;color:#555;margin-bottom:32px}.welcome-body p{margin-bottom:16px}.age-select-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;text-align:center}.age-select-page h1{font-size:1.8rem;color:#8b4513;margin-bottom:8px}.age-select-subtitle{color:#888;font-style:italic;margin-bottom:24px;font-size:.95rem}.age-select-page .tier-options{max-width:480px;width:100%;margin-bottom:24px}.age-select-page .btn{margin-top:8px}.home-page{padding-top:40px}.home-page h1{font-size:1.5rem;margin-bottom:4px}.home-page .welcome{color:#888;margin-bottom:32px;font-size:.9rem}.section-title{font-size:1.1rem;color:#8b4513;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px;font-size:.8rem}.campaign-card,.playthrough-card{background:#fff;border-radius:12px;padding:20px;margin-bottom:12px;box-shadow:0 1px 3px #00000014;cursor:pointer;transition:box-shadow .2s}.campaign-card:hover,.playthrough-card:hover{box-shadow:0 2px 8px #0000001f}.campaign-card h3{margin-bottom:4px;font-size:1.1rem}.campaign-card .genre{color:#888;font-size:.85rem;margin-bottom:8px}.campaign-card .description{font-size:.9rem;color:#555;line-height:1.5}.playthrough-card{display:flex;justify-content:space-between;align-items:center}.playthrough-card .info h3{font-size:1rem;margin-bottom:2px}.playthrough-card .info .meta{font-size:.8rem;color:#888}.playthrough-card .status{font-size:.75rem;padding:4px 10px;border-radius:12px;background:#e8f5e9;color:#2e7d32;font-family:sans-serif}.playthrough-card .status.completed{background:#f3e5f5;color:#7b1fa2}.campaign-start{padding-top:40px;text-align:center}.campaign-start h1{font-size:1.8rem;margin-bottom:8px;color:#8b4513}.campaign-start .genre{color:#888;font-style:italic;margin-bottom:24px}.campaign-start .description{text-align:left;font-size:.95rem;line-height:1.6;margin-bottom:32px;color:#555}.age-tier-picker{margin-bottom:32px}.age-tier-picker h3{margin-bottom:12px;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;color:#888}.tier-options{display:flex;flex-direction:column;gap:8px}.tier-option{padding:14px 20px;border:2px solid #ddd;border-radius:10px;cursor:pointer;transition:all .2s;text-align:left;background:#fff}.tier-option:hover{border-color:#8b4513}.tier-option.selected{border-color:#8b4513;background:#8b45130a}.tier-option .tier-name{font-weight:700;margin-bottom:2px}.tier-option .tier-desc{font-size:.85rem;color:#888}.gender-picker{margin-bottom:32px}.gender-picker h3{margin-bottom:12px;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;color:#888}.gender-options{display:flex;gap:12px;justify-content:center}.gender-option{padding:14px 32px;border:2px solid #ddd;border-radius:10px;cursor:pointer;transition:all .2s;background:#fff;font-size:1rem;font-weight:700;font-family:inherit}.gender-option:hover{border-color:#8b4513}.gender-option.selected{border-color:#8b4513;background:#8b45130a}.character-picker{margin-bottom:32px}.character-picker h3{margin-bottom:12px;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;color:#888}.character-carousel{display:flex;flex-direction:column;gap:12px}.character-card{display:flex;flex-direction:column;border:2px solid #ddd;border-radius:12px;cursor:pointer;transition:all .2s;background:#fff;text-align:left;overflow:hidden}.character-card:hover{border-color:#8b4513}.character-card.selected{border-color:#8b4513;background:#8b45130a;box-shadow:0 2px 8px #8b451326}.character-card.dimmed{opacity:.55}@media(max-width:600px){.character-carousel{flex-direction:row;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px;padding:4px 0;scrollbar-width:none}.character-carousel::-webkit-scrollbar{display:none}.character-card{flex:0 0 85%;scroll-snap-align:center}.character-card.dimmed{opacity:.7}}.character-portrait{width:100%;height:auto;display:block;background:#e8e0d8}.character-info{padding:14px 16px}.character-name{font-weight:700;font-size:1.1rem;margin-bottom:4px;color:#3c3c3c}.character-desc{font-size:.9rem;color:#555;line-height:1.5}.character-backstory{margin-top:8px}.backstory-text{font-size:.85rem;color:#666;line-height:1.5;margin-bottom:4px;font-style:italic}.backstory-toggle{background:none;border:none;color:#8b4513;cursor:pointer;font-size:.8rem;font-family:sans-serif;padding:0;text-decoration:underline}.backstory-toggle:hover{color:sienna}.reading-page{padding-top:20px;padding-bottom:120px}.story-column{min-width:0}.chapter-block{margin-bottom:40px}.chapter-header{text-align:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e0d8d0}.chapter-number{font-size:.75rem;text-transform:uppercase;letter-spacing:2px;color:#8b4513;margin-bottom:4px;font-family:sans-serif}.chapter-title{font-size:1.3rem;color:#3c3c3c}.chapter-content{font-size:1.05rem;line-height:1.8;white-space:pre-wrap}.chapter-content p{margin-bottom:1em}.chapter-choice{margin-top:16px;padding:12px 16px;background:#f0ebe4;border-radius:8px;font-size:.9rem;font-style:italic;color:#8b4513}.chapter-choice:before{content:"You chose: ";font-weight:700}.choice-panel{margin-top:32px;padding-top:24px;border-top:2px solid #e0d8d0}.choice-panel h3{font-size:.85rem;text-transform:uppercase;letter-spacing:1px;color:#8b4513;margin-bottom:12px;font-family:sans-serif}.suggestion-btn{display:block;width:100%;padding:14px 16px;margin-bottom:8px;background:#fff;border:2px solid #ddd;border-radius:10px;font-family:inherit;font-size:.95rem;cursor:pointer;text-align:left;transition:all .2s;color:#2c2c2c;line-height:1.4}.suggestion-btn:hover{border-color:#8b4513;background:#8b45130a}.choice-divider{text-align:center;margin:16px 0;color:#aaa;font-size:.85rem;font-family:sans-serif}.free-form-input{display:flex;gap:8px}.free-form-input input{flex:1;padding:12px 16px;font-family:inherit;font-size:.95rem;border:2px solid #ddd;border-radius:10px}.free-form-input input:focus{outline:none;border-color:#8b4513}.free-form-input .btn{padding:12px 20px;font-size:.9rem}.chapter-image{width:100%;border-radius:12px;margin:20px 0;box-shadow:0 2px 8px #0000001a;animation:fadeIn .3s ease}.chapter-image-placeholder{width:100%;height:200px;border-radius:12px;margin:20px 0;background:linear-gradient(110deg,#e8e0d8 8%,#f0ebe4 18%,#e8e0d8 33%);background-size:200% 100%;animation:shimmer 1.5s linear infinite}@keyframes shimmer{to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.streaming-cursor{display:inline-block;width:2px;height:1.1em;background:#8b4513;margin-left:2px;animation:blink .8s infinite;vertical-align:text-bottom}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.loading{text-align:center;padding:40px;color:#888;font-style:italic}.ending-block{text-align:center;margin-top:40px;padding:32px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014}.ending-block h2{font-size:1.3rem;color:#8b4513;margin-bottom:8px}.ending-block p{color:#888;margin-bottom:20px;font-style:italic}.back-link{display:inline-block;margin-bottom:20px;color:#8b4513;text-decoration:none;font-size:.9rem;font-family:sans-serif}.back-link:hover{text-decoration:underline}.logout-btn{background:none;border:none;color:#aaa;cursor:pointer;font-size:.8rem;font-family:sans-serif;padding:4px 0}.logout-btn:hover{color:#8b4513}.home-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.admin-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;color:#1a1a1a;line-height:1.5;min-height:100vh}.admin-page *{font-family:inherit}.admin-login{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}.admin-login h1{font-size:1.5rem;font-weight:600;margin-bottom:4px}.admin-login p{color:#666;margin-bottom:24px;font-size:.9rem}.admin-login form{display:flex;flex-direction:column;gap:12px;width:280px}.admin-topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid #e5e5e5;background:#fafafa}.admin-topbar-left{display:flex;align-items:center;gap:16px}.admin-topbar h1{font-size:1.1rem;font-weight:600}.admin-campaign-name{color:#666;font-size:.9rem}.admin-layout{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 53px)}.admin-sidebar{border-right:1px solid #e5e5e5;padding:12px 0;background:#fafafa}.admin-nav-item{display:block;width:100%;padding:10px 20px;text-align:left;background:none;border:none;cursor:pointer;font-size:.9rem;color:#444;transition:background .15s,color .15s}.admin-nav-item:hover{background:#eee;color:#111}.admin-nav-item.active{background:#e8e8e8;color:#111;font-weight:600}.admin-content{padding:24px 32px;max-width:900px}.admin-loading{color:#888;padding:40px;text-align:center}.admin-input,.admin-textarea,.admin-select{display:block;width:100%;padding:8px 12px;border:1px solid #d0d0d0;border-radius:6px;font-size:.9rem;background:#fff;color:#1a1a1a;transition:border-color .15s}.admin-input:focus,.admin-textarea:focus,.admin-select:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 2px #4a90d926}.admin-input[readonly]{background:#f5f5f5;color:#888}.admin-textarea{resize:vertical;min-height:80px;line-height:1.5}.admin-select{width:auto;padding-right:28px}.admin-btn{padding:8px 16px;border:1px solid #d0d0d0;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .15s;background:#fff;color:#333}.admin-btn:hover{background:#f0f0f0}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn-primary{background:#4a90d9;color:#fff;border-color:#4a90d9}.admin-btn-primary:hover{background:#3a7bc8}.admin-btn-secondary{background:transparent;color:#666}.admin-btn-danger{color:#dc3545;border-color:#dc3545}.admin-btn-danger:hover{background:#dc3545;color:#fff}.admin-field{margin-bottom:20px}.admin-field-label{display:block;font-size:.8rem;font-weight:600;color:#555;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.admin-string-list{display:flex;flex-direction:column;gap:6px}.admin-string-list-item{display:flex;gap:8px;align-items:center}.admin-string-list-item .admin-input{flex:1}.admin-string-list-item .admin-btn{padding:6px 10px;font-size:.8rem;flex-shrink:0}.admin-card{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:8px;overflow:hidden}.admin-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f8f8f8;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.admin-card-header:hover{background:#f0f0f0}.admin-card-title{font-size:.9rem;font-weight:500}.admin-card-chevron{font-size:.7rem;color:#888;transition:transform .15s}.admin-card-chevron.open{transform:rotate(90deg)}.admin-card-body{padding:16px;border-top:1px solid #e0e0e0}.admin-card-actions{display:flex;justify-content:flex-end;padding:8px 14px;border-top:1px solid #f0f0f0}.admin-nested{padding:12px;border:1px solid #eee;border-radius:6px;background:#fafafa}.admin-nested-label{font-size:.85rem;font-weight:600;color:#444;margin-bottom:12px}.admin-thread-group{margin-bottom:12px;padding:10px;border:1px solid #eee;border-radius:6px;background:#fafafa}.admin-thread-label{font-size:.8rem;font-weight:600;color:#666;margin-bottom:8px;text-transform:capitalize}.admin-image-pair{display:flex;gap:20px}.admin-image-slot{display:flex;flex-direction:column;align-items:center;gap:8px}.admin-image-slot label{font-size:.8rem;font-weight:600;color:#666}.admin-image-preview{width:100px;height:100px;border-radius:8px;object-fit:cover;background:#f0f0f0;border:1px solid #ddd}.admin-image-placeholder{width:100px;height:100px;border-radius:8px;background:#f0f0f0;border:1px dashed #ccc;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#999}.admin-save-bar{display:flex;align-items:center;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #e5e5e5}.admin-message{font-size:.85rem;padding:4px 0}.admin-message.success{color:#28a745}.admin-message.error{color:#dc3545}.admin-error{color:#dc3545;font-size:.85rem;margin-top:8px}.admin-section-header{font-size:1.2rem;font-weight:600;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #e5e5e5}.admin-tier-section{margin-bottom:16px}.admin-tier-label{font-size:.9rem;font-weight:600;color:#333;margin-bottom:12px;text-transform:capitalize}.admin-add-row{margin-top:8px}.admin-nav-divider{height:1px;background:#e0e0e0;margin:8px 16px}.pt-inspector{width:100%}.pt-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.pt-list-header h2{font-size:1.2rem;font-weight:600}.pt-card{border:1px solid #e0e0e0;border-radius:8px;padding:14px 16px;margin-bottom:8px;cursor:pointer;transition:background .15s,box-shadow .15s}.pt-card:hover{background:#f8f8f8;box-shadow:0 1px 4px #00000014}.pt-card-header{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:500;flex-wrap:wrap}.pt-card-status{font-size:.85rem}.pt-card-sep{color:#aaa;font-size:.8rem}.pt-card-user{color:#555}.pt-card-meta{font-size:.8rem;color:#888;margin-top:4px}.pt-card-campaign{font-size:.8rem;color:#666;margin-top:2px}.pt-empty{color:#888;font-size:.9rem;text-align:center;padding:32px 0}.pt-detail-loading{color:#888;font-size:.9rem;padding:16px 0;text-align:center}.pt-back-btn{margin-bottom:16px}.pt-detail-header{display:flex;align-items:center;gap:6px;font-size:.9rem;color:#444;margin-bottom:16px;flex-wrap:wrap}.pt-tabs{display:flex;gap:0;border-bottom:2px solid #e5e5e5;margin-bottom:20px}.pt-tab{padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:.9rem;color:#666;transition:color .15s,border-color .15s}.pt-tab:hover{color:#333}.pt-tab.active{color:#4a90d9;border-bottom-color:#4a90d9;font-weight:600}.pt-chapter-block{margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid #eee}.pt-chapter-block:last-child{border-bottom:none}.pt-chapter-header h3{font-size:1rem;font-weight:600;margin-bottom:4px}.pt-chapter-meta{font-size:.8rem;color:#888;margin-bottom:12px}.pt-chapter-content{font-size:.9rem;line-height:1.7;white-space:pre-wrap;margin-bottom:12px}.pt-chapter-image{max-width:100%;border-radius:8px;margin:12px 0;box-shadow:0 1px 4px #0000001a;cursor:pointer}.pt-player-choice{padding:8px 12px;background:#e8f4fd;border-radius:6px;font-size:.85rem;color:#1a6daa;font-weight:500;margin-bottom:8px}.pt-suggestions{margin-top:8px}.pt-suggestions-label{font-size:.8rem;color:#888;margin-bottom:4px}.pt-suggestions-list{margin:0;padding-left:20px;font-size:.85rem;color:#555}.pt-suggestions-list li{margin-bottom:2px}.pt-suggestions-list li.pt-chosen{font-weight:600;color:#1a6daa}.pt-story-state{font-size:.9rem}.pt-state-section{margin-bottom:24px;padding:16px;border:1px solid #eee;border-radius:8px;background:#fafafa}.pt-state-section h3{font-size:1rem;font-weight:600;margin-bottom:12px}.pt-state-block{margin-bottom:12px}.pt-state-label{font-size:.8rem;font-weight:600;color:#555}.reading-layout{max-width:640px;margin:0 auto;padding:20px;min-height:100vh}.reading-layout.debug-active{max-width:1200px;display:grid;grid-template-columns:1fr 420px;gap:24px}@media(max-width:1023px){.reading-layout.debug-active{grid-template-columns:1fr}}.debug-panel{position:sticky;top:0;height:100vh;overflow-y:auto;border-left:2px solid #e0d8d0;padding:16px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;background:#fdfcfa}@media(max-width:1023px){.debug-panel{position:static;height:auto;max-height:60vh;border-left:none;border-top:2px solid #e0d8d0}}.debug-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px solid #e0d8d0;margin-bottom:12px;position:sticky;top:0;background:#fdfcfa;z-index:1}.debug-header-left{display:flex;align-items:center;gap:8px}.debug-label{font-weight:700;color:#e67e22;letter-spacing:1px;font-size:11px}.debug-inactive{font-size:11px;color:#ef4444}.debug-waiting{font-size:11px;color:#f59e0b}.debug-clear-btn{padding:4px 10px;font-size:11px;font-family:inherit;border:1px solid #d0d0d0;border-radius:4px;background:#fff;cursor:pointer;color:#666}.debug-clear-btn:hover{background:#f0f0f0;color:#333}.debug-entry{border:1px solid #e0d8d0;border-radius:6px;margin-bottom:8px;overflow:hidden}.debug-entry-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;cursor:pointer;background:#f8f6f2;font-weight:600;gap:8px}.debug-entry-header:hover{background:#f0ebe4}.debug-entry-header-left{display:flex;align-items:center;gap:6px;min-width:0}.debug-entry-header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.debug-entry-chevron{font-size:9px;color:#888;flex-shrink:0}.debug-entry-type{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.debug-entry-time{font-size:10px;color:#888;font-weight:400}.debug-entry-duration{font-size:11px;font-weight:400;color:#666}.debug-entry.error .debug-entry-header{background:#fef2f2;border-left:3px solid #ef4444}.debug-entry.success .debug-entry-header{border-left:3px solid #22c55e}.debug-entry.in-progress .debug-entry-header{border-left:3px solid #f59e0b}.debug-entry-summary{padding:6px 12px;font-size:11px;color:#555;background:#fcfbf9;border-top:1px solid #f0ebe4}.debug-summary-item{line-height:1.6}.debug-summary-label{color:#888}.debug-entry-details{padding:12px;background:#fff;border-top:1px solid #e0d8d0}.debug-text-section{margin-bottom:12px}.debug-text-section:last-child{margin-bottom:0}.debug-text-label{font-size:10px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.pt-state-value{color:#333;line-height:1.6}.pt-flag{font-family:monospace;font-size:.85rem}.pt-flag-key{color:#666}.pt-choice-entry{margin-bottom:8px;padding-left:8px;border-left:2px solid #ddd}.pt-choice-chapter{font-weight:500}.pt-choice-outcome{font-size:.85rem;color:#666;margin-top:2px}.pt-images-section{margin-bottom:24px}.pt-images-section h3{font-size:1rem;font-weight:600;margin-bottom:12px}.pt-images-section h4{font-size:.9rem;font-weight:600;color:#555;margin-bottom:8px;text-transform:capitalize}.pt-ref-group{margin-bottom:16px}.pt-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.pt-image-thumb{cursor:pointer;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:box-shadow .15s}.pt-image-thumb:hover{box-shadow:0 2px 8px #0000001f}.pt-image-thumb img{width:100%;height:120px;object-fit:cover;display:block;background:#f0f0f0}.pt-image-broken{width:100%;height:120px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;color:#999;font-size:.75rem}.pt-image-label{padding:4px 8px;font-size:.8rem;font-weight:500;color:#444}.pt-image-meta{padding:0 8px 6px;font-size:.7rem;color:#888}.lightbox-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.lightbox-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;cursor:default}.debug-text-block{background:#1e1e1e;color:#d4d4d4;padding:12px;border-radius:4px;font-size:11px;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;margin:4px 0;position:relative}.debug-ref-list{list-style:disc;padding-left:18px;font-size:11px;color:#555}.debug-ref-list li{margin-bottom:2px}.debug-refs-detail{display:flex;flex-direction:column;gap:4px;margin-top:4px}.debug-ref-group{display:flex;flex-wrap:wrap;align-items:center;gap:4px;font-size:11px}.debug-ref-type{color:#888;font-weight:500;white-space:nowrap}.debug-ref-tag{background:#e8f0fe;color:#1a56db;padding:1px 6px;border-radius:3px;font-size:10px;font-family:monospace;position:relative}.debug-ref-tag.has-preview{cursor:pointer;text-decoration:underline dotted}.debug-ref-preview{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:1000;background:#1a1a2e;border:1px solid #444;border-radius:6px;padding:4px;box-shadow:0 4px 16px #0006;pointer-events:none}.debug-ref-preview img{display:block;max-width:200px;max-height:200px;border-radius:4px}.debug-ref-tag.generated{background:#d4edda;color:#155724}.debug-ref-tag.failed{background:#f8d7da;color:#721c24}.debug-show-more{color:#3b82f6;cursor:pointer;font-size:11px;border:none;background:none;padding:2px 0;font-family:inherit}.debug-show-more:hover{text-decoration:underline}.debug-copy-btn{position:absolute;top:6px;right:6px;padding:2px 6px;font-size:10px;background:#333;color:#aaa;border:1px solid #555;border-radius:3px;cursor:pointer;font-family:inherit}.debug-copy-btn:hover{background:#444;color:#ddd}.debug-status-icon{font-size:12px;font-weight:700}.debug-status-icon.success{color:#22c55e}.debug-status-icon.error{color:#ef4444}.debug-status-spinner{display:inline-block;width:12px;height:12px;border:2px solid #f59e0b;border-top-color:transparent;border-radius:50%;animation:debug-spin .8s linear infinite}@keyframes debug-spin{to{transform:rotate(360deg)}}.style-refs-intro{color:#666;font-size:.9rem;line-height:1.6;margin-bottom:24px;max-width:600px}.style-refs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.style-ref-card{border:1px solid #d0d0d0;border-radius:10px;overflow:hidden;background:#fff}.style-ref-header{padding:16px 16px 8px}.style-ref-header h3{margin:0 0 4px;font-size:1rem;color:#1a1a1a}.style-ref-header p{margin:0;font-size:.8rem;color:#888;line-height:1.4}.style-ref-preview{padding:0 16px}.style-ref-image{width:100%;border-radius:6px;display:block;object-fit:cover;max-height:200px}.style-ref-empty{width:100%;height:140px;background:#f5f5f5;border:2px dashed #d0d0d0;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#aaa;font-size:.85rem}.style-ref-actions{padding:12px 16px 16px;display:flex;gap:8px}.style-ref-upload-btn{cursor:pointer;text-align:center}.style-ref-upload-btn.disabled{opacity:.6;pointer-events:none}.dice-roll-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;margin:16px 0}.dice-d20{width:120px;height:120px}.dice-svg{width:100%;height:100%}.dice-face{fill:#f5f0e6;stroke:#8b4513;stroke-width:2}.dice-face-highlight{fill:#8b45131a;stroke:none}.dice-number{font-family:Georgia,serif;font-size:28px;font-weight:700;fill:#8b4513}.dice-tumbling{animation:dice-tumble 3s ease-out forwards}.dice-landed{animation:dice-land .3s ease-out forwards}@keyframes dice-tumble{0%{transform:rotate(0) scale(.5);opacity:0}20%{transform:rotate(180deg) scale(1.1);opacity:1}40%{transform:rotate(360deg) scale(.95)}60%{transform:rotate(540deg) scale(1.05)}80%{transform:rotate(680deg) scale(1)}to{transform:rotate(720deg) scale(1)}}@keyframes dice-land{0%{transform:scale(1.1)}to{transform:scale(1)}}.dice-result-text{margin-top:12px;font-family:Georgia,serif;font-size:16px;color:#666;text-align:center;animation:dice-result-appear .3s ease-out}.dice-outcome-label{margin-top:8px;font-family:Georgia,serif;font-size:26px;font-weight:700;color:#8b4513;text-align:center;animation:dice-result-appear .4s ease-out}@keyframes dice-result-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dice-result-crit-success{color:#d4a017}.dice-result-crit-success .dice-face{fill:#fff8dc;stroke:#d4a017}.dice-result-crit-success .dice-number{fill:#d4a017}.dice-result-success{color:#2e7d32}.dice-result-success .dice-face{fill:#e8f5e9;stroke:#2e7d32}.dice-result-success .dice-number{fill:#2e7d32}.dice-result-failure{color:#c62828}.dice-result-failure .dice-face{fill:#ffebee;stroke:#c62828}.dice-result-failure .dice-number{fill:#c62828}.dice-result-crit-failure{color:#8b0000}.dice-result-crit-failure .dice-face{fill:#f3e5e5;stroke:#8b0000}.dice-result-crit-failure .dice-number{fill:#8b0000}.dice-challenge{text-align:center;margin-bottom:16px;animation:dice-result-appear .4s ease-out}.dice-target{font-family:Georgia,serif;font-size:20px;font-weight:700;color:#8b4513;text-align:center}.dice-difficulty{margin-top:4px;font-family:Georgia,serif;font-size:15px;font-style:italic;color:#8b7355;text-align:center}.dice-flavor-text{margin-top:8px;font-family:Georgia,serif;font-size:15px;font-style:italic;color:#666;text-align:center;animation:dice-result-appear .4s ease-out}.dice-continue-btn{margin-top:16px;padding:10px 24px;font-family:Georgia,serif;font-size:1rem;background:#8b4513;color:#fff;border:none;border-radius:8px;cursor:pointer;animation:dice-result-appear .3s ease-out}.dice-continue-btn:hover{background:sienna}.skill-check-pending{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;font-family:Georgia,serif;font-style:italic;color:#8b4513}.skill-check-spinner{width:16px;height:16px;border:2px solid #d4c4a8;border-top-color:#8b4513;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.character-sheet-floating-icon{position:fixed;top:72px;right:20px;z-index:100;background:#f5f0e6;border:2px solid #8b4513;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#8b4513;box-shadow:0 2px 8px #00000026;transition:transform .2s}.character-sheet-floating-icon:hover{transform:scale(1.1)}.character-sheet-hp-badge{position:absolute;bottom:-4px;right:-4px;background:#c62828;color:#fff;font-size:10px;font-weight:700;padding:1px 4px;border-radius:8px;min-width:16px;text-align:center}.character-sheet-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;justify-content:flex-end}.character-sheet-panel{width:320px;max-width:90vw;height:100%;background:#faf8f5;box-shadow:-4px 0 16px #0003;padding:24px;overflow-y:auto;animation:sheet-slide-in .3s ease-out;position:relative}@keyframes sheet-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.character-sheet-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;color:#8b4513;cursor:pointer}.character-sheet-header h2{font-family:Georgia,serif;color:#8b4513;margin:0 0 16px;font-size:24px}.character-sheet-section{margin-bottom:20px}.character-sheet-section h3{font-family:Georgia,serif;color:sienna;font-size:14px;text-transform:uppercase;letter-spacing:1px;margin:0 0 8px;border-bottom:1px solid #d4c4a8;padding-bottom:4px}.character-sheet-hp-bar{height:20px;background:#e0d6c8;border-radius:10px;overflow:hidden;border:1px solid #8b4513}.character-sheet-hp-fill{height:100%;background:linear-gradient(to right,#c62828,#e53935);border-radius:10px;transition:width .5s ease-out}.character-sheet-hp-text{text-align:center;font-size:14px;font-weight:700;color:#8b4513;margin-top:4px}.character-sheet-hearts{font-size:24px;text-align:center}.character-sheet-attributes{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.character-sheet-attr-card{background:#f0ebe0;border:1px solid #d4c4a8;border-radius:8px;padding:8px;text-align:center}.character-sheet-attr-label{font-size:11px;font-weight:700;color:sienna;text-transform:uppercase;letter-spacing:.5px}.character-sheet-attr-score{font-size:20px;font-weight:700;color:#8b4513;margin:4px 0 2px}.character-sheet-attr-mod{font-size:12px;color:#666}.character-sheet-roll-history{display:flex;flex-direction:column;gap:6px}.character-sheet-roll-entry{display:flex;align-items:center;gap:8px;font-size:13px;padding:4px 8px;background:#f0ebe0;border-radius:4px}.roll-chapter{color:#999;font-size:11px;min-width:32px}.roll-attr{font-weight:700;color:#8b4513;min-width:48px}.roll-result{color:#555;flex:1}.roll-outcome{font-weight:700;font-size:12px}.combat-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #c62828;border-radius:12px;padding:20px;margin:24px 0;color:#e0e0e0}.combat-header{text-align:center;margin-bottom:16px}.combat-round-indicator{font-size:18px;font-weight:700;color:#ff6b6b;text-transform:uppercase;letter-spacing:2px}.combat-arena{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;padding:12px 0}.combat-player-side{flex:0 0 auto;text-align:center;min-width:80px}.combat-player-portrait img{width:64px;height:64px;border-radius:8px;border:2px solid #4caf50;object-fit:cover}.combat-player-silhouette{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:8px;border:2px solid #4caf50;background:#2a2a3e}.combat-player-hp-hearts{margin-top:4px;font-size:16px}.combat-vs{flex:0 0 auto;font-size:24px;font-weight:700;color:#ff6b6b;align-self:center}.combat-enemies-side{flex:1 1 auto;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}.combat-enemy-card{text-align:center;min-width:70px;transition:opacity .3s}.combat-enemy-defeated{opacity:.4}.combat-enemy-portrait{position:relative;width:60px;height:60px;margin:0 auto}.combat-enemy-portrait img{width:60px;height:60px;border-radius:8px;border:2px solid #c62828;object-fit:cover}.combat-enemy-silhouette{display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:8px;border:2px solid #c62828;background:#2a2a3e}.combat-enemy-ko-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px;font-weight:700;color:#ff6b6b;text-shadow:0 0 4px rgba(0,0,0,.8)}.combat-enemy-name{font-size:12px;margin-top:4px;color:#ccc}.combat-health-bar-wrapper{margin-top:4px}.combat-health-label{font-size:11px;color:#aaa;margin-bottom:2px}.combat-health-bar{height:8px;background:#333;border-radius:4px;overflow:hidden;min-width:60px}.combat-health-bar-fill{height:100%;border-radius:4px;transition:width .5s ease,background-color .5s ease}.combat-health-numbers{font-size:11px;color:#aaa;margin-top:2px}.combat-log{max-height:120px;overflow-y:auto;padding:8px 12px;background:#0000004d;border-radius:8px;margin-bottom:16px;font-size:14px;line-height:1.6}.combat-log-entry{margin-bottom:4px;padding:2px 0}.combat-log-hit{color:#ff6b6b}.combat-log-miss{color:#aaa}.combat-enemy-action{text-align:center;padding:8px 12px;margin-bottom:12px;border-radius:8px;font-size:14px;animation:combat-flash .3s ease}.combat-enemy-hit{background:#c6282833;border:1px solid rgba(198,40,40,.4)}.combat-enemy-miss{background:#64646433;border:1px solid rgba(100,100,100,.4)}.combat-enemy-roll{color:#888;font-size:12px}.combat-damage{color:#ff6b6b;font-weight:700}.combat-miss{color:#888;font-style:italic}.combat-actions{border-top:1px solid rgba(255,255,255,.1);padding-top:16px}.combat-prompt{text-align:center;font-size:16px;margin-bottom:12px;color:#e0e0e0}.combat-free-text{display:flex;gap:8px;margin-bottom:12px}.combat-free-text input{flex:1;padding:8px 12px;border:1px solid #555;border-radius:8px;background:#2a2a3e;color:#e0e0e0;font-size:14px}.combat-free-text input::placeholder{color:#888}.combat-free-text .btn{padding:8px 16px}.combat-action-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.combat-action-btn{padding:8px 20px;border:2px solid #555;border-radius:8px;background:#ffffff0d;color:#e0e0e0;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.combat-action-btn:hover:not(:disabled){background:#ff6b6b33;border-color:#ff6b6b;color:#fff}.combat-action-btn:disabled{opacity:.5;cursor:not-allowed}.combat-processing{text-align:center;padding:16px;color:#aaa;font-size:14px}@keyframes combat-flash{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
