@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Inter:wght@300;400;500;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.campaign-dashboard{padding:2rem 0}.campaign-dashboard h2{color:#8b2c2c;font-size:2rem;margin-bottom:2rem;text-align:center;border-bottom:3px solid #d4af37;padding-bottom:1rem}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:linear-gradient(135deg,#f4e4c1fa,#e8d4a8fa);border:2px solid #d4af37;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0000004d;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0006}.stat-icon{font-size:2.5rem;line-height:1}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:700;color:#8b2c2c;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.9rem;color:#6b3410;text-transform:uppercase;letter-spacing:.5px}.dashboard-section{background:linear-gradient(135deg,#f4e4c1fa,#e8d4a8fa);border:2px solid #d4af37;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 12px #0000004d}.dashboard-section h3{color:#8b2c2c;font-size:1.4rem;margin-top:0;margin-bottom:1rem;border-bottom:2px solid #d4af37;padding-bottom:.5rem}.recent-activity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.activity-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffff80;border-radius:8px;border:1px solid #8b4513}.activity-label{color:#6b3410;font-weight:600}.activity-value{color:#8b2c2c;font-size:1.5rem;font-weight:700}.dashboard-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-top:2rem}.chart-card{background:linear-gradient(135deg,#f4e4c1fa,#e8d4a8fa);border:2px solid #d4af37;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000004d}.chart-card.chart-wide{grid-column:span 2}.chart-card h3{color:#8b2c2c;font-size:1.3rem;margin-top:0;margin-bottom:1rem;border-bottom:2px solid #d4af37;padding-bottom:.5rem}.chart-container{height:300px;position:relative}.chart-wide .chart-container{height:250px}.dashboard-loading{text-align:center;padding:3rem;color:#6b3410;font-size:1.2rem;font-style:italic}@media(max-width:1200px){.chart-card.chart-wide{grid-column:span 1}}@media(max-width:768px){.dashboard-stats-grid,.dashboard-charts-grid{grid-template-columns:1fr}.chart-card.chart-wide{grid-column:span 1}.stat-card{padding:1rem}.stat-icon{font-size:2rem}.stat-value{font-size:1.5rem}.chart-container{height:250px}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a0f;--bg-secondary: #13131a;--bg-card: #1a1a24;--bg-elevated: #22222f;--bg-glass: rgba(26, 26, 36, .7);--bg-glass-light: rgba(34, 34, 47, .5);--gradient-gold: linear-gradient(135deg, #f6d365 0%, #fda085 100%);--gradient-purple: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-emerald: linear-gradient(135deg, #56ab2f 0%, #a8e063 100%);--gradient-crimson: linear-gradient(135deg, #eb3349 0%, #f45c43 100%);--gradient-royal: linear-gradient(135deg, #8e2de2 0%, #4a00e0 100%);--text-primary: #ffffff;--text-secondary: #b8b8d1;--text-muted: #6b6b8a;--text-accent: #f6d365;--gold-primary: #f6d365;--gold-light: #ffd89b;--gold-dark: #e8c45f;--purple-primary: #8b7cf7;--purple-light: #a69af9;--purple-dark: #7165e3;--emerald-primary: #56ab2f;--emerald-light: #a8e063;--crimson-primary: #eb3349;--crimson-dark: #d62828;--success: #56ab2f;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .15);--shadow-md: 0 4px 16px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .45);--glow-gold: 0 0 40px rgba(246, 211, 101, .3);--glow-purple: 0 0 40px rgba(139, 124, 247, .3);--glow-emerald: 0 0 40px rgba(86, 171, 47, .3);--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .15);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--radius-2xl: 32px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55)}.modal-loading{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0a0fcc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-primary);font-family:Cinzel,serif;font-size:1.25rem;z-index:9999;animation:fadeIn .2s ease-out}.modal-loading:after{content:"";position:absolute;width:40px;height:40px;border:3px solid var(--border-medium);border-top-color:var(--gold-primary);border-radius:50%;animation:spin 1s linear infinite;margin-top:60px}html{scroll-behavior:smooth}body{background:var(--bg-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);position:relative;line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse 120% 80% at 30% 20%,rgba(139,124,247,.08) 0%,transparent 50%),radial-gradient(ellipse 100% 70% at 70% 80%,rgba(246,211,101,.06) 0%,transparent 50%),radial-gradient(ellipse 80% 60% at 50% 50%,rgba(86,171,47,.04) 0%,transparent 50%);pointer-events:none;z-index:0;animation:backgroundPulse 20s ease-in-out infinite}@keyframes backgroundPulse{0%,to{opacity:1}50%{opacity:.7}}::selection{background:var(--gold-primary);color:var(--bg-primary)}::-moz-selection{background:var(--gold-primary);color:var(--bg-primary)}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--gold-primary),var(--purple-primary));border-radius:6px;border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--gold-light),var(--purple-light))}h1,h2,h3,h4,h5,h6{font-family:Cinzel,serif;font-weight:700;letter-spacing:.02em;line-height:1.3;margin-bottom:var(--space-md)}h1{font-size:clamp(2.25rem,5vw,3.5rem);background:var(--gradient-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-lg)}h2{font-size:clamp(1.75rem,4vw,2.5rem);color:var(--text-primary)}h3{font-size:clamp(1.25rem,3vw,1.75rem);color:var(--text-secondary)}p{margin-bottom:var(--space-md);color:var(--text-secondary)}.app{max-width:1600px;margin:0 auto;padding:var(--space-xl);position:relative;z-index:1}@media(max-width:768px){.app{padding:var(--space-md)}}.app-header{text-align:center;margin-bottom:var(--space-2xl);padding:var(--space-3xl) var(--space-xl);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-medium);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg),var(--glow-gold);position:relative;overflow:visible;animation:fadeInUp .8s cubic-bezier(.16,1,.3,1)}.app-header:before{content:"";position:absolute;top:0;left:-50%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(246,211,101,.05),transparent);animation:shimmer 8s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.logo-container{display:flex;align-items:center;justify-content:center;gap:1rem;position:relative;z-index:1}.logo{width:64px;height:64px;flex-shrink:0}.logo svg{width:100%;height:100%}.logo-container>div:last-child{text-align:left}.app-header h1{position:relative;z-index:1;margin-bottom:var(--space-sm);text-shadow:0 4px 12px rgba(246,211,101,.3)}.app-header .subtitle{position:relative;z-index:1;font-size:1.125rem;color:var(--text-secondary);margin:0}.app-header p{position:relative;z-index:1;font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.global-search-btn{position:absolute;top:1rem;right:1rem;z-index:10;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.global-search-btn:hover{background:var(--bg-card);border-color:var(--gold-primary);color:var(--text-secondary)}.global-search-btn .search-hint{font-size:.85rem}.global-search-btn kbd{padding:.15rem .4rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:.7rem}@media(max-width:600px){.global-search-btn .search-hint,.global-search-btn kbd{display:none}}.campaign-selector{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-2xl);padding:var(--space-lg);background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-medium);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) .2s both;flex-wrap:wrap}.campaign-selector label{font-weight:600;color:var(--text-primary);font-size:1.125rem}.campaign-selector select{flex:1;max-width:400px;padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);outline:none}.campaign-selector select:hover{border-color:var(--gold-primary);box-shadow:0 0 0 3px #f6d3651a}.campaign-selector select:focus{border-color:var(--gold-primary);box-shadow:0 0 0 4px #f6d36533}button{font-family:Inter,sans-serif;font-weight:600;cursor:pointer;transition:all var(--transition-base);outline:none;border:none}.action-button{padding:var(--space-md) var(--space-xl);background:var(--gradient-gold);color:var(--bg-primary);border-radius:var(--radius-md);font-size:1rem;font-weight:700;box-shadow:var(--shadow-md);position:relative;overflow:hidden;transition:all var(--transition-base)}.action-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.action-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--glow-gold)}.action-button:hover:before{left:100%}.action-button:active{transform:translateY(0)}.action-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-button{padding:var(--space-md) var(--space-xl);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-base)}.secondary-button:hover{border-color:var(--gold-primary);background:var(--bg-card);transform:translateY(-1px)}.cancel-button,.delete-button{padding:var(--space-md) var(--space-xl);background:var(--bg-elevated);color:var(--error);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-base)}.cancel-button:hover,.delete-button:hover{background:var(--error);color:#fff;border-color:var(--error);box-shadow:0 0 20px #ef444466}.tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-2xl);overflow-x:auto;padding:var(--space-sm);background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-medium);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) .3s both}.tabs::-webkit-scrollbar{height:6px}.tab{padding:var(--space-md) var(--space-xl);background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;white-space:nowrap;transition:all var(--transition-base);position:relative}.tab:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:3px;background:var(--gradient-gold);border-radius:3px;transform:translate(-50%);transition:width var(--transition-base)}.tab:hover{color:var(--text-secondary);background:#ffffff08}.tab.active{color:var(--text-primary);background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.tab.active:before{width:80%}.navigation{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);margin-bottom:var(--space-2xl);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-medium);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) .3s both;flex-wrap:wrap}.nav-group{display:flex;gap:var(--space-xs);align-items:center}.nav-divider{width:1px;height:24px;background:var(--border-medium);margin:0 var(--space-sm)}.nav-button{padding:var(--space-sm) var(--space-md);background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;white-space:nowrap;transition:all var(--transition-base);position:relative}.nav-button:before{content:"";position:absolute;bottom:2px;left:50%;width:0;height:2px;background:var(--gradient-gold);border-radius:2px;transform:translate(-50%);transition:width var(--transition-base)}.nav-button:hover{color:var(--text-secondary);background:#ffffff08}.nav-button:hover:before{width:60%}.nav-button.active{color:var(--gold-primary);background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.nav-button.active:before{width:80%}.nav-button:disabled{opacity:.4;cursor:not-allowed}.nav-button:disabled:hover{background:transparent;color:var(--text-muted)}.nav-button:disabled:hover:before{width:0}@media(max-width:900px){.navigation{gap:var(--space-sm);padding:var(--space-sm)}.nav-group{flex-wrap:wrap;justify-content:center}.nav-divider{display:none}.nav-button{padding:var(--space-xs) var(--space-sm);font-size:.85rem}}@media(max-width:600px){.navigation{flex-direction:column;gap:var(--space-xs)}.nav-group{width:100%;justify-content:center}}.card{background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);transition:all var(--transition-base);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1)}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-2px)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=file],select,textarea{width:100%;padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-family:Inter,sans-serif;transition:all var(--transition-base);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--gold-primary);box-shadow:0 0 0 4px #f6d3651a;background:var(--bg-card)}textarea{resize:vertical;min-height:120px;line-height:1.6}::placeholder{color:var(--text-muted);opacity:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.modal-overlay{position:fixed;inset:0;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);animation:fadeIn var(--transition-base)}.modal-content{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius-2xl);padding:var(--space-2xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:scaleIn var(--transition-slow);position:relative}.modal-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-base)}.modal-close:hover{background:var(--error);color:#fff;border-color:var(--error);transform:rotate(90deg)}.entity-filters{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.search-box{position:relative;width:100%}.search-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);font-size:1.25rem;color:var(--text-muted);pointer-events:none;z-index:1}.search-input{width:100%;padding:var(--space-md) var(--space-md) var(--space-md) 3rem;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:all var(--transition-base);font-family:Inter,sans-serif}.search-input:focus{outline:none;border-color:var(--gold-primary);box-shadow:0 0 0 3px #d4af371a;background:var(--bg-card)}.search-input::placeholder{color:var(--text-muted);opacity:.6}.search-clear{position:absolute;right:var(--space-md);top:50%;transform:translateY(-50%);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);padding:0;line-height:1}.search-clear:hover{background:var(--error);color:#fff;border-color:var(--error);transform:translateY(-50%) rotate(90deg)}.filter-controls{display:flex;gap:var(--space-md);flex-wrap:wrap}.filter-select{flex:1;min-width:200px;padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-base)}.filter-select:hover{border-color:var(--border-strong);background:var(--bg-card)}.filter-select:focus{outline:none;border-color:var(--gold-primary);box-shadow:0 0 0 3px #d4af371a}.filter-select option{background:var(--bg-card);color:var(--text-primary)}.entity-count{margin-top:var(--space-lg);color:var(--text-muted);font-size:.9375rem;font-style:italic;text-align:center}.entity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md);margin-top:var(--space-md);align-items:start}@media(max-width:768px){.entity-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media(max-width:480px){.entity-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.entity-card{background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-lg);padding:var(--space-sm);box-shadow:var(--shadow-md);transition:all var(--transition-base);cursor:pointer;position:relative;overflow:hidden;animation:fadeInUp .6s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;min-height:0}.entity-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--gradient-gold);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.entity-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg),var(--glow-gold);transform:translateY(-4px)}.entity-card:hover:before{transform:scaleX(1)}.entity-card.collapsed .entity-card-content{padding:.75rem}.entity-card.collapsed .entity-description,.entity-card.collapsed .entity-tags-preview{display:none}.entity-card-header{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-xs);flex-shrink:0}.entity-card-header h4{font-family:Cinzel,serif;font-size:.85rem;color:var(--text-primary);margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.entity-card.collapsed .entity-card-header{margin-bottom:0}.entity-card.collapsed .entity-type-badge{font-size:.55rem;padding:.15rem .4rem}.entity-type-badge{display:inline-block;padding:.25rem .5rem;background:var(--gradient-gold);color:var(--bg-primary);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm);align-self:flex-start;font-family:Inter,sans-serif}.expand-indicator{display:none}.entity-card-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.entity-description{color:var(--text-secondary);line-height:1.5;font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1}.entity-expanded-modal{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-xl);animation:fadeIn var(--transition-base)}.entity-expanded-content{background:var(--bg-card);border:2px solid var(--gold-primary);border-radius:var(--radius-2xl);padding:var(--space-2xl);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl),var(--glow-gold);animation:scaleIn var(--transition-slow);position:relative}.entity-expanded-content h3{font-family:Cinzel,serif;font-size:2rem;color:var(--text-primary);margin-bottom:var(--space-lg);background:var(--gradient-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.entity-expanded-content .entity-description{font-size:1rem;line-height:1.8;color:var(--text-secondary);white-space:pre-wrap;display:block;-webkit-line-clamp:unset;-webkit-box-orient:unset;overflow:visible;text-overflow:unset;margin-bottom:var(--space-xl)}.entity-expanded-content .entity-thumbnail{max-height:400px;width:auto;margin:0 auto var(--space-xl) auto;display:block}.entity-expanded-content .entity-metadata{display:flex;flex-wrap:wrap;gap:var(--space-lg);margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-medium)}.entity-expanded-close{position:absolute;top:var(--space-lg);right:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-base)}.entity-expanded-close:hover{background:var(--error);color:#fff;border-color:var(--error);transform:rotate(90deg)}@media(max-width:768px){.entity-expanded-modal{padding:var(--space-md)}.entity-expanded-content{padding:var(--space-lg)}.entity-expanded-content h3{font-size:1.5rem}}.entity-relationships-section{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-lg)}.entity-relationships-section h4{font-family:Cinzel,serif;font-size:1.125rem;color:var(--text-primary);margin:0 0 var(--space-md) 0}.relationships-list{display:flex;flex-direction:column;gap:var(--space-sm)}.relationship-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);transition:all var(--transition-base)}.relationship-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.relationship-info{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.relationship-type{display:inline-block;padding:.25rem .625rem;background:var(--gradient-gold);color:var(--bg-primary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm);align-self:flex-start}.relationship-target{font-weight:600;color:var(--text-primary);font-size:.9375rem}.relationship-description{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin:0}.relationship-delete-btn{background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);padding:0;line-height:1;flex-shrink:0}.relationship-delete-btn:hover{background:var(--error);color:#fff;border-color:var(--error);transform:rotate(90deg)}.entity-relationship-btn{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-base);font-size:.9375rem;box-shadow:var(--shadow-sm)}.entity-relationship-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.selected-entity{padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-weight:600}.entity-tags-section{margin-bottom:var(--space-lg)}.entity-tags-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm);font-size:.9375rem}.tags-input-container{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.tag-input{flex:1;padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:Inter,sans-serif;transition:all var(--transition-base)}.tag-input:focus{outline:none;border-color:var(--gold-primary);box-shadow:0 0 0 3px #d4af371a;background:var(--bg-card)}.tag-input::placeholder{color:var(--text-muted);opacity:.6}.tag-add-button{padding:var(--space-md) var(--space-lg);background:var(--gradient-gold);color:var(--bg-primary);border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-base);font-size:.9375rem;white-space:nowrap}.tag-add-button:hover{box-shadow:var(--shadow-md),var(--glow-gold);transform:translateY(-2px)}.tags-list{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.tag{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.375rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.tag:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.tag-remove{background:#fff3;border:none;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;cursor:pointer;transition:all var(--transition-base);padding:0;line-height:1}.tag-remove:hover{background:#fff6;transform:rotate(90deg)}.entity-tags-preview{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:var(--space-xs)}.tag-mini{display:inline-block;padding:.125rem .375rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;white-space:nowrap;box-shadow:0 1px 3px #0003}.tag-mini.tag-more{background:linear-gradient(135deg,#4a5568,#2d3748)}.entity-tags-display{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-lg)}.entity-tags-display h4{font-family:Cinzel,serif;font-size:1.125rem;color:var(--text-primary);margin:0 0 var(--space-md) 0}.template-selector-modal{max-width:900px!important;max-height:85vh;overflow-y:auto}.template-subtitle{color:var(--text-secondary);margin:var(--space-md) 0 var(--space-xl) 0;font-size:.9375rem;line-height:1.6}.template-category{margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--border-light)}.template-category:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.template-category h3{font-family:Cinzel,serif;font-size:1.25rem;color:var(--text-primary);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-md)}.template-card{padding:var(--space-lg);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.template-card:hover{border-color:var(--gold-primary);box-shadow:var(--shadow-md),var(--glow-gold);transform:translateY(-2px);background:var(--bg-elevated)}.template-name{font-family:Cinzel,serif;font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.template-description{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-md)}.template-tags{display:flex;flex-wrap:wrap;gap:.25rem}.entities-header-buttons{display:flex;gap:var(--space-sm);align-items:center}.action-button.secondary{background:var(--gradient-purple);color:var(--text-primary)}.action-button.secondary:hover{box-shadow:var(--shadow-md),0 0 20px #667eea66}.timeline-modal{max-width:800px!important;max-height:85vh;overflow-y:auto}.timeline-subtitle{color:var(--text-secondary);margin:var(--space-md) 0 var(--space-xl) 0;font-size:.9375rem;line-height:1.6}.timeline-filter{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap}.filter-button{padding:var(--space-sm) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif}.filter-button:hover{border-color:var(--gold-primary);color:var(--text-primary);background:var(--bg-card)}.filter-button.active{background:var(--gradient-gold);color:var(--bg-primary);border-color:var(--gold-primary);box-shadow:var(--shadow-sm),var(--glow-gold)}.timeline-events{position:relative}.timeline-empty{text-align:center;padding:var(--space-3xl);color:var(--text-muted);font-size:.9375rem;line-height:1.6}.timeline-event{display:flex;gap:var(--space-lg);margin-bottom:var(--space-xl);position:relative}.timeline-event:last-child{margin-bottom:0}.timeline-event-marker{display:flex;flex-direction:column;align-items:center;position:relative;flex-shrink:0}.timeline-dot{width:16px;height:16px;border-radius:50%;background:var(--gradient-gold);box-shadow:0 0 0 4px var(--bg-card),0 0 0 6px var(--border-medium),var(--glow-gold);z-index:2;flex-shrink:0}.timeline-line{width:2px;flex:1;background:linear-gradient(to bottom,var(--border-medium),transparent);margin-top:var(--space-xs);min-height:60px}.timeline-event-content{flex:1;padding:var(--space-lg);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.timeline-event-content:hover{border-color:var(--gold-primary);box-shadow:var(--shadow-md),var(--glow-gold);transform:translate(4px)}.timeline-event-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.timeline-event-icon{font-size:1.5rem;flex-shrink:0}.timeline-event-info{flex:1;min-width:0}.timeline-event-title{font-family:Cinzel,serif;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-xs) 0}.timeline-event-date{font-size:.8125rem;color:var(--text-muted);font-weight:500}.timeline-event-badge{padding:.25rem .75rem;background:var(--gradient-purple);color:#fff;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;text-transform:capitalize;white-space:nowrap;flex-shrink:0}.timeline-event-badge.entity{background:var(--gradient-gold);color:var(--bg-primary)}.timeline-event-badge.session{background:var(--gradient-emerald);color:var(--bg-primary)}.timeline-event-badge.note{background:var(--gradient-purple);color:#fff}.timeline-event-description{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-md)}.timeline-event-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:var(--space-sm)}.timeline-event-category,.timeline-event-duration{font-size:.8125rem;color:var(--text-muted);margin-top:var(--space-sm);font-weight:500}.entity-image-container{margin-bottom:var(--space-xs);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-medium);box-shadow:var(--shadow-sm);transition:all var(--transition-base);flex-shrink:0}.entity-image-container:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.entity-thumbnail{width:100%;aspect-ratio:1 / 1;object-fit:cover;display:block;transition:transform var(--transition-slow)}.entity-card:hover .entity-thumbnail{transform:scale(1.05)}.entity-placeholder{width:100%;aspect-ratio:1 / 1;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-card) 100%);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-muted);opacity:.5;transition:all var(--transition-base)}.entity-card:hover .entity-placeholder{opacity:.7;color:var(--gold-primary)}.entity-image-upload{margin-bottom:var(--space-lg)}.entity-image-upload label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.image-upload-area{border:2px dashed var(--border-medium);border-radius:var(--radius-md);padding:var(--space-xl);text-align:center;transition:all var(--transition-base);cursor:pointer}.image-upload-area:hover{border-color:var(--gold-primary);background:#f6d3650d}.image-upload-area input[type=file]{display:none}.image-preview{max-width:100%;max-height:300px;border-radius:var(--radius-md);margin-top:var(--space-md);box-shadow:var(--shadow-md)}.remove-image-button{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);color:var(--error);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);font-size:.875rem;transition:all var(--transition-base)}.remove-image-button:hover{background:var(--error);color:#fff;border-color:var(--error)}.entity-card .entity-actions{display:none}.entity-expanded-content .entity-actions{display:flex;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-medium)}.entity-edit-btn,.entity-delete-btn{flex:1;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-size:1rem;font-weight:600;transition:all var(--transition-base)}.entity-edit-btn{background:var(--bg-elevated);color:var(--gold-primary);border:1px solid var(--gold-primary)}.entity-edit-btn:hover{background:var(--gold-primary);color:var(--bg-primary);box-shadow:var(--glow-gold);transform:translateY(-2px)}.entity-delete-btn{background:var(--bg-elevated);color:var(--error);border:1px solid rgba(239,68,68,.3)}.entity-delete-btn:hover{background:var(--error);color:#fff;border-color:var(--error);box-shadow:0 0 20px #ef444466;transform:translateY(-2px)}.entity-merge-btn{flex:1;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-size:1rem;font-weight:600;transition:all var(--transition-base);background:var(--bg-elevated);color:#a855f7;border:1px solid rgba(168,85,247,.3)}.entity-merge-btn:hover{background:#a855f7;color:#fff;border-color:#a855f7;box-shadow:0 0 20px #a855f766;transform:translateY(-2px)}.merge-modal{max-width:600px;width:95%}.merge-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.merge-description strong{color:var(--gold-primary)}.merge-entities-display{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1.5rem}.merge-arrow{font-size:2rem;color:var(--text-muted)}.merge-entity-card{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--bg-elevated);border:2px solid var(--border-medium);border-radius:var(--radius-lg);min-width:150px;position:relative}.merge-entity-card.primary{border-color:#22c55e}.merge-entity-card.secondary{border-color:#ef4444}.merge-entity-card.empty{border-style:dashed;opacity:.7}.merge-entity-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#22c55e;color:#fff;padding:2px 12px;border-radius:10px;font-size:.75rem;font-weight:600}.merge-entity-badge.delete{background:#ef4444}.merge-entity-image{width:64px;height:64px;border-radius:50%;object-fit:cover;margin-bottom:.5rem}.merge-entity-placeholder{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--gold-primary),var(--gold-dark));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.5rem}.merge-entity-name{font-weight:600;color:var(--text-primary);text-align:center}.merge-entity-type{font-size:.8rem;color:var(--text-muted);text-transform:capitalize}.merge-change-btn{margin-top:.5rem;padding:4px 12px;background:var(--bg-hover);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8rem;cursor:pointer}.merge-change-btn:hover{border-color:var(--gold-primary);color:var(--gold-primary)}.merge-entity-selector label{display:block;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.merge-entity-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;max-height:250px;overflow-y:auto;padding:.5rem;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-medium)}.merge-entity-option{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.merge-entity-option:hover{border-color:var(--gold-primary);background:var(--bg-hover)}.merge-option-image{width:32px;height:32px;border-radius:50%;object-fit:cover}.merge-option-placeholder{width:32px;height:32px;border-radius:50%;background:var(--gold-primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;color:#fff}.merge-option-name{font-size:.85rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-merge-options{grid-column:1 / -1;text-align:center;color:var(--text-muted);padding:1rem}.merge-preview{background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.merge-preview h4{margin:0 0 .75rem;color:var(--text-primary);font-size:.9rem}.merge-preview ul{margin:0;padding-left:1.25rem}.merge-preview li{color:var(--text-secondary);font-size:.85rem;margin-bottom:.25rem}.merge-preview li:last-child{color:#f59e0b}.entity-card .entity-metadata{display:none}.entity-expanded-content .entity-metadata{display:flex;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-medium);font-size:1rem;color:var(--text-secondary)}.entity-metadata-item{display:flex;align-items:center;gap:var(--space-xs)}.mention-count{display:none}.entity-expanded-content .mention-count{display:block;font-size:.875rem;color:var(--text-muted);margin-top:var(--space-sm)}.entity-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-xs);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-right:var(--space-xs);margin-bottom:var(--space-xs)}.entity-badge.auto-extracted{border-color:var(--purple-primary);color:var(--purple-primary)}.entity-badge.manual{border-color:var(--emerald-primary);color:var(--emerald-primary)}.recording-section{margin-bottom:var(--space-2xl);padding:var(--space-xl);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);animation:fadeInUp .8s cubic-bezier(.16,1,.3,1)}.recording-controls{display:flex;gap:var(--space-md);align-items:center;justify-content:center;flex-wrap:wrap}.audio-storage-info{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-light);font-size:.85rem;color:var(--text-muted)}.audio-storage-info .storage-icon{font-size:1rem}.audio-storage-info .storage-text{flex:1}.audio-storage-info .clear-storage-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast)}.audio-storage-info .clear-storage-btn:hover{background:var(--error);border-color:var(--error);color:#fff}.recording-button{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);font-size:1.125rem;border-radius:var(--radius-md);transition:all var(--transition-base)}.recording-button.active{background:var(--gradient-crimson);animation:pulse 2s infinite}.recording-indicator{width:12px;height:12px;background:var(--error);border-radius:50%;box-shadow:0 0 10px var(--error);animation:pulse 1.5s infinite}.recording-progress-container{margin-top:var(--space-lg);padding:var(--space-lg);background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-medium)}.recording-progress-bar{width:100%;height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden;position:relative}.progress-fill{height:100%;background:var(--gradient-gold);border-radius:4px;transition:width var(--transition-base);box-shadow:var(--glow-gold);position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.recording-status{margin-top:var(--space-md);text-align:center;color:var(--text-secondary);font-size:.875rem}.chunk-indicator{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-weight:600;color:var(--gold-primary);margin-top:var(--space-md)}.transcription-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);background:var(--gradient-emerald);color:#fff;border-radius:var(--radius-xs);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--glow-emerald)}.audio-import-section{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-subtle)}.audio-import-section h3{margin:0 0 .25rem;color:var(--text-primary);font-size:1.1rem}.import-subtitle{color:var(--text-muted);font-size:.85rem;margin:0 0 1rem}.import-progress-container{margin-bottom:1rem}.import-progress-bar{background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-sm);height:36px;position:relative;overflow:hidden}.import-progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--gradient-gold);transition:width .3s ease}.import-progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:shimmer 1.5s infinite}.import-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-primary);font-size:.85rem;font-weight:500;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap}.import-chunks-info{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.chunks-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.chunks-dots{display:flex;gap:4px;flex-wrap:wrap;max-width:200px;justify-content:flex-end}.chunk-dot{width:10px;height:10px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border-medium);transition:all .3s ease}.chunk-dot.complete{background:var(--success);border-color:var(--success);box-shadow:0 0 6px #56ab2f66}.chunk-dot.active{background:var(--gold-primary);border-color:var(--gold-primary);animation:pulse-dot 1s infinite}@keyframes pulse-dot{0%,to{transform:scale(1);box-shadow:0 0 4px #f6d36566}50%{transform:scale(1.2);box-shadow:0 0 8px #f6d36599}}.drop-zone{border:2px dashed var(--border-medium);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-card)}.drop-zone:hover{border-color:var(--gold-primary);background:#f6d3650d}.drop-zone.drag-over{border-color:var(--gold-primary);background:#f6d3651a;transform:scale(1.01)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.drop-icon{font-size:3rem;opacity:.8}.drop-main{margin:0;font-size:1.1rem;color:var(--text-primary);font-weight:500}.drop-sub{margin:0;font-size:.9rem;color:var(--text-muted)}.drop-formats{margin:.5rem 0 0;font-size:.75rem;color:var(--text-muted);padding:.25rem .75rem;background:var(--bg-elevated);border-radius:var(--radius-xs)}.online-recording-guide{margin-top:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.online-recording-guide summary{padding:var(--space-md);cursor:pointer;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.online-recording-guide summary:hover{color:var(--text-primary);background:var(--bg-elevated)}.online-recording-guide[open] summary{border-bottom:1px solid var(--border-subtle)}.guide-content{padding:var(--space-lg)}.guide-content h4{margin:0 0 .75rem;color:var(--gold-primary);font-size:.95rem}.guide-content h4:not(:first-child){margin-top:1.5rem}.guide-content ol{margin:0 0 0 1.25rem;padding:0;color:var(--text-secondary);font-size:.9rem;line-height:1.7}.guide-content li{margin-bottom:.5rem}.guide-content code{background:var(--bg-elevated);padding:.15rem .4rem;border-radius:var(--radius-xs);font-family:Monaco,Consolas,monospace;font-size:.85em;color:var(--gold-light)}.guide-content a{color:var(--purple-light);text-decoration:none}.guide-content a:hover{text-decoration:underline}.guide-tip{margin-top:1.5rem;padding:var(--space-md);background:#f6d3651a;border:1px solid rgba(246,211,101,.3);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-secondary)}.guide-tip strong{color:var(--gold-primary)}@media(max-width:600px){.drop-zone{padding:var(--space-xl)}.drop-icon{font-size:2rem}.drop-main{font-size:1rem}.guide-content{padding:var(--space-md)}.guide-content ol{margin-left:1rem;font-size:.85rem}}.session-container,.notes-container{margin-bottom:var(--space-2xl)}.session-list,.notes-list{display:flex;flex-direction:column;gap:var(--space-lg)}.session-item,.note-item{background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);transition:all var(--transition-base);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1)}.session-item:hover,.note-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translate(4px)}.session-header,.note-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md)}.session-title,.note-title{font-family:Cinzel,serif;font-size:1.5rem;color:var(--text-primary);margin-bottom:var(--space-xs)}.session-date,.note-date{font-size:.875rem;color:var(--text-muted)}.session-content,.note-content{color:var(--text-secondary);line-height:1.8;margin-bottom:var(--space-md);white-space:pre-wrap}.session-actions,.note-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.entity-preview-section{margin-top:var(--space-2xl);padding:var(--space-xl);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid var(--gold-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),var(--glow-gold);animation:scaleIn .5s cubic-bezier(.16,1,.3,1)}.entity-preview-section h2{margin-bottom:var(--space-lg);color:var(--gold-primary)}.entity-preview-list{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.entity-preview-item{background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-base)}.entity-preview-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.entity-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.entity-preview-name{font-weight:700;color:var(--text-primary);font-size:1.125rem}.entity-preview-type{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-elevated);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-xs)}.entity-preview-description{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-md)}.remove-entity-button{padding:var(--space-xs) var(--space-md);background:var(--bg-elevated);color:var(--error);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);font-size:.875rem;transition:all var(--transition-base)}.remove-entity-button:hover{background:var(--error);color:#fff;border-color:var(--error)}.entity-preview-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.save-entities-button{flex:1;padding:var(--space-lg) var(--space-xl);background:var(--gradient-emerald);color:#fff;border-radius:var(--radius-md);font-size:1.125rem;font-weight:700;box-shadow:var(--shadow-md),var(--glow-emerald);transition:all var(--transition-base)}.save-entities-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--glow-emerald)}.discard-entities-button{padding:var(--space-lg) var(--space-xl);background:var(--bg-elevated);color:var(--error);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);font-size:1.125rem;transition:all var(--transition-base)}.discard-entities-button:hover{background:var(--error);color:#fff;border-color:var(--error)}.campaign-management{margin-bottom:var(--space-2xl);padding:var(--space-xl);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.campaign-list{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-lg)}.campaign-item{background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:var(--space-lg);display:flex;justify-content:space-between;align-items:center;transition:all var(--transition-base)}.campaign-item:hover{border-color:var(--gold-primary);box-shadow:var(--shadow-sm)}.campaign-item.active{border-color:var(--gold-primary);background:var(--bg-elevated);box-shadow:0 0 20px #f6d36533}.campaign-name{font-weight:700;color:var(--text-primary);font-size:1.125rem}.tools-content{margin-top:var(--space-xl)}.tools-content h2{text-align:center;margin-bottom:var(--space-2xl);font-family:Cinzel,serif;font-size:clamp(1.75rem,4vw,2.5rem)}.tools-category{margin-bottom:var(--space-2xl)}.tools-category-header{display:flex;align-items:center;gap:var(--space-sm);font-family:Cinzel,serif;font-size:1.25rem;color:var(--text-primary);margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-medium)}.tools-category-header .category-icon{font-size:1.5rem}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg)}.tools-grid-small{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));max-width:500px}@media(max-width:768px){.tools-grid{grid-template-columns:1fr}.tools-grid-small{grid-template-columns:1fr 1fr;max-width:100%}}.tool-card{background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);transition:all var(--transition-base);cursor:pointer;text-align:center;position:relative;overflow:hidden;animation:fadeInUp .6s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.tool-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--gradient-gold);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.tool-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg),var(--glow-gold);transform:translateY(-8px)}.tool-card:hover:before{transform:scaleX(1)}.tool-card:active{transform:translateY(-4px)}.tool-card.featured{border-color:var(--gold-dark);background:linear-gradient(135deg,#f6d3651a,#f6d36505)}.tool-card.featured:before{transform:scaleX(1)}.tool-card.compact{padding:var(--space-md)}.tool-card.compact .tool-icon{font-size:2.5rem;margin-bottom:var(--space-xs)}.tool-card.compact h3{font-size:1rem}.tool-card.compact p{font-size:.8rem;margin:0}.tool-icon{font-size:4rem;line-height:1;margin-bottom:var(--space-sm);filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));transition:all var(--transition-base)}.tool-card:hover .tool-icon{transform:scale(1.1);filter:drop-shadow(0 6px 12px rgba(246,211,101,.4))}.tool-card h3{font-family:Cinzel,serif;font-size:1.25rem;color:var(--text-primary);margin:0;margin-bottom:var(--space-xs)}.tool-card p{color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin:0}.floating-campaign-button{position:fixed;bottom:var(--space-xl);right:var(--space-xl);width:64px;height:64px;border-radius:50%;background:var(--gradient-purple);color:#fff;font-size:2rem;border:none;box-shadow:var(--shadow-lg),var(--glow-purple);cursor:pointer;transition:all var(--transition-base);z-index:100;display:flex;align-items:center;justify-content:center}.floating-campaign-button:hover{transform:scale(1.1) rotate(5deg);box-shadow:var(--shadow-xl),var(--glow-purple)}.floating-campaign-button:active{transform:scale(1.05) rotate(5deg)}@media(max-width:768px){.floating-campaign-button{bottom:var(--space-lg);right:var(--space-lg);width:56px;height:56px;font-size:1.75rem}}.npc-generator{margin-bottom:var(--space-2xl);padding:var(--space-xl);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.npc-generator-form{display:flex;flex-direction:column;gap:var(--space-lg);margin-top:var(--space-lg)}.npc-result{margin-top:var(--space-xl);padding:var(--space-xl);background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-md);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1)}.session-prep{margin-bottom:var(--space-2xl);padding:var(--space-xl);background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.prep-checklist{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-lg)}.prep-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-md);transition:all var(--transition-base)}.prep-item:hover{border-color:var(--border-strong)}.prep-checkbox{width:24px;height:24px;border-radius:var(--radius-xs);cursor:pointer}.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-xl);margin-top:var(--space-2xl)}.dashboard-card{background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);transition:all var(--transition-base);animation:fadeInUp .6s cubic-bezier(.16,1,.3,1)}.dashboard-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.dashboard-stat{font-size:3rem;font-weight:700;background:var(--gradient-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:var(--space-sm)}.dashboard-label{color:var(--text-muted);font-size:.875rem;text-transform:uppercase;letter-spacing:.1em}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--bg-elevated);border-top-color:var(--gold-primary);border-radius:50%;animation:spin 1s linear infinite}.status-message{padding:var(--space-lg);background:var(--bg-card);border-left:4px solid var(--gold-primary);border-radius:var(--radius-md);color:var(--text-secondary);margin-bottom:var(--space-lg)}.status-message.error{border-left-color:var(--error);background:#ef44441a;color:var(--error)}.status-message.success{border-left-color:var(--success);background:#56ab2f1a;color:var(--emerald-light)}.status-message.warning{border-left-color:var(--warning);background:#f59e0b1a;color:var(--warning)}*:focus-visible{outline:3px solid var(--gold-primary);outline-offset:2px;border-radius:var(--radius-xs)}button:focus-visible,a:focus-visible{outline:3px solid var(--gold-primary);outline-offset:3px}.skip-to-content{position:absolute;top:-100px;left:0;background:var(--gold-primary);color:var(--bg-primary);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-weight:700;z-index:9999;transition:top var(--transition-base)}.skip-to-content:focus{top:var(--space-md)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(max-width:1200px){.entity-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.dashboard{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media(max-width:768px){:root{--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 2.5rem}.app{padding:var(--space-md)}.app-header{padding:var(--space-xl) var(--space-lg)}h1{font-size:2rem}h2{font-size:1.5rem}.tabs{overflow-x:auto}.entity-grid{grid-template-columns:1fr;gap:var(--space-md)}.modal-content{padding:var(--space-lg)}.recording-controls,.entity-actions,.entity-preview-actions{flex-direction:column}.campaign-selector{flex-direction:column;align-items:stretch}.campaign-selector select{max-width:100%}}@media(max-width:480px){.app{padding:var(--space-sm)}.app-header{padding:var(--space-lg) var(--space-md)}.card,.entity-card,.session-item,.note-item{padding:var(--space-md)}.dashboard-stat{font-size:2.5rem}}@media print{body{background:#fff;color:#000}.app-header,.tabs,button,.recording-controls,.entity-actions{display:none}.entity-card,.session-item,.note-item{border:1px solid #ddd;break-inside:avoid}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:var(--space-xs)}.mt-2{margin-top:var(--space-sm)}.mt-3{margin-top:var(--space-md)}.mt-4{margin-top:var(--space-lg)}.mt-5{margin-top:var(--space-xl)}.mb-1{margin-bottom:var(--space-xs)}.mb-2{margin-bottom:var(--space-sm)}.mb-3{margin-bottom:var(--space-md)}.mb-4{margin-bottom:var(--space-lg)}.mb-5{margin-bottom:var(--space-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-xs)}.gap-2{gap:var(--space-sm)}.gap-3{gap:var(--space-md)}.gap-4{gap:var(--space-lg)}.w-full{width:100%}.h-full{height:100%}.dice-roller-modal{max-width:600px;max-height:90vh;overflow-y:auto}.dice-quick-rolls,.dice-advantage,.custom-dice-roll{margin-bottom:1.5rem}.quick-roll-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.75rem;margin-top:.75rem}.dice-button{padding:1rem;background:#8b45134d;border:2px solid var(--accent-color);border-radius:8px;color:var(--text-color);font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease}.dice-button:hover{background:#8b451380;transform:translateY(-2px);box-shadow:0 4px 12px #daa5204d}.advantage-buttons{display:flex;gap:1rem;margin-top:.75rem}.advantage-button,.disadvantage-button{flex:1;padding:.875rem;border:2px solid;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.advantage-button{background:#00800033;border-color:#4ade80;color:#4ade80}.advantage-button:hover{background:#00800066}.disadvantage-button{background:#f003;border-color:#f87171;color:#f87171}.disadvantage-button:hover{background:#f006}.custom-dice-inputs{display:flex;align-items:center;gap:.5rem;margin-top:.75rem}.dice-input{width:80px;padding:.5rem;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);text-align:center}.roll-custom-button{padding:.5rem 1.5rem;background:var(--accent-color);border:none;border-radius:6px;color:var(--bg-color);font-weight:600;cursor:pointer;transition:all .3s ease}.roll-custom-button:hover{background:#f0d86b;transform:translateY(-1px)}.dice-history{margin-top:1.5rem;max-height:300px;overflow-y:auto}.roll-history-list{display:flex;flex-direction:column;gap:.75rem}.roll-result{padding:.875rem;background:#0000004d;border:1px solid var(--border-color);border-radius:8px}.roll-notation{font-weight:600;color:var(--accent-color);margin-bottom:.5rem}.roll-details{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.advantage-tag,.disadvantage-tag{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700}.advantage-tag{background:#0080004d;color:#4ade80}.disadvantage-tag{background:#ff00004d;color:#f87171}.roll-breakdown{color:var(--text-secondary)}.roll-total{font-size:1.5rem;font-weight:700;color:var(--text-color);margin-left:auto}.roll-timestamp{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem}.combat-tracker-modal{max-width:900px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column}.combat-tracker-modal h2{margin:0 0 .75rem;font-size:1.3rem}.combat-status{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.5rem .75rem;background:#8b45134d;border-radius:6px}.combat-status h3{margin:0;font-size:1rem}.combat-controls{display:flex;gap:.5rem}.next-turn-button,.reset-combat-button{padding:.375rem .75rem;border:1px solid;border-radius:4px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease}.next-turn-button{background:#00800033;border-color:#4ade80;color:#4ade80}.next-turn-button:hover{background:#00800066}.reset-combat-button{background:#f003;border-color:#f87171;color:#f87171}.reset-combat-button:hover{background:#f006}.add-combatant{margin-bottom:.75rem}.add-combatant h3{margin:0 0 .5rem;font-size:.9rem}.combatant-inputs{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:.5rem;align-items:center}.combatant-input{padding:.375rem .5rem;background:#0000004d;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:.9rem}.combatant-input-small{padding:.375rem .5rem;background:#0000004d;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);text-align:center;font-size:.9rem}.add-combatant-button{padding:.375rem 1rem;background:var(--accent-color);border:none;border-radius:4px;color:var(--bg-color);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-combatant-button:hover{background:#f0d86b}.combatants-list{flex:1;overflow-y:auto;min-height:0}.combatants-list h3{margin:0 0 .5rem;font-size:.9rem;position:sticky;top:0;background:var(--bg-color);padding:.25rem 0;z-index:1}.combatant-card{padding:.5rem .75rem;background:#0000004d;border:1px solid var(--border-color);border-radius:4px;margin-bottom:.5rem;transition:all .2s ease}.combatant-card.active-turn{border-color:var(--accent-color);background:#8b45134d;box-shadow:0 0 12px #daa52040}.combatant-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.combatant-header h4{margin:0;color:var(--text-color);font-size:.95rem}.remove-btn{background:#ff00004d;border:1px solid #f87171;border-radius:3px;color:#f87171;font-size:1.1rem;width:24px;height:24px;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.remove-btn:hover{background:#ff000080}.combatant-stats{display:flex;gap:1rem;margin-bottom:.375rem}.stat{display:flex;align-items:baseline;gap:.375rem}.stat-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase}.stat-value{font-size:.9rem;font-weight:600;color:var(--text-color)}.hp-stat .stat-value{color:var(--accent-color)}.hp-controls{display:flex;gap:.375rem}.hp-button{flex:1;padding:.25rem .375rem;background:#0000004d;border:1px solid var(--border-color);border-radius:3px;color:var(--text-color);font-weight:600;font-size:.8rem;cursor:pointer;transition:all .2s ease}.hp-button:hover{background:#8b45134d;border-color:var(--accent-color)}.hp-button.damage{color:#f87171}.hp-button.damage:hover{background:#ef444433;border-color:#f87171}.hp-button.heal{color:#4ade80}.hp-button.heal:hover{background:#4ade8033;border-color:#4ade80}.custom-damage-input{display:flex;align-items:center;gap:.25rem}.damage-input{width:40px;padding:.25rem;background:#0000004d;border:1px solid var(--border-color);border-radius:3px;color:var(--text-primary);text-align:center;font-size:.8rem}.damage-input:focus{outline:none;border-color:var(--gold-primary)}.monster-search-button{padding:.4rem .75rem;background:#8b5cf633;border:1px solid var(--purple-primary);border-radius:4px;color:var(--purple-primary);cursor:pointer;transition:all .2s ease}.monster-search-button:hover{background:var(--purple-primary);color:#fff}.monster-search-panel{margin-top:.75rem;padding:.75rem;background:var(--bg-elevated);border-radius:8px;border:1px solid var(--border-color)}.monster-search-input{width:100%;padding:.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);margin-bottom:.5rem}.monster-search-results{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.monster-result-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s ease;text-align:left}.monster-result-item:hover{background:var(--bg-glass-light);border-color:var(--gold-primary)}.monster-name{font-weight:500;color:var(--text-primary)}.monster-stats{font-size:.75rem;color:var(--text-muted)}.no-monsters{color:var(--text-muted);font-style:italic;text-align:center;padding:.5rem}.combat-log{margin-top:1rem;padding:.75rem;background:var(--bg-card);border-radius:8px;border:1px solid var(--border-color);max-height:200px;overflow-y:auto}.combat-log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.combat-log-header h4{margin:0;font-size:.9rem;color:var(--text-primary)}.clear-log-btn{padding:.2rem .5rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-muted);font-size:.7rem;cursor:pointer}.clear-log-btn:hover{border-color:var(--text-muted)}.combat-log-entries{display:flex;flex-direction:column;gap:.25rem}.log-entry{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background:var(--bg-elevated);border-radius:4px;font-size:.8rem}.log-entry.damage{background:#ef44441a;border-left:2px solid #f87171}.log-entry.healing{background:#4ade801a;border-left:2px solid #4ade80}.log-entry.death{background:#ef444433;border-left:2px solid #ef4444}.log-entry.status{background:#8b5cf61a;border-left:2px solid var(--purple-primary)}.log-round{padding:.1rem .3rem;background:var(--bg-card);border-radius:3px;font-size:.7rem;font-weight:600;color:var(--text-muted)}.log-message{flex:1;color:var(--text-secondary)}.log-time{font-size:.7rem;color:var(--text-muted)}.defeated-marker{margin-top:.375rem;padding:.25rem;background:#ff00004d;border:1px solid #f87171;border-radius:3px;text-align:center;color:#f87171;font-weight:700;font-size:.75rem}.combatant-inputs{grid-template-columns:2fr 1fr 1fr 1fr auto auto}.import-combatant-button{padding:.375rem .75rem;background:#3b82f64d;border:1px solid #60a5fa;border-radius:4px;color:#60a5fa;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.import-combatant-button:hover{background:#3b82f680}.import-menu{margin-top:.75rem;padding:.75rem;background:#0006;border:1px solid var(--border-color);border-radius:6px;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.import-section h4{margin:0 0 .5rem;font-size:.85rem;color:var(--accent-color)}.import-item{display:block;width:100%;padding:.375rem .5rem;margin-bottom:.375rem;background:#8b451333;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:.85rem;text-align:left;cursor:pointer;transition:all .2s ease}.import-item:hover{background:#8b451366;border-color:var(--accent-color)}.empty-import{font-size:.8rem;color:var(--text-secondary);font-style:italic}.player-combatant{border-left:3px solid #60a5fa}.player-badge{display:inline-block;margin-left:.5rem;padding:.125rem .375rem;background:#3b82f64d;border:1px solid #60a5fa;border-radius:3px;color:#60a5fa;font-size:.65rem;font-weight:700}.status-effects-list{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.status-effect-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#a855f74d;border:1px solid #a78bfa;border-radius:3px;color:#a78bfa;font-size:.75rem;font-weight:600}.remove-effect-btn{background:none;border:none;color:#f87171;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;margin-left:.125rem;line-height:1}.remove-effect-btn:hover{color:#fca5a5}.concentration-indicator{display:inline-flex;align-items:center;padding:.125rem .375rem;background:#8b5cf64d;border:1px solid #a78bfa;border-radius:3px;color:#a78bfa;font-size:.7rem;font-weight:600}.combatant-actions{display:flex;gap:.375rem;margin-top:.5rem}.action-btn{flex:1;padding:.25rem .5rem;background:#8b451333;border:1px solid var(--border-color);border-radius:3px;color:var(--text-color);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#8b451366;border-color:var(--accent-color)}.action-btn.active{background:#8b5cf64d;border-color:#a78bfa;color:#a78bfa}.death-saves{margin-top:.75rem;padding:.5rem;background:#0006;border:1px solid #f87171;border-radius:4px}.death-saves h5{margin:0 0 .5rem;font-size:.85rem;color:#f87171}.death-save-tracker{display:flex;flex-direction:column;gap:.375rem}.save-type{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.save-type span{min-width:60px}.save-boxes{display:flex;gap:.25rem}.save-box{width:24px;height:24px;background:#0000004d;border:1px solid var(--border-color);border-radius:3px;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.save-box.filled{border-color:#4ade80;color:#4ade80;background:#00800033}.save-box.failure.filled{border-color:#f87171;color:#f87171;background:#f003}.save-box:hover{background:#8b45134d}.reset-saves-btn{margin-top:.25rem;padding:.25rem .5rem;background:#0000004d;border:1px solid var(--border-color);border-radius:3px;color:var(--text-color);font-size:.7rem;cursor:pointer;transition:all .2s ease}.reset-saves-btn:hover{background:#8b45134d;border-color:var(--accent-color)}.save-result{margin-top:.5rem;padding:.25rem;text-align:center;font-weight:700;font-size:.75rem;border-radius:3px}.save-result.success{background:#0080004d;border:1px solid #4ade80;color:#4ade80}.save-result.failure{background:#ff00004d;border:1px solid #f87171;color:#f87171}.status-effect-modal{max-width:400px}.status-effect-modal h3{margin:0 0 1rem;color:var(--accent-color)}.status-input{width:100%;padding:.5rem;margin-bottom:.75rem;background:#0000004d;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:.9rem}.common-effects{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.common-effects button{padding:.5rem;background:#8b451333;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:.85rem;cursor:pointer;transition:all .2s ease}.common-effects button:hover{background:#8b451366;border-color:var(--accent-color)}.modal-actions{display:flex;gap:.5rem}.confirm-btn,.cancel-btn{flex:1;padding:.5rem;border:none;border-radius:4px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.confirm-btn{background:var(--accent-color);color:var(--bg-color)}.confirm-btn:hover{background:#f0d86b}.cancel-btn{background:#ff00004d;border:1px solid #f87171;color:#f87171}.cancel-btn:hover{background:#ff000080}.random-generator-modal{max-width:500px}.generator-type-selector{margin-bottom:1.5rem}.generator-type-selector label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:600}.generator-select,.option-select,.option-input{width:100%;padding:.75rem;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:1rem}.generator-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.option-group{display:flex;flex-direction:column;gap:.5rem}.option-group label{color:var(--text-secondary);font-weight:600}.generate-button{width:100%;padding:.875rem;background:var(--accent-color);border:none;border-radius:8px;color:var(--bg-color);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.generate-button:hover{background:#f0d86b;transform:translateY(-2px);box-shadow:0 4px 12px #daa5204d}.generated-result{margin-top:1.5rem;padding:1.5rem;background:#8b45134d;border:2px solid var(--accent-color);border-radius:8px}.generated-result h3{margin:0 0 .75rem;color:var(--accent-color)}.result-text{font-size:1.2rem;color:var(--text-color);line-height:1.6}.encounter-generator-modal{max-width:700px;max-height:90vh;overflow-y:auto}.encounter-params{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.param-group{display:flex;flex-direction:column;gap:.5rem}.param-group label{color:var(--text-secondary);font-weight:600}.param-input,.param-select{padding:.75rem;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:1rem}.generate-encounter-button{width:100%;padding:.875rem;background:var(--accent-color);border:none;border-radius:8px;color:var(--bg-color);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.generate-encounter-button:hover{background:#f0d86b;transform:translateY(-2px);box-shadow:0 4px 12px #daa5204d}.encounter-result{margin-top:1.5rem}.encounter-summary{padding:1.5rem;background:#8b45134d;border:2px solid var(--accent-color);border-radius:8px;margin-bottom:1.5rem}.encounter-summary h3{margin:0 0 1rem;color:var(--accent-color)}.encounter-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.encounter-stat{display:flex;flex-direction:column;gap:.25rem}.encounter-stat .stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.encounter-stat .stat-value{font-size:1.2rem;font-weight:600;color:var(--text-color)}.encounter-monsters h3{margin-bottom:1rem;color:var(--accent-color)}.monster-card{padding:1rem;background:#0000004d;border:2px solid var(--border-color);border-radius:8px;margin-bottom:.75rem}.monster-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.monster-header h4{margin:0;color:var(--text-color)}.monster-type{padding:.25rem .75rem;background:#8b451366;border:1px solid var(--accent-color);border-radius:4px;font-size:.85rem;color:var(--accent-color)}.monster-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.monster-stat{padding:.375rem .75rem;background:#0006;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;color:var(--text-color)}.dungeon-generator-modal{max-width:95vw;max-height:90vh;overflow-y:auto}.dungeon-params{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.dungeon-theme-section{margin-bottom:1.5rem;padding:1rem;background:#daa5200d;border:1px solid rgba(218,165,32,.2);border-radius:8px}.theme-toggle{display:flex;flex-direction:column;gap:.25rem}.toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:600;color:var(--accent-color)}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-color);cursor:pointer}.toggle-text{font-size:1rem}.theme-hint{font-size:.85rem;color:var(--text-secondary);margin-left:26px}.theme-input-container{margin-top:1rem}.theme-input-container label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-color)}.theme-textarea{width:100%;padding:.75rem;background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:.95rem;resize:vertical;min-height:80px;font-family:inherit}.theme-textarea::placeholder{color:var(--text-secondary);opacity:.7}.theme-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #daa52033}.theme-examples{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.examples-label{font-size:.85rem;color:var(--text-secondary)}.example-btn{padding:.35rem .75rem;background:#daa5201a;border:1px solid rgba(218,165,32,.3);border-radius:16px;color:var(--accent-color);font-size:.8rem;cursor:pointer;transition:all .2s ease}.example-btn:hover{background:#daa52033;border-color:var(--accent-color)}.generation-error{margin-bottom:1rem;padding:.75rem;background:#dc35451a;border:1px solid rgba(220,53,69,.3);border-radius:6px;color:#dc3545;font-size:.9rem}.generate-dungeon-button{width:100%;padding:.875rem;background:var(--accent-color);border:none;border-radius:8px;color:var(--bg-color);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.generate-dungeon-button:hover:not(:disabled){background:#f0d86b;transform:translateY(-2px);box-shadow:0 4px 12px #daa5204d}.generate-dungeon-button:disabled{opacity:.6;cursor:not-allowed}.dungeon-result{margin-top:1.5rem;display:grid;grid-template-columns:300px 1fr;gap:1.5rem}@media(max-width:1024px){.dungeon-result{grid-template-columns:1fr}}.dungeon-map{position:sticky;top:1rem;align-self:start}.dungeon-map h3{margin:0 0 1rem;color:var(--accent-color)}.dungeon-map-canvas-container{margin-bottom:1rem;max-height:600px;overflow:auto;background:#1a1410;border:2px solid var(--border-color);border-radius:8px;padding:.5rem}.dungeon-map-canvas{width:100%;height:auto;max-width:100%;display:block;margin-bottom:.75rem;image-rendering:crisp-edges}.download-map-button{width:100%;padding:.5rem;background:var(--accent-color);border:none;border-radius:6px;color:var(--bg-color);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.download-map-button:hover{background:#f0d86b;transform:translateY(-1px)}.map-grid{display:grid;gap:.5rem;padding:1rem;background:#0000004d;border:2px solid var(--border-color);border-radius:8px;margin-bottom:1rem}.map-room{width:60px;height:60px;background:#8b45134d;border:2px solid var(--border-color);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;transition:all .3s ease;cursor:pointer}.map-room:hover{transform:scale(1.1);border-color:var(--accent-color);box-shadow:0 0 12px #daa5204d}.map-room.combat{border-color:#f87171;background:#f003}.map-room.puzzle{border-color:#a78bfa;background:#a78bfa33}.map-room.exploration{border-color:#4ade80;background:#4ade8033}.map-room.treasure{border-color:#fbbf24;background:#fbbf2433}.room-number{font-size:.75rem;font-weight:700;color:var(--text-color)}.room-icon{font-size:1.25rem}.map-legend{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.legend-icon{font-size:1rem}.dungeon-rooms h3{margin:0 0 1rem;color:var(--accent-color)}.room-card{padding:1rem;background:#0000004d;border:2px solid var(--border-color);border-radius:8px;margin-bottom:1rem}.room-card.combat{border-left:4px solid #f87171}.room-card.puzzle{border-left:4px solid #a78bfa}.room-card.exploration{border-left:4px solid #4ade80}.room-card.treasure{border-left:4px solid #fbbf24}.room-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.room-header h4{margin:0;color:var(--text-color);font-size:1.1rem}.room-type-icon{font-size:1.5rem}.room-description{color:var(--text-secondary);line-height:1.6;margin-bottom:.75rem}.room-encounter{padding:.75rem;background:#8b451333;border:1px solid var(--border-color);border-radius:6px;margin-top:.75rem}.room-encounter strong{color:var(--accent-color);display:block;margin-bottom:.5rem}.room-encounter p{margin:.5rem 0;color:var(--text-color)}.room-encounter em{color:var(--text-secondary)}.encounter-monsters-compact{display:flex;flex-direction:column;gap:.375rem;margin-top:.5rem}.monster-compact{padding:.375rem .5rem;background:#0000004d;border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:.9rem}.trap-warning{color:#f87171;font-weight:600;padding:.5rem;background:#ff00001a;border:1px solid #f87171;border-radius:4px;margin-bottom:.5rem}.schedule-content{display:flex;flex-direction:column;gap:2rem}.schedule-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.schedule-header h2{margin:0;color:var(--gold-color)}.schedule-actions{display:flex;gap:.75rem;flex-wrap:wrap}.action-button.secondary{background:#8b5cf633;border-color:var(--purple-accent)}.action-button.secondary:hover{background:#8b5cf666}.schedule-calendar{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-header h3{margin:0;color:var(--text-color);font-size:1.25rem}.calendar-nav-button{background:#d4af3733;border:1px solid var(--gold-color);color:var(--gold-color);width:36px;height:36px;border-radius:8px;cursor:pointer;font-size:1.1rem;transition:all .2s ease}.calendar-nav-button:hover{background:#d4af3766}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day-header{text-align:center;padding:.5rem;color:var(--gold-color);font-weight:600;font-size:.85rem}.calendar-day{min-height:80px;background:#0003;border-radius:6px;padding:.5rem;position:relative;border:1px solid transparent;transition:all .2s ease}.calendar-day:hover{border-color:var(--border-color)}.calendar-day.empty{background:transparent}.calendar-day.today{border-color:var(--gold-color);background:#d4af371a}.calendar-day.past{opacity:.6}.calendar-day.has-session{background:#8b5cf61a}.day-number{font-size:.9rem;color:var(--text-muted);font-weight:500}.calendar-day.today .day-number{color:var(--gold-color);font-weight:700}.calendar-session-indicator{font-size:.7rem;padding:2px 6px;border-radius:4px;margin-top:4px;cursor:pointer;transition:transform .2s ease;text-align:center}.calendar-session-indicator:hover{transform:scale(1.05)}.calendar-session-indicator.proposed{background:#8b5cf666;color:#c4b5fd}.calendar-session-indicator.confirmed{background:#10b98166;color:#6ee7b7}.calendar-session-indicator.cancelled{background:#ef444466;color:#fca5a5;text-decoration:line-through}.calendar-session-indicator.completed{background:#3b82f666;color:#93c5fd}.upcoming-sessions-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.upcoming-sessions-section h3{margin:0 0 1rem;color:var(--gold-color)}.no-sessions-message{color:var(--text-muted);font-style:italic;text-align:center;padding:2rem}.scheduled-sessions-list{display:flex;flex-direction:column;gap:1rem}.scheduled-session-card{background:#0000004d;border-radius:10px;padding:1rem;border:1px solid var(--border-color);transition:all .2s ease}.scheduled-session-card:hover{border-color:var(--gold-color)}.scheduled-session-card.proposed{border-left:4px solid var(--purple-accent)}.scheduled-session-card.confirmed{border-left:4px solid var(--emerald-accent)}.scheduled-session-card.cancelled{border-left:4px solid #ef4444;opacity:.6}.session-card-header{display:flex;gap:1rem;align-items:flex-start}.session-card-date{display:flex;flex-direction:column;align-items:center;background:#d4af3726;padding:.75rem;border-radius:8px;min-width:70px}.session-card-date .date-day{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.session-card-date .date-full{font-size:1rem;font-weight:700;color:var(--gold-color)}.session-card-date .date-time{font-size:.85rem;color:var(--text-muted);margin-top:4px}.session-card-info{flex:1}.session-card-info h4{margin:0 0 .5rem;color:var(--text-color);font-size:1.1rem}.session-meta{display:flex;gap:1rem;color:var(--text-muted);font-size:.85rem}.session-status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.session-status-badge.proposed{background:#8b5cf64d;color:#c4b5fd}.session-status-badge.confirmed{background:#10b9814d;color:#6ee7b7}.session-status-badge.cancelled{background:#ef44444d;color:#fca5a5}.session-status-badge.completed{background:#3b82f64d;color:#93c5fd}.session-card-notes{margin:1rem 0 0;color:var(--text-muted);font-size:.9rem;padding-left:calc(70px + 1rem);font-style:italic}.availability-summary{display:flex;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.availability-label{color:var(--text-muted);font-size:.85rem}.no-responses{color:var(--text-muted);font-style:italic;font-size:.85rem}.availability-counts{display:flex;gap:1rem}.availability-counts span{font-size:.9rem;font-weight:600}.availability-counts .available{color:#6ee7b7}.availability-counts .maybe{color:#fcd34d}.availability-counts .unavailable{color:#fca5a5}.player-responses{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.player-response{font-size:.8rem;padding:.25rem .5rem;border-radius:4px;background:#0000004d}.player-response.available{color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}.player-response.maybe{color:#fcd34d;border:1px solid rgba(252,211,77,.3)}.player-response.unavailable{color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.mark-availability{display:flex;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);flex-wrap:wrap}.mark-availability>span{color:var(--text-muted);font-size:.9rem}.availability-buttons{display:flex;gap:.5rem}.avail-btn{padding:.4rem .75rem;border-radius:6px;border:1px solid;cursor:pointer;font-size:.85rem;transition:all .2s ease;background:transparent}.avail-btn.available{border-color:#10b98180;color:#6ee7b7}.avail-btn.available:hover,.avail-btn.available.selected{background:#10b9814d}.avail-btn.maybe{border-color:#fcd34d80;color:#fcd34d}.avail-btn.maybe:hover,.avail-btn.maybe.selected{background:#fcd34d4d}.avail-btn.unavailable{border-color:#ef444480;color:#fca5a5}.avail-btn.unavailable:hover,.avail-btn.unavailable.selected{background:#ef44444d}.session-card-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);align-items:center}.status-select{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.4rem .75rem;color:var(--text-color);font-size:.85rem;cursor:pointer}.edit-btn,.delete-btn{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border-color);background:transparent;cursor:pointer;font-size:.9rem;transition:all .2s ease}.edit-btn:hover{background:#8b5cf64d;border-color:var(--purple-accent)}.delete-btn:hover{background:#ef44444d;border-color:#ef4444}.export-btn{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border-color);background:transparent;cursor:pointer;font-size:.9rem;transition:all .2s ease}.export-btn:hover{background:#3b82f64d;border-color:#3b82f6}.session-history-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.session-history-section h3{margin:0 0 1.5rem;color:var(--gold-color)}.session-history-timeline{position:relative;padding-left:40px}.session-history-timeline:before{content:"";position:absolute;left:15px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold-color),var(--purple-accent))}.timeline-item{position:relative;padding-bottom:1.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-40px;width:30px;height:30px;background:var(--gold-color);border-radius:50%;display:flex;align-items:center;justify-content:center}.timeline-marker .session-number{font-size:.7rem;font-weight:700;color:#1a1410}.timeline-content{background:#0000004d;border-radius:8px;padding:1rem;border:1px solid var(--border-color)}.timeline-date{color:var(--text-color);font-weight:600;margin-bottom:.5rem}.timeline-meta{display:flex;gap:1rem;color:var(--text-muted);font-size:.85rem;margin-bottom:.75rem}.view-session-btn{background:#d4af3733;border:1px solid var(--gold-color);color:var(--gold-color);padding:.4rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.view-session-btn:hover{background:#d4af3766}.schedule-modal{max-width:500px}.schedule-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-muted);font-size:.85rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.75rem;color:var(--text-color);font-size:.95rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--gold-color)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.recurrence-section{background:#8b45131a;border:1px solid rgba(139,69,19,.3);border-radius:8px;padding:1rem}.recurrence-section .form-row{align-items:center}.recurrence-section select{flex:1}.recurrence-count{display:flex;align-items:center;gap:.5rem}.recurrence-count label{white-space:nowrap;font-size:.85rem}.recurrence-count select{width:auto}.recurrence-preview{margin-top:.75rem;padding:.5rem .75rem;background:#d4af371a;border-radius:4px;color:var(--gold-color)}.recurrence-preview small{display:block;line-height:1.4}.share-modal{max-width:500px}.share-instructions{color:var(--text-muted);margin-bottom:1.5rem;line-height:1.5}.share-code-container{display:flex;flex-direction:column;gap:.75rem}.share-code-box{background:#00000080;border:1px solid var(--border-color);border-radius:6px;padding:1rem;color:var(--text-color);font-family:monospace;font-size:.85rem;resize:none;word-break:break-all}.share-code-box:focus{outline:none;border-color:var(--gold-color)}.copy-btn{align-self:flex-end}.share-note{margin-top:1.5rem;padding:1rem;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:6px;color:var(--text-muted);font-size:.9rem}.share-note strong{color:var(--gold-color)}@media(max-width:768px){.calendar-day{min-height:60px;padding:.25rem}.calendar-day-header{font-size:.75rem;padding:.25rem}.day-number{font-size:.8rem}.calendar-session-indicator{font-size:.6rem;padding:1px 3px}.session-card-header{flex-wrap:wrap}.form-row{grid-template-columns:1fr}.schedule-header{flex-direction:column;align-items:stretch}.schedule-actions{justify-content:stretch}.schedule-actions button{flex:1}}.quests-content{display:flex;flex-direction:column;gap:1.5rem}.quests-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.quests-header h2{margin:0;color:var(--gold-color)}.quests-controls{display:flex;gap:.75rem;align-items:center}.quest-filter-select{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem 1rem;color:var(--text-color);cursor:pointer}.no-quests-message{text-align:center;padding:3rem;color:var(--text-muted)}.quests-list{display:flex;flex-direction:column;gap:1rem}.quest-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color);transition:all .2s ease}.quest-card:hover{border-color:var(--gold-color)}.quest-card.main{border-left:4px solid var(--gold-color)}.quest-card.side{border-left:4px solid var(--purple-accent)}.quest-card.personal{border-left:4px solid var(--emerald-accent)}.quest-card[data-dm-only=true]{background:#8b5cf61a}.quest-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.quest-card-header h3{margin:0;flex:1;color:var(--text-color)}.quest-priority-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;font-weight:600;background:#d4af3733;color:var(--gold-color)}.quest-card.side .quest-priority-badge{background:#8b5cf633;color:var(--purple-accent)}.quest-card.personal .quest-priority-badge{background:#10b98133;color:var(--emerald-accent)}.quest-status-badge{font-size:.75rem;padding:.25rem .6rem;border-radius:12px;font-weight:500;text-transform:capitalize}.quest-status-badge.active{background:#3b82f64d;color:#93c5fd}.quest-status-badge.completed{background:#10b9814d;color:#6ee7b7}.quest-status-badge.failed{background:#ef44444d;color:#fca5a5}.quest-description{color:var(--text-muted);margin:0 0 1rem;line-height:1.5}.quest-meta{display:flex;gap:1.5rem;color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.quest-objectives{background:#0003;border-radius:8px;padding:1rem;margin-bottom:1rem}.quest-objectives h4{margin:0 0 .5rem;color:var(--gold-color);font-size:.9rem}.quest-objectives ul{list-style:none;padding:0;margin:0}.quest-objectives li{padding:.4rem 0;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:opacity .2s}.quest-objectives li.completed{text-decoration:line-through;opacity:.6}.objective-checkbox{font-size:1.1rem}.quest-rewards{color:var(--gold-color);font-size:.9rem;margin-bottom:.75rem}.quest-dm-notes{background:#8b5cf61a;padding:.75rem;border-radius:6px;font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem;border-left:3px solid var(--purple-accent)}.quest-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid var(--border-color);align-items:center}.quest-modal{max-width:550px}.quest-form{display:flex;flex-direction:column;gap:1rem}.objectives-list{display:flex;flex-direction:column;gap:.5rem}.objective-input{display:flex;gap:.5rem}.objective-input input{flex:1;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem;color:var(--text-color)}.objective-input button{background:#ef44444d;border:1px solid #ef4444;color:#fca5a5;padding:.5rem .75rem;border-radius:6px;cursor:pointer}.add-objective-btn{background:#d4af3733;border:1px dashed var(--gold-color);color:var(--gold-color);padding:.5rem;border-radius:6px;cursor:pointer;transition:all .2s}.add-objective-btn:hover{background:#d4af374d}.dm-only-checkbox{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);cursor:pointer}.inventory-content{display:flex;flex-direction:column;gap:2rem}.inventory-header{display:flex;justify-content:space-between;align-items:center}.inventory-header h2{margin:0;color:var(--gold-color)}.currency-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.currency-section h3{margin:0 0 1rem;color:var(--gold-color)}.currency-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.currency-item{display:flex;flex-direction:column;gap:.25rem}.currency-item label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase}.currency-item input{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem;color:var(--text-color);font-size:1.1rem;text-align:center}.currency-item.platinum input{border-color:#e5e7eb;color:#e5e7eb}.currency-item.gold input{border-color:var(--gold-color);color:var(--gold-color)}.currency-item.electrum input{border-color:#a3e635;color:#a3e635}.currency-item.silver input{border-color:#9ca3af;color:#9ca3af}.currency-item.copper input{border-color:#f97316;color:#f97316}.currency-total{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);text-align:right;color:var(--gold-color);font-weight:600}.party-items-section,.character-inventories-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.party-items-section h3,.character-inventories-section h3{margin:0 0 1rem;color:var(--gold-color)}.add-item-form{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.add-item-form input{flex:1;min-width:120px;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem;color:var(--text-color)}.attunement-checkbox{display:flex;align-items:center;gap:.25rem;color:var(--text-muted);font-size:.85rem;white-space:nowrap}.no-items-message{color:var(--text-muted);text-align:center;padding:1.5rem;font-style:italic}.items-list{display:flex;flex-direction:column;gap:.5rem}.inventory-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#0003;border-radius:8px;gap:1rem}.item-info{flex:1}.item-name{font-weight:500;color:var(--text-color)}.attunement-badge{color:var(--purple-accent);margin-left:.25rem}.item-value{margin-left:.75rem;color:var(--gold-color);font-size:.85rem}.item-description{margin:.25rem 0 0;font-size:.85rem;color:var(--text-muted)}.item-actions{display:flex;gap:.5rem;align-items:center}.item-actions select{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.4rem;color:var(--text-color);font-size:.85rem}.character-inventories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.character-inventory-card{background:#0003;border-radius:8px;padding:1rem;border:1px solid var(--border-color)}.character-inventory-card h4{margin:0 0 .75rem;color:var(--gold-color);font-size:1rem}.char-items-list{list-style:none;padding:0;margin:0}.char-items-list li{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0;font-size:.9rem;border-bottom:1px solid var(--border-color)}.char-items-list li:last-child{border-bottom:none}.return-btn{background:transparent;border:none;color:var(--gold-color);cursor:pointer;padding:.25rem;font-size:1rem}.maps-content{display:flex;flex-direction:column;gap:1.5rem}.maps-header{display:flex;justify-content:space-between;align-items:center}.maps-header h2{margin:0;color:var(--gold-color)}.no-maps-message{text-align:center;padding:3rem;color:var(--text-muted)}.maps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.map-card{background:var(--card-bg);border-radius:12px;overflow:hidden;border:2px solid var(--border-color);cursor:pointer;transition:all .2s ease}.map-card:hover,.map-card.selected{border-color:var(--gold-color);transform:translateY(-2px)}.map-thumbnail{height:150px;overflow:hidden;position:relative}.map-thumbnail img{width:100%;height:100%;object-fit:cover}.pin-count{position:absolute;bottom:.5rem;right:.5rem;background:#000000b3;color:var(--gold-color);padding:.2rem .5rem;border-radius:4px;font-size:.75rem}.map-card-info{padding:.75rem;display:flex;justify-content:space-between;align-items:center}.map-card-info h4{margin:0;font-size:.95rem;color:var(--text-color)}.map-viewer{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.map-viewer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.map-viewer-header h3{margin:0;color:var(--gold-color)}.map-viewer-header button{background:#ef44444d;border:1px solid #ef4444;color:#fca5a5;padding:.4rem .75rem;border-radius:6px;cursor:pointer}.map-viewer-image{position:relative;border-radius:8px;overflow:hidden;cursor:crosshair}.map-viewer-image img{width:100%;height:auto;display:block}.map-viewer-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border-medium);margin-bottom:1rem}.map-viewer-header h3{margin:0;color:var(--gold-primary)}.map-viewer-actions{display:flex;align-items:center;gap:1rem}.map-pin-count{color:var(--text-muted);font-size:.85rem}.map-close-btn{padding:.5rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-medium);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.map-close-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.map-pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;z-index:10;transition:all .2s ease;display:flex;flex-direction:column;align-items:center}.map-pin .pin-marker{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);font-size:1rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));transition:all .2s ease;border:2px solid rgba(255,255,255,.8)}.map-pin .pin-marker>*{transform:rotate(45deg)}.map-pin .pin-label-text{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#0f172ae6;color:#fff;padding:2px 8px;border-radius:4px;font-size:.75rem;white-space:nowrap;margin-top:4px;border:1px solid var(--gold-primary);opacity:0;transition:opacity .2s ease}.map-pin:hover .pin-label-text{opacity:1}.map-pin:hover{z-index:20;transform:translate(-50%,-100%) scale(1.2)}.map-pin:hover .pin-marker{filter:drop-shadow(0 4px 8px rgba(0,0,0,.7))}.map-pin.has-link{cursor:pointer}.map-pin.has-link .pin-marker{animation:pin-pulse 2s ease-in-out infinite}@keyframes pin-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.map-pin:hover .pin-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-8px)}.pin-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(0);background:#0f172af2;border:1px solid var(--gold-primary);color:#fff;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.85rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:100;min-width:150px;text-align:center;pointer-events:none;box-shadow:0 4px 12px #0006}.pin-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:var(--gold-primary)}.pin-tooltip strong{display:block;color:var(--gold-primary);font-size:.95rem;margin-bottom:.25rem}.pin-entity-link{display:block;color:#10b981;font-size:.8rem;margin-top:.25rem}.pin-description{margin:.5rem 0 0;color:var(--text-secondary);font-size:.8rem;white-space:normal;max-width:200px}.pin-hint{display:block;font-size:.7rem;color:var(--text-muted);margin-top:.5rem;border-top:1px solid rgba(255,255,255,.1);padding-top:.5rem}.pin-tray{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);margin-bottom:.75rem}.pin-tray-section{display:flex;align-items:center;gap:.75rem}.pin-tray-label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;font-weight:600}.pin-tray-items,.pin-tray-tokens{display:flex;flex-wrap:wrap;gap:.5rem}.pin-tray-item{cursor:grab;transition:transform .15s ease}.pin-tray-item:hover{transform:scale(1.15)}.pin-tray-item:active{cursor:grabbing}.pin-tray-marker{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);font-size:.9rem;border:2px solid rgba(255,255,255,.8);box-shadow:0 2px 4px #0000004d}.pin-tray-marker>*{transform:rotate(45deg)}.pin-tray-token{display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:grab;transition:transform .15s ease}.pin-tray-token:hover{transform:scale(1.1)}.pin-tray-token:active{cursor:grabbing}.pin-tray-token .token-image{width:40px;height:40px;border-radius:50%;object-fit:cover;border:3px solid #22c55e;box-shadow:0 2px 6px #0006}.pin-tray-token .token-placeholder{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;border:3px solid #22c55e;box-shadow:0 2px 6px #0006}.pin-tray-token .token-name{font-size:.65rem;color:var(--text-secondary);max-width:50px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.map-token{position:absolute;transform:translate(-50%,-50%);cursor:pointer;z-index:15;transition:all .2s ease;display:flex;flex-direction:column;align-items:center}.map-token:hover{z-index:25;transform:translate(-50%,-50%) scale(1.15)}.map-token .token-map-image{width:48px;height:48px;border-radius:50%;object-fit:cover;border:3px solid var(--token-color, #22c55e);box-shadow:0 3px 8px #00000080;transition:all .2s ease}.map-token:hover .token-map-image{box-shadow:0 4px 12px #0009}.map-token .token-map-placeholder{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--token-color, #22c55e),color-mix(in srgb,var(--token-color, #22c55e) 70%,black));display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#fff;border:3px solid var(--token-color, #22c55e);box-shadow:0 3px 8px #00000080;transition:all .2s ease}.map-token:hover .token-map-placeholder{box-shadow:0 4px 12px #0009}.map-token .token-map-name{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#0f172af2;color:#fff;padding:3px 8px;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap;margin-top:4px;border:1px solid var(--token-color, #22c55e);opacity:0;transition:opacity .2s ease}.map-token:hover .token-map-name{opacity:1}.map-viewer-image.drop-target{outline:3px dashed var(--gold-primary);outline-offset:-3px;background:#d4af371a}.map-viewer-image.drop-target img{opacity:.8}.map-hint{text-align:center;color:var(--text-muted);font-size:.85rem;margin-top:.75rem;padding:.75rem;background:#d4af371a;border-radius:var(--radius-md);border:1px dashed var(--gold-primary)}.map-pin-modal{max-width:550px;width:95%}.map-pin-form{display:flex;flex-direction:column;gap:1.25rem}.map-pin-form .form-group{display:flex;flex-direction:column;gap:.5rem}.map-pin-form .form-group label{font-weight:600;color:var(--text-primary);font-size:.9rem}.map-pin-form input[type=text],.map-pin-form textarea,.map-pin-form select{padding:.75rem;border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:.95rem;transition:all .2s ease}.map-pin-form input[type=text]:focus,.map-pin-form textarea:focus,.map-pin-form select:focus{outline:none;border-color:var(--gold-primary);box-shadow:0 0 0 3px #d4af3733}.entity-link-select{max-height:200px}.entity-link-hint{color:#10b981;font-size:.8rem;margin:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.color-picker-row{display:flex;align-items:center;gap:.75rem}.color-picker{width:40px;height:40px;border:none;border-radius:var(--radius-md);cursor:pointer;padding:0}.color-presets{display:flex;gap:.5rem}.color-preset{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s ease}.color-preset:hover{transform:scale(1.1)}.color-preset.active{border-color:#fff;box-shadow:0 0 0 2px var(--gold-primary)}.icon-picker{display:flex;flex-wrap:wrap;gap:.5rem}.icon-preset{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--bg-elevated);border:2px solid var(--border-medium);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.icon-preset:hover{border-color:var(--gold-primary);background:var(--bg-hover)}.icon-preset.active{border-color:var(--gold-primary);background:#d4af3733}.pin-preview{padding:1rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-medium)}.pin-preview label{display:block;font-weight:600;color:var(--text-secondary);font-size:.8rem;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.pin-preview-box{display:flex;align-items:center;gap:1rem;justify-content:center}.pin-preview-box .map-pin.preview{position:relative;transform:none}.pin-preview-box .map-pin.preview .pin-marker{width:40px;height:40px;font-size:1.25rem}.pin-preview-box .map-pin.preview .pin-label-text{opacity:1;position:static;transform:none;margin-top:8px}.preview-label{color:var(--text-primary);font-weight:500}.map-pin-modal .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-medium);margin-top:.5rem}.map-pin-modal .delete-btn{margin-right:auto;padding:.75rem 1rem;background:#ef444433;border:1px solid #ef4444;color:#ef4444;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.map-pin-modal .delete-btn:hover{background:#ef44444d}.map-pin-modal .cancel-btn{padding:.75rem 1.25rem;background:var(--bg-elevated);border:1px solid var(--border-medium);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.map-pin-modal .cancel-btn:hover{background:var(--bg-hover)}.map-pin-modal .confirm-btn{padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--gold-primary),var(--gold-dark));border:none;color:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:all .2s ease}.map-pin-modal .confirm-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4af3766}@media(max-width:768px){.form-row{grid-template-columns:1fr}.map-pin-modal .modal-actions{flex-wrap:wrap}.map-pin-modal .delete-btn{width:100%;margin-right:0;margin-bottom:.5rem}}.calendar-content{display:flex;flex-direction:column;gap:2rem}.calendar-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.calendar-header h2{margin:0;color:var(--gold-color)}.calendar-setup{background:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);width:100%}.calendar-setup p{margin:0 0 1rem;color:var(--text-muted)}.calendar-options{display:flex;gap:.75rem;flex-wrap:wrap}.calendar-options button{background:#d4af3733;border:1px solid var(--gold-color);color:var(--gold-color);padding:.75rem 1.25rem;border-radius:8px;cursor:pointer;transition:all .2s}.calendar-options button:hover{background:#d4af3766}.current-date-display{background:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);text-align:center}.current-date-display h3{margin:0 0 1rem;color:var(--gold-color)}.date-display{display:flex;flex-direction:column;align-items:center;gap:1rem}.current-date{font-size:1.5rem;font-weight:600;color:var(--text-color)}.date-controls{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.date-controls button{background:#d4af3733;border:1px solid var(--gold-color);color:var(--gold-color);padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s}.date-controls button:hover{background:#d4af3766}.set-date-form{display:flex;flex-direction:column;align-items:center;gap:1rem}.set-date-form p{margin:0;color:var(--text-muted)}.date-inputs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;align-items:center}.date-inputs input,.date-inputs select{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem;color:var(--text-color)}.date-inputs input[type=number]{width:80px}.calendar-months{background:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color)}.calendar-months h3{margin:0 0 1rem;color:var(--gold-color)}.months-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.month-card{background:#0003;padding:.75rem;border-radius:8px;text-align:center;border:1px solid transparent;transition:all .2s}.month-card.current{border-color:var(--gold-color);background:#d4af371a}.month-card h4{margin:0 0 .25rem;font-size:.9rem;color:var(--text-color)}.month-card span{font-size:.8rem;color:var(--text-muted)}.calendar-holidays{background:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color)}.calendar-holidays h3{margin:0 0 1rem;color:var(--gold-color)}.calendar-holidays ul{list-style:none;padding:0;margin:0}.calendar-holidays li{padding:.5rem 0;border-bottom:1px solid var(--border-color)}.calendar-holidays li:last-child{border-bottom:none}.calendar-holidays li strong{color:var(--text-color)}.calendar-holidays li span{color:var(--text-muted);font-size:.9rem}.calendar-events{background:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color)}.calendar-events h3{margin:0 0 1rem;color:var(--gold-color)}.no-events-message{color:var(--text-muted);text-align:center;padding:1rem;font-style:italic}.events-list{list-style:none;padding:0;margin:1rem 0 0}.events-list li{padding:.75rem;background:#0003;border-radius:8px;margin-bottom:.5rem}.events-list li strong{color:var(--text-color);display:block}.event-date{color:var(--gold-color);font-size:.85rem;margin-left:.5rem}.events-list li p{margin:.25rem 0 0;color:var(--text-muted);font-size:.9rem}.entity-mention{background:#d4af3733;color:var(--gold-color);padding:.1rem .4rem;border-radius:4px;cursor:pointer;transition:all .2s ease;font-weight:500}.entity-mention:hover{background:#d4af3766;text-decoration:underline}.entity-mention.npc{background:#8b5cf633;color:var(--purple-accent)}.entity-mention.npc:hover{background:#8b5cf666}.entity-mention.player-character{background:#10b98133;color:var(--emerald-accent)}.entity-mention.player-character:hover{background:#10b98166}.entity-mention.location{background:#3b82f633;color:#93c5fd}.entity-mention.location:hover{background:#3b82f666}.entity-mention.organization{background:#f9731633;color:#fdba74}.entity-mention.organization:hover{background:#f9731666}.entity-mention.item{background:#eab30833;color:#fcd34d}.entity-mention.item:hover{background:#eab30866}.entity-mention.plot-thread{background:#ec489933;color:#f9a8d4}.entity-mention.plot-thread:hover{background:#ec489966}.mention-input-container{position:relative;width:100%}.mention-toolbar{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem}.mention-hint{color:var(--text-muted);font-size:.75rem}.quick-insert-btn{background:var(--bg-darker);border:1px solid var(--border-color);color:var(--text-color);padding:.35rem .75rem;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .15s ease}.quick-insert-btn:hover{background:var(--gold-color);color:var(--bg-darker);border-color:var(--gold-color)}.mention-autocomplete-dropdown{background:var(--bg-darker);border:1px solid var(--gold-color);border-radius:8px;box-shadow:0 8px 32px #0006;max-height:300px;overflow-y:auto;min-width:250px}.mention-suggestion{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .15s ease}.mention-suggestion:last-child{border-bottom:none}.mention-suggestion:hover,.mention-suggestion.selected{background:#d4af3726}.mention-suggestion-icon{font-size:1.2rem;width:28px;text-align:center}.mention-suggestion-name{flex:1;font-weight:500;color:var(--text-color)}.mention-suggestion-type{font-size:.75rem;color:var(--text-muted);background:var(--bg-color);padding:.2rem .5rem;border-radius:4px}.mention-suggestion.npc{border-left:3px solid #f59e0b}.mention-suggestion.player-character{border-left:3px solid #3b82f6}.mention-suggestion.location{border-left:3px solid #10b981}.mention-suggestion.organization{border-left:3px solid #8b5cf6}.mention-suggestion.item{border-left:3px solid #ef4444}.mention-suggestion.plot-thread{border-left:3px solid #ec4899}.entity-backlinks-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.entity-backlinks-section h4{margin:0 0 .75rem;color:var(--gold-color);font-size:.95rem}.backlinks-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.backlink-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-color);border-radius:6px;cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.backlink-item:hover{background:#d4af371a;transform:translate(4px)}.backlink-item.backlink-note{border-left-color:#3b82f6}.backlink-item.backlink-quest{border-left-color:#f59e0b}.backlink-item.backlink-session{border-left-color:#10b981}.backlink-item.backlink-handout{border-left-color:#8b5cf6}.backlink-icon{font-size:1rem}.backlink-title{flex:1;font-size:.85rem;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.backlink-type{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;background:var(--bg-darker);padding:.15rem .4rem;border-radius:3px}.entity-comention-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.entity-comention-section h4{margin:0 0 .75rem;color:var(--gold-color);font-size:.95rem}.comention-list{display:flex;flex-wrap:wrap;gap:.5rem}.comention-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:var(--bg-color);border-radius:20px;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.comention-item:hover{background:#d4af3726;border-color:var(--gold-color);transform:scale(1.02)}.comention-icon{font-size:.9rem}.comention-name{font-size:.85rem;color:var(--text-color);font-weight:500}.comention-count{font-size:.7rem;color:var(--text-muted);background:var(--bg-darker);padding:.1rem .35rem;border-radius:8px}.comention-item.npc{border-color:#f59e0b4d}.comention-item.player-character{border-color:#3b82f64d}.comention-item.location{border-color:#10b9814d}.comention-item.organization{border-color:#8b5cf64d}.comention-item.item{border-color:#ef44444d}.comention-item.plot-thread{border-color:#ec48994d}.entity-picker-modal{max-width:600px;max-height:80vh}.picker-subtitle{color:var(--text-muted);margin:.5rem 0 1rem;font-size:.9rem}.entity-picker-search{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-darker);color:var(--text-color);font-size:1rem;margin-bottom:1rem}.entity-picker-search:focus{outline:none;border-color:var(--gold-color)}.entity-picker-grid{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto}.entity-picker-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-color);border-radius:8px;cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.entity-picker-item:hover{background:#d4af3726;transform:translate(4px)}.entity-picker-item.npc{border-left-color:#f59e0b}.entity-picker-item.player-character{border-left-color:#3b82f6}.entity-picker-item.location{border-left-color:#10b981}.entity-picker-item.organization{border-left-color:#8b5cf6}.entity-picker-item.item{border-left-color:#ef4444}.entity-picker-item.plot-thread{border-left-color:#ec4899}.picker-icon{font-size:1.5rem;width:36px;text-align:center}.picker-info{display:flex;flex-direction:column;flex:1}.picker-name{font-weight:500;color:var(--text-color)}.picker-type{font-size:.75rem;color:var(--text-muted)}.no-entities-message{text-align:center;color:var(--text-muted);padding:2rem}.handouts-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-color)}.handouts-section h3{margin:0 0 1rem;color:var(--gold-color)}.handouts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.handout-card{background:var(--card-bg);border-radius:12px;padding:1.25rem;border:1px solid var(--border-color)}.handout-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.handout-header h4{margin:0;color:var(--text-color)}.handout-type{font-size:.75rem;padding:.2rem .5rem;background:#8b5cf633;color:var(--purple-accent);border-radius:4px;text-transform:uppercase}.handout-content{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin:0 0 1rem;white-space:pre-wrap}.handout-image{width:100%;border-radius:8px;margin-bottom:1rem}.handout-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-color)}.shared-with{font-size:.85rem;color:var(--text-muted)}.handout-modal{max-width:600px}.handout-form{display:flex;flex-direction:column;gap:1rem}.handouts-section{margin-top:2rem}.handouts-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.handouts-header h3{margin:0;color:var(--text-primary)}.handout-category-filter{display:flex;flex-wrap:wrap;gap:.5rem}.category-pill{padding:.35rem .75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .2s ease}.category-pill:hover{border-color:var(--text-muted);color:var(--text-secondary)}.category-pill.active{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.empty-handouts{text-align:center;padding:2rem;color:var(--text-muted)}.empty-handouts .hint{font-size:.85rem;margin-top:.5rem}.handouts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.handout-card{background:var(--bg-card);border-radius:12px;padding:1rem;border:1px solid var(--border-color);transition:all .2s ease}.handout-card:hover{border-color:var(--gold-dark);box-shadow:0 4px 20px #0003}.handout-card.revealed{border-color:var(--gold-primary);background:linear-gradient(135deg,rgba(246,211,101,.05),transparent)}.handout-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.handout-header h4{margin:0;color:var(--text-primary);font-size:1rem}.reveal-btn{padding:.25rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;color:var(--text-muted);cursor:pointer;transition:all .2s ease;white-space:nowrap}.reveal-btn:hover{border-color:var(--gold-primary)}.reveal-btn.active{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.handout-meta{display:flex;gap:.5rem;flex-wrap:wrap}.handout-type{font-size:.7rem;padding:.15rem .4rem;background:#8b5cf633;color:var(--purple-primary);border-radius:4px;text-transform:uppercase}.handout-category{font-size:.7rem;padding:.15rem .4rem;background:#56ab2f33;color:var(--emerald-primary);border-radius:4px}.handout-content-preview{padding:.75rem 0;cursor:pointer;border-radius:6px;transition:background .2s ease}.handout-content-preview:hover{background:var(--bg-elevated)}.handout-thumbnail{width:100%;max-height:120px;object-fit:cover;border-radius:6px;margin-bottom:.5rem}.handout-text{margin:0;color:var(--text-secondary);font-size:.85rem;line-height:1.4}.view-more{display:block;margin-top:.5rem;font-size:.75rem;color:var(--gold-primary)}.handout-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-color);margin-top:.5rem}.shared-with{font-size:.8rem;color:var(--text-muted)}.handout-actions{display:flex;gap:.25rem}.handout-actions .action-btn,.handout-actions .delete-btn{padding:.3rem .5rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s ease}.handout-actions .action-btn:hover{background:var(--bg-elevated);border-color:var(--gold-primary)}.handout-actions .delete-btn:hover{background:#ef444433;border-color:var(--crimson-primary)}.handout-reveal-overlay{z-index:1050}.handout-reveal-modal{max-width:800px;max-height:90vh;overflow-y:auto}.revealed-handout{padding:1rem 0}.revealed-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.revealed-header h2{margin:0 0 .75rem;color:var(--gold-primary)}.revealed-meta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.reveal-toggle{padding:.4rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.reveal-toggle:hover{border-color:var(--gold-primary)}.reveal-toggle.revealed{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.revealed-image-container{margin-bottom:1.5rem;text-align:center}.revealed-image{max-width:100%;max-height:500px;border-radius:8px;box-shadow:0 4px 20px #0000004d}.revealed-content{font-size:1rem;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap}.revealed-footer{display:flex;justify-content:space-between;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color);font-size:.85rem;color:var(--text-muted)}.relationship-graph-container{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);margin-bottom:1.5rem}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.graph-header h3{margin:0;color:var(--gold-color)}.graph-controls{display:flex;align-items:center;gap:.5rem;margin-left:auto}.graph-zoom-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.9rem;transition:all .2s ease}.graph-zoom-btn:hover{background:var(--bg-hover);border-color:var(--gold-primary)}.graph-zoom-level{font-size:.8rem;color:var(--text-secondary);min-width:45px;text-align:center}.graph-header>button:last-child{background:#ef44444d;border:1px solid #ef4444;color:#fca5a5;padding:.4rem .75rem;border-radius:6px;cursor:pointer}.relationship-graph{background:#0000004d;border-radius:8px;overflow:hidden;height:600px;position:relative}.graph-empty-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-muted)}.graph-empty-message p:first-child{font-size:1.2rem;color:var(--text-secondary);margin-bottom:.5rem}.graph-transform-wrapper{width:100%;height:100%;transition:transform .05s ease-out}.graph-svg{width:100%;height:100%}.graph-hint-text{text-align:center;color:var(--text-muted);font-size:.8rem;margin:.75rem 0;padding:.5rem;background:#d4af371a;border-radius:var(--radius-sm)}.graph-node{cursor:pointer;transition:transform .2s}.graph-node:hover circle{filter:brightness(1.2);stroke:#fff;stroke-width:3}.graph-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;justify-content:center}.graph-legend span{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-muted)}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.pc{background:#10b981}.legend-dot.npc{background:#8b5cf6}.legend-dot.location{background:#3b82f6}.legend-dot.org{background:#f97316}.legend-dot.item{background:#eab308}.legend-dot.plot{background:#ec4899}.legend-line{width:20px;height:3px;border-radius:2px}.legend-line.party{background:#22c55e}.legend-line.allies{background:#10b981}.legend-line.enemies{background:#ef4444}.legend-line.family{background:#8b5cf6}.legend-line.romantic{background:#ec4899}.legendary-actions{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#8b5cf61a;border-radius:6px;margin-top:.5rem}.legendary-actions span{font-size:.8rem;color:var(--purple-accent)}.legendary-pips{display:flex;gap:.25rem}.legendary-pip{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:.1rem;transition:transform .2s}.legendary-pip.available{color:var(--purple-accent)}.legendary-pip.used{color:var(--text-muted);opacity:.5}.legendary-pip:hover{transform:scale(1.2)}.refresh-legendary-btn{background:#8b5cf64d;border:1px solid var(--purple-accent);color:var(--purple-accent);padding:.2rem .4rem;border-radius:4px;cursor:pointer;font-size:.9rem}.lair-action-reminder{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:8px;margin-top:1rem}.lair-action-reminder span{color:var(--gold-color);font-size:.9rem}.lair-init-input{width:50px;background:#0000004d;border:1px solid var(--gold-color);border-radius:4px;padding:.25rem .5rem;color:var(--gold-color);text-align:center}.legendary-toggle{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#0003;border-radius:8px;margin-top:1rem;flex-wrap:wrap}.legendary-toggle label{display:flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.9rem;cursor:pointer}.legendary-count-input{width:60px;background:#0000004d;border:1px solid var(--border-color);border-radius:4px;padding:.25rem .5rem;color:var(--text-color)}.srd-modal{max-width:700px;max-height:80vh;display:flex;flex-direction:column}.srd-controls{display:flex;gap:.75rem;margin-bottom:1rem}.srd-category-select{background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem 1rem;color:var(--text-color);cursor:pointer}.srd-search-input{flex:1;background:#0000004d;border:1px solid var(--border-color);border-radius:6px;padding:.5rem 1rem;color:var(--text-color)}.srd-search-input:focus{outline:none;border-color:var(--gold-color)}.srd-results{overflow-y:auto;max-height:60vh;display:flex;flex-direction:column;gap:.75rem;padding-right:.5rem}.srd-card{background:#0000004d;border-radius:10px;padding:1rem;border:1px solid var(--border-color)}.srd-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.srd-card h4{margin:0;color:var(--text-color)}.spell-level{font-size:.75rem;padding:.2rem .5rem;background:#8b5cf633;color:var(--purple-accent);border-radius:4px}.spell-school{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;font-style:italic}.spell-details{display:flex;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.spell-details span strong{color:var(--gold-color)}.srd-description{margin:0;color:var(--text-muted);font-size:.9rem;line-height:1.5}.condition-card h4{margin-bottom:.5rem;color:var(--gold-color)}.item-rarity{font-size:.75rem;padding:.2rem .5rem;border-radius:4px;text-transform:capitalize}.item-rarity.uncommon{background:#22c55e33;color:#22c55e}.item-rarity.very\ rare{background:#8b5cf633;color:#8b5cf6}.item-rarity.legendary{background:#f9731633;color:#f97316}.item-type{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;font-style:italic}.wiki-tab{padding:1rem 0}.wiki-header-section{text-align:center;margin-bottom:2rem}.wiki-header-section h2{color:var(--gold-color);font-size:2rem;margin-bottom:.5rem}.wiki-subtitle{color:var(--text-muted);font-size:1rem;margin-bottom:1.5rem}.wiki-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;max-width:900px;margin:0 auto}.wiki-search-container{position:relative;flex:1;min-width:250px}.wiki-search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-darker);color:var(--text-color);font-size:1rem}.wiki-search-input:focus{outline:none;border-color:var(--gold-color)}.wiki-search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer}.wiki-actions{display:flex;gap:.5rem}.wiki-view-btn,.wiki-settings-btn,.wiki-export-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-darker);color:var(--text-color);cursor:pointer;transition:all .15s ease}.wiki-view-btn:hover,.wiki-settings-btn:hover,.wiki-export-btn:hover{background:#d4af371a;border-color:var(--gold-color)}.wiki-view-btn.active{background:var(--gold-color);color:var(--bg-darker)}.wiki-export-btn{background:#8b5cf626;border-color:#8b5cf666}.wiki-stats-banner{display:flex;justify-content:center;gap:2rem;padding:1rem;background:var(--card-bg);border-radius:12px;margin-bottom:1.5rem;flex-wrap:wrap}.wiki-stat{display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem}.stat-number{font-size:1.75rem;font-weight:700;color:var(--gold-color)}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase}.wiki-category-nav{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.wiki-category-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:20px;background:var(--bg-darker);color:var(--text-color);cursor:pointer;transition:all .15s ease}.wiki-category-btn:hover{background:#d4af371a}.wiki-category-btn.active{background:var(--gold-color);color:var(--bg-darker);border-color:var(--gold-color)}.wiki-content{min-height:400px}.wiki-empty{text-align:center;padding:3rem;color:var(--text-muted)}.wiki-empty-hint{font-size:.9rem;margin-top:.5rem}.wiki-article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.wiki-article-card{background:var(--card-bg);border-radius:12px;overflow:hidden;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease;border-left:4px solid var(--gold-color)}.wiki-article-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:var(--gold-color)}.wiki-article-card.npc,.wiki-article-card.player-character{border-left-color:#f59e0b}.wiki-article-card.location{border-left-color:#10b981}.wiki-article-card.item{border-left-color:#ef4444}.wiki-article-card.organization{border-left-color:#8b5cf6}.wiki-article-card.plot-thread{border-left-color:#ec4899}.wiki-card-image{aspect-ratio:1 / 1;overflow:hidden}.wiki-card-image img{width:100%;height:100%;object-fit:cover}.wiki-card-content{padding:1.25rem}.wiki-card-content h3{color:var(--gold-color);margin:0 0 .5rem;font-size:1.1rem}.wiki-card-type{display:inline-block;font-size:.75rem;color:var(--text-muted);background:var(--bg-darker);padding:.2rem .5rem;border-radius:4px;margin-bottom:.75rem}.wiki-card-excerpt{font-size:.9rem;color:var(--text-color);line-height:1.5;margin-bottom:.75rem}.wiki-card-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.wiki-mentions{font-size:.8rem;color:var(--text-muted)}.wiki-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:4px}.wiki-badge.top{background:#d4af3733;color:var(--gold-color)}.wiki-badge.manual{background:#10b98133;color:#10b981}.wiki-article-view{max-width:1000px;margin:0 auto}.wiki-back-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-darker);color:var(--text-color);cursor:pointer;margin-bottom:1.5rem}.wiki-back-btn:hover{background:#d4af371a}.wiki-article{display:flex;gap:2rem;position:relative}.wiki-infobox{width:280px;flex-shrink:0;background:var(--card-bg);border:2px solid var(--gold-color);border-radius:8px;overflow:hidden;height:fit-content;position:sticky;top:1rem}.infobox-image{width:100%;height:200px;overflow:hidden}.infobox-image img{width:100%;height:100%;object-fit:cover}.infobox-title{text-align:center;padding:1rem;background:var(--gold-color);color:var(--bg-darker);margin:0;font-size:1.1rem}.infobox-rows{padding:.75rem}.infobox-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.infobox-row:last-child{border-bottom:none}.infobox-label{color:var(--text-muted);font-weight:500}.infobox-value{color:var(--text-color);text-align:right;max-width:60%}.wiki-article-main{flex:1;min-width:0}.wiki-article-title{color:var(--gold-color);font-size:2rem;margin:0 0 1.5rem;border-bottom:2px solid var(--gold-color);padding-bottom:.5rem}.wiki-toc{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem 1.5rem;margin-bottom:1.5rem;display:inline-block}.wiki-toc h4{color:var(--gold-color);margin:0 0 .75rem;font-size:.9rem}.wiki-toc ol{margin:0;padding-left:1.5rem}.wiki-toc li{margin:.25rem 0}.wiki-toc a{color:var(--text-color);text-decoration:none}.wiki-toc a:hover{color:var(--gold-color)}.wiki-section{margin-bottom:2rem}.wiki-section h2{color:var(--gold-color);font-size:1.3rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.wiki-section-content{line-height:1.7;white-space:pre-wrap}.wiki-relationships-list{list-style:none;padding:0;margin:0}.wiki-relationship{padding:.75rem;background:var(--bg-darker);border-radius:6px;margin-bottom:.5rem}.wiki-relationship .relationship-type{display:inline-block;background:var(--gold-color);color:var(--bg-darker);padding:.2rem .5rem;border-radius:4px;font-size:.8rem;margin-right:.5rem}.wiki-relationship .relationship-entity{color:var(--gold-color);cursor:pointer;font-weight:500}.wiki-relationship .relationship-entity:hover{text-decoration:underline}.wiki-relationship .relationship-desc{color:var(--text-muted);font-style:italic}.wiki-timeline{list-style:none;padding:0;margin:0;border-left:2px solid var(--gold-color);padding-left:1.5rem}.wiki-timeline-item{position:relative;padding:.75rem 0}.wiki-timeline-item:before{content:"";position:absolute;left:-1.65rem;top:1rem;width:10px;height:10px;background:var(--gold-color);border-radius:50%}.timeline-session{font-weight:600;color:var(--gold-color)}.timeline-title{color:var(--text-color)}.timeline-date{color:var(--text-muted);font-size:.85rem;margin-left:.5rem}.wiki-quests-list{list-style:none;padding:0;margin:0}.wiki-quest-item{padding:1rem;background:var(--bg-darker);border-radius:8px;margin-bottom:.75rem}.wiki-quest-item .quest-status{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;text-transform:uppercase;margin-right:.5rem}.wiki-quest-item .quest-status.active{background:#3b82f633;color:#3b82f6}.wiki-quest-item .quest-status.completed{background:#10b98133;color:#10b981}.wiki-quest-item .quest-title{font-weight:500;color:var(--text-color)}.wiki-quest-item .quest-desc{margin-top:.5rem;color:var(--text-muted);font-size:.9rem}.wiki-notes-list{display:flex;flex-direction:column;gap:1rem}.wiki-note-item{padding:1rem;background:var(--bg-darker);border-radius:8px;border-left:3px solid #3b82f6}.wiki-note-item h4{color:var(--gold-color);margin:0 0 .5rem}.wiki-note-item p{margin:0;color:var(--text-color);font-size:.9rem}.wiki-related-list{display:flex;flex-wrap:wrap;gap:.5rem}.wiki-related-link{padding:.5rem 1rem;background:var(--bg-darker);border:1px solid var(--border-color);border-radius:20px;color:var(--gold-color);cursor:pointer;transition:all .15s ease}.wiki-related-link:hover{background:var(--gold-color);color:var(--bg-darker)}.wiki-settings-modal{max-width:700px;max-height:85vh;overflow-y:auto}.wiki-settings-form{display:flex;flex-direction:column;gap:1.5rem}.settings-section{background:var(--bg-darker);padding:1.25rem;border-radius:8px}.settings-section h3{color:var(--gold-color);margin:0 0 1rem;font-size:1rem}.settings-hint{color:var(--text-muted);font-size:.85rem;margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px}.wiki-curation-list{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px}.wiki-curation-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.wiki-curation-item:last-child{border-bottom:none}.wiki-curation-item.included{background:#10b9810d}.wiki-curation-item.excluded{background:#ef44440d}.curation-info{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.curation-name{font-weight:500;color:var(--text-color)}.curation-type{font-size:.75rem;color:var(--text-muted);background:var(--bg-color);padding:.15rem .4rem;border-radius:3px}.curation-mentions{font-size:.75rem;color:var(--gold-color)}.curation-reason{font-size:.7rem;padding:.15rem .4rem;border-radius:3px}.curation-reason.top-mentioned{background:#d4af3733;color:var(--gold-color)}.curation-reason.threshold{background:#3b82f633;color:#3b82f6}.curation-reason.player-character{background:#8b5cf633;color:#8b5cf6}.curation-reason.manual{background:#10b98133;color:#10b981}.curation-reason.excluded{background:#ef444433;color:#ef4444}.curation-reason.below-threshold{background:#9ca3af33;color:#9ca3af}.curation-btn{padding:.4rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;border:1px solid var(--border-color);background:var(--bg-color);color:var(--text-color);transition:all .15s ease}.curation-btn:hover{border-color:var(--gold-color)}.curation-btn.active{background:#10b98133;border-color:#10b981;color:#10b981}@media(max-width:768px){.wiki-article{flex-direction:column}.wiki-infobox{width:100%;position:static}.wiki-toolbar{flex-direction:column;align-items:stretch}.wiki-actions{justify-content:center}}.cropper-overlay{z-index:2000}.cropper-modal{max-width:800px;width:95%;max-height:90vh;overflow-y:auto}.cropper-instructions{color:#94a3b8;font-size:.9rem;margin-bottom:1rem;text-align:center}.cropper-container{display:flex;justify-content:center;margin:1rem 0;background:#0f172a;border-radius:8px;padding:1rem}.cropper-image-wrapper{position:relative;display:inline-block;max-width:100%;-webkit-user-select:none;user-select:none}.cropper-image{display:block;max-width:100%;max-height:500px;object-fit:contain}.cropper-overlay-top,.cropper-overlay-bottom,.cropper-overlay-left,.cropper-overlay-right{position:absolute;background:#0009;pointer-events:none}.cropper-overlay-top{top:0;left:0;right:0}.cropper-overlay-bottom{left:0;right:0;bottom:0}.cropper-overlay-left{left:0}.cropper-overlay-right{right:0}.crop-selection{position:absolute;border:2px solid #10b981;box-shadow:0 0 0 9999px #00000080;cursor:move;box-sizing:border-box}.crop-selection:hover{border-color:#34d399}.crop-grid{position:absolute;inset:0;pointer-events:none}.crop-grid-line{position:absolute;background:#ffffff4d}.crop-grid-line.horizontal{left:0;right:0;height:1px}.crop-grid-line.vertical{top:0;bottom:0;width:1px}.crop-handle{position:absolute;width:20px;height:20px;background:#10b981;border:2px solid #fff;border-radius:50%;pointer-events:none}.crop-handle-nw{top:-10px;left:-10px}.crop-handle-ne{top:-10px;right:-10px}.crop-handle-sw{bottom:-10px;left:-10px}.crop-handle-se{bottom:-10px;right:-10px;cursor:nwse-resize;pointer-events:auto}.crop-handle-se:hover{background:#34d399;transform:scale(1.2)}.cropper-preview-section{text-align:center;margin:1rem 0}.cropper-preview-section h4{color:#94a3b8;margin-bottom:.5rem;font-size:.9rem}.cropper-preview{width:100px;height:100px;overflow:hidden;border-radius:8px;border:2px solid #334155;margin:0 auto;background:#1e293b}.cropper-preview img{display:block;max-width:none}.cropper-actions{display:flex;justify-content:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #334155}.cropper-actions .cancel-btn{padding:.75rem 1.5rem;background:#475569;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .2s ease}.cropper-actions .cancel-btn:hover{background:#64748b}.cropper-actions .confirm-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease}.cropper-actions .confirm-btn:hover{background:linear-gradient(135deg,#34d399,#10b981);transform:translateY(-1px)}@media(max-width:768px){.cropper-modal{padding:1rem}.cropper-image{max-height:350px}.cropper-preview{width:80px;height:80px}.cropper-actions{flex-direction:column}.cropper-actions button{width:100%}}.dm-screen-overlay{z-index:1000}.dm-screen-modal{width:95vw;max-width:1400px;height:90vh;max-height:90vh;display:flex;flex-direction:column;padding:0;overflow:hidden}.dm-screen-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-elevated);border-bottom:1px solid var(--border-color)}.dm-screen-header h2{margin:0;color:var(--gold-primary)}.dm-screen-quick-actions{display:flex;align-items:center;gap:.5rem}.dm-screen-quick-actions>button{padding:.5rem .75rem;font-size:1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease}.dm-screen-quick-actions>button:hover{background:var(--bg-glass-light);border-color:var(--gold-primary)}.quick-dice{display:flex;gap:.25rem;margin-left:.5rem;padding-left:.5rem;border-left:1px solid var(--border-color)}.quick-dice button{padding:.4rem .6rem;font-size:.75rem;font-weight:600;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.quick-dice button:hover{background:var(--purple-primary);color:#fff;border-color:var(--purple-primary)}.last-roll{margin-left:.5rem;padding:.4rem .75rem;background:var(--bg-card);border-radius:4px;color:var(--text-secondary);font-size:.9rem}.last-roll strong{color:var(--gold-primary);font-size:1.1rem}.dm-screen-tabs{display:flex;gap:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.dm-screen-tabs button{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:all .2s ease}.dm-screen-tabs button:hover{color:var(--text-secondary);background:var(--bg-glass-light)}.dm-screen-tabs button.active{color:var(--gold-primary);border-bottom-color:var(--gold-primary);background:var(--bg-card)}.dm-screen-content{flex:1;overflow-y:auto;padding:1.5rem;background:var(--bg-primary)}.dm-screen-party .empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.pc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.pc-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1rem;transition:all .2s ease}.pc-card:hover{border-color:var(--gold-dark);box-shadow:0 4px 20px #0000004d}.pc-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.pc-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--gold-dark)}.pc-name-section h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.pc-class{font-size:.8rem;color:var(--text-muted);text-transform:capitalize}.pc-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.stat-block{display:flex;flex-direction:column;gap:.25rem}.stat-block.wide,.stat-block.hp-block{grid-column:span 3}.stat-block label{font-size:.7rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.stat-block input{padding:.4rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.9rem;text-align:center}.stat-block input[type=text]{text-align:left}.stat-block input:focus{outline:none;border-color:var(--gold-primary)}.hp-controls{display:flex;align-items:center;gap:.25rem}.hp-controls button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;cursor:pointer;transition:all .2s ease}.hp-controls button:hover{background:var(--gold-primary);color:var(--bg-primary)}.hp-controls input{width:50px}.hp-controls .max-hp{width:50px;color:var(--text-muted)}.hp-controls span{color:var(--text-muted)}.hp-bar{height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden;margin-top:.25rem}.hp-fill{height:100%;border-radius:3px;transition:all .3s ease}.pc-conditions{margin-bottom:.75rem}.pc-conditions>label{font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem;display:block}.condition-tags{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.condition-tag{padding:.2rem .5rem;background:var(--crimson-primary);border-radius:4px;font-size:.75rem;color:#fff;cursor:pointer;transition:all .2s ease}.condition-tag:hover{background:var(--crimson-dark)}.condition-tags select{padding:.2rem .4rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-muted);font-size:.75rem;cursor:pointer}.pc-concentration{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.pc-concentration label{display:flex;align-items:center;gap:.25rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.pc-concentration input[type=text]{flex:1;padding:.3rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.85rem}.pc-notes input{width:100%;padding:.4rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:.85rem}.pc-notes input::placeholder{color:var(--text-muted)}.dm-screen-npcs{display:flex;flex-direction:column;gap:1.5rem}.npcs-section h3{margin-bottom:.75rem;color:var(--text-primary)}.empty-hint{color:var(--text-muted);font-style:italic}.pinned-npcs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.npc-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.npc-card.pinned{border-color:var(--gold-dark)}.npc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.npc-header h4{margin:0;color:var(--text-primary)}.unpin-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;opacity:.7;transition:opacity .2s ease}.unpin-btn:hover{opacity:1}.npc-quick-stats{display:flex;gap:1rem;margin-bottom:.5rem}.stat-inline{display:flex;align-items:center;gap:.25rem}.stat-inline label{font-size:.75rem;color:var(--text-muted)}.stat-inline input{width:45px;padding:.25rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);text-align:center;font-size:.85rem}.stat-inline span{color:var(--text-muted)}.npc-notes{width:100%;padding:.4rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:.85rem}.all-npcs-list{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto}.npc-list-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px}.npc-list-item.is-pinned{border-color:var(--gold-dark);background:#f6d3650d}.npc-name{flex:1;color:var(--text-primary)}.npc-tags{color:var(--text-muted);font-size:.8rem}.pin-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;opacity:.5;transition:all .2s ease}.pin-btn:hover,.pin-btn.pinned{opacity:1}.dm-screen-reference{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.ref-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.ref-section h3{margin-bottom:.75rem;color:var(--gold-primary);font-size:1rem}.conditions-grid{display:flex;flex-direction:column;gap:.25rem}.condition-item{padding:.5rem;background:var(--bg-elevated);border-radius:4px}.condition-item summary{cursor:pointer;font-weight:500;color:var(--text-primary)}.condition-item p{margin-top:.5rem;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.dc-table{width:100%;border-collapse:collapse}.dc-table td{padding:.4rem .5rem;border-bottom:1px solid var(--border-color)}.dc-table td:first-child{color:var(--text-secondary)}.dc-table td:last-child{text-align:right;font-weight:600;color:var(--gold-primary)}.ref-list{list-style:none;padding:0}.ref-list li{padding:.4rem 0;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.ref-list li:last-child{border-bottom:none}.ref-list strong{color:var(--text-primary)}.dm-screen-notes{height:100%;display:flex;flex-direction:column}.dm-screen-notes h3{margin-bottom:.5rem;color:var(--text-primary)}.notes-hint{color:var(--text-muted);font-size:.85rem;margin-bottom:1rem}.dm-screen-notes textarea{flex:1;width:100%;padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.95rem;line-height:1.6;resize:none}.dm-screen-notes textarea:focus{outline:none;border-color:var(--gold-primary)}@media(max-width:768px){.dm-screen-modal{width:100%;height:100%;max-height:100%;border-radius:0}.dm-screen-header{flex-direction:column;gap:1rem}.dm-screen-quick-actions{flex-wrap:wrap;justify-content:center}.pc-grid,.dm-screen-reference{grid-template-columns:1fr}}.search-overlay{z-index:1100;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.search-modal{width:90vw;max-width:700px;max-height:80vh;padding:0;display:flex;flex-direction:column;animation:searchSlideIn .2s ease-out}@keyframes searchSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.search-header{padding:1rem;border-bottom:1px solid var(--border-color);background:var(--bg-elevated)}.search-input-wrapper{display:flex;align-items:center;gap:.75rem;background:var(--bg-card);border:2px solid var(--border-color);border-radius:12px;padding:.75rem 1rem;transition:border-color .2s ease}.search-input-wrapper:focus-within{border-color:var(--gold-primary)}.search-icon{font-size:1.25rem;opacity:.6}.search-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:1.1rem;outline:none}.search-input::placeholder{color:var(--text-muted)}.search-clear{background:var(--bg-elevated);border:none;width:24px;height:24px;border-radius:50%;color:var(--text-muted);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-clear:hover{background:var(--crimson-primary);color:#fff}.search-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.category-btn{display:flex;align-items:center;gap:.25rem;padding:.35rem .6rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .2s ease}.category-btn:hover{border-color:var(--text-muted);color:var(--text-secondary)}.category-btn.active{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.cat-icon{font-size:.9rem}.search-results{flex:1;overflow-y:auto;padding:.5rem;min-height:200px;max-height:50vh}.search-empty,.search-no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--text-muted)}.search-tips{margin-top:1.5rem;text-align:left}.search-tips h4{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem}.search-tips ul{list-style:none;padding:0}.search-tips li{padding:.25rem 0;font-size:.85rem}.search-tips kbd{display:inline-block;padding:.15rem .4rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:.75rem}.search-no-results .hint{margin-top:.5rem;font-size:.85rem}.results-count{padding:.5rem .75rem;font-size:.8rem;color:var(--text-muted);border-bottom:1px solid var(--border-color);margin-bottom:.25rem}.search-result{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;transition:all .15s ease}.search-result:hover,.search-result.selected{background:var(--bg-elevated)}.search-result.selected{border-left:3px solid var(--gold-primary)}.result-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:8px}.result-content{flex:1;min-width:0}.result-title{color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem;font-size:.8rem}.result-type{color:var(--gold-primary);font-weight:500}.result-match{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:350px}.result-arrow{color:var(--text-muted);opacity:0;transition:opacity .15s ease}.search-result:hover .result-arrow,.search-result.selected .result-arrow{opacity:1}.search-footer{padding:.75rem 1rem;border-top:1px solid var(--border-color);background:var(--bg-elevated);text-align:center}.keyboard-hint{font-size:.8rem;color:var(--text-muted)}.keyboard-hint kbd{display:inline-block;padding:.15rem .4rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:.75rem;margin:0 .15rem}.backstory-generator-modal{max-width:800px;width:95%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.backstory-generator-modal h2{margin:0 0 1rem;font-size:1.25rem}.backstory-mode-selector{display:flex;gap:.35rem;margin-bottom:1rem}.backstory-mode-selector .mode-button{flex:1;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;font-size:.85rem}.backstory-mode-selector .mode-button:hover:not(:disabled){border-color:var(--text-muted);color:var(--text-secondary)}.backstory-mode-selector .mode-button.active{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.backstory-mode-selector .mode-button:disabled{opacity:.5;cursor:not-allowed}.backstory-params{margin-bottom:.75rem}.backstory-params .form-row{gap:.75rem}.backstory-params .form-group{margin-bottom:.5rem}.backstory-params .form-group label{font-size:.8rem;margin-bottom:.25rem}.backstory-params .form-group input{padding:.5rem .75rem;font-size:.9rem}.backstory-style-options{background:var(--bg-elevated);border-radius:6px;padding:.75rem;margin-bottom:.75rem}.backstory-style-options .form-row{gap:.75rem}.backstory-style-options .form-group{margin-bottom:.5rem}.backstory-style-options .form-group label{font-size:.8rem;margin-bottom:.25rem}.backstory-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;margin:.5rem 0}.backstory-checkboxes label{display:flex;align-items:center;gap:.4rem;color:var(--text-secondary);font-size:.85rem;cursor:pointer}.backstory-checkboxes input[type=checkbox]{width:14px;height:14px;accent-color:var(--gold-primary)}.generate-btn{width:100%;padding:.75rem;font-size:1rem;margin-top:.5rem}.generated-backstory-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.generated-backstory-section h3{margin-bottom:.75rem;color:var(--gold-primary);font-size:1rem}.backstory-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:1rem;max-height:300px;overflow-y:auto;white-space:pre-wrap;line-height:1.6;color:var(--text-secondary);font-size:.9rem}.backstory-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.backstory-actions .action-button{flex:1;min-width:120px;padding:.5rem .75rem;font-size:.85rem}.guided-mode-intro{display:flex;justify-content:space-between;align-items:center;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:6px;padding:.5rem .75rem;margin-bottom:.75rem}.guided-mode-intro p{margin:0;color:var(--text-secondary);font-size:.8rem}.answered-count{background:var(--gold-primary);color:var(--bg-primary);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;white-space:nowrap}.guided-questionnaire{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;max-height:320px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:6px}.question-category{background:var(--bg-elevated)}.question-category:not(:last-child){border-bottom:1px solid var(--border-subtle)}.category-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:var(--bg-card);border:none;color:var(--text-primary);cursor:pointer;transition:background .2s ease;font-size:.9rem}.category-header:hover{background:var(--bg-glass-light)}.category-header.expanded{border-bottom:1px solid var(--border-subtle)}.category-name{font-weight:600;color:var(--gold-primary);font-size:.85rem}.category-progress{font-size:.7rem;color:var(--text-muted);background:var(--bg-elevated);padding:.15rem .4rem;border-radius:var(--radius-sm)}.category-chevron{font-size:.65rem;color:var(--text-muted);margin-left:.5rem}.category-questions{padding:.75rem;display:flex;flex-direction:column;gap:.75rem;background:var(--bg-elevated)}.guided-question{display:flex;flex-direction:column;gap:.15rem}.guided-question label{color:var(--text-primary);font-weight:500;font-size:.85rem}.question-hint{color:var(--text-muted);font-size:.75rem;font-style:italic;margin-bottom:.2rem}.guided-question textarea{width:100%;padding:.5rem .6rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-primary);font-size:.85rem;resize:vertical;min-height:60px;transition:border-color .2s ease}.guided-question textarea:focus{outline:none;border-color:var(--gold-primary)}.guided-question textarea::placeholder{color:var(--text-muted);font-size:.8rem}.backstory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.backstory-header h3{margin:0;font-size:.95rem}.version-selector{display:flex;align-items:center;gap:.4rem}.version-selector label{font-size:.8rem;color:var(--text-muted)}.version-selector select{padding:.25rem .5rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-secondary);font-size:.8rem}.edit-prompt-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.edit-btn{position:relative;padding:.5rem .75rem;font-size:.85rem}.edit-limit-badge{margin-left:.4rem;padding:.1rem .35rem;background:#8b5cf633;color:#a78bfa;font-size:.65rem;font-weight:600;border-radius:3px;text-transform:uppercase}.edit-section{background:var(--bg-elevated);border-radius:6px;padding:.75rem;margin-top:.75rem}.edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.edit-header h4{margin:0;color:var(--text-primary);font-size:.9rem}.free-edit-notice{font-size:.75rem;color:var(--success);background:#56ab2f26;padding:.15rem .5rem;border-radius:var(--radius-sm)}.pro-edit-notice{font-size:.75rem;color:#a78bfa;background:#8b5cf626;padding:.15rem .5rem;border-radius:var(--radius-sm)}.edit-request-input{width:100%;padding:.5rem .6rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-primary);font-size:.85rem;resize:vertical;margin-bottom:.5rem;min-height:60px}.edit-request-input:focus{outline:none;border-color:var(--gold-primary)}.edit-actions{display:flex;gap:.4rem}.edit-actions .action-button{flex:1;padding:.4rem .6rem;font-size:.85rem}@media(max-width:600px){.backstory-generator-modal{max-width:100%;padding:1rem}.backstory-mode-selector{flex-wrap:wrap}.backstory-mode-selector .mode-button{flex:1 1 45%;min-width:0}.guided-mode-intro{flex-direction:column;gap:.5rem;text-align:center}.guided-questionnaire{max-height:250px}.backstory-content{max-height:200px}.backstory-actions{flex-direction:column}.backstory-actions .action-button{min-width:100%}}.campaign-planner-modal{max-width:850px;width:95%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.campaign-planner-modal h2{margin:0 0 1rem;font-size:1.25rem}.planner-mode-selector{display:flex;gap:.35rem;margin-bottom:1rem}.planner-mode-selector .mode-button{flex:1;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;font-size:.85rem}.planner-mode-selector .mode-button:hover{border-color:var(--text-muted);color:var(--text-secondary)}.planner-mode-selector .mode-button.active{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.planner-params{margin-bottom:.75rem}.planner-params .form-row{gap:.75rem}.planner-params .form-group{margin-bottom:.5rem}.planner-params .form-group label{font-size:.8rem;margin-bottom:.25rem}.planner-params .form-group input,.planner-params .form-group select{padding:.5rem .75rem;font-size:.9rem}.template-selection{margin-bottom:.75rem}.template-selection>label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.template-card{display:flex;flex-direction:column;padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer;transition:all .2s ease;text-align:left}.template-card:hover{border-color:var(--gold-primary);background:var(--bg-elevated)}.template-card.selected{border-color:var(--gold-primary);background:#d4af371a}.template-card strong{font-size:.85rem;color:var(--text-primary);margin-bottom:.15rem}.template-card span{font-size:.75rem;color:var(--text-muted)}.output-type-selection{margin-bottom:.75rem}.output-type-selection>label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.output-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.4rem}.output-type-btn{display:flex;flex-direction:column;padding:.5rem .6rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:5px;cursor:pointer;transition:all .2s ease;text-align:left}.output-type-btn:hover{border-color:var(--text-muted)}.output-type-btn.selected{border-color:var(--gold-primary);background:#d4af371a}.output-type-btn strong{font-size:.8rem;color:var(--text-primary)}.output-type-btn span{font-size:.7rem;color:var(--text-muted)}.generated-content-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.content-header h3{margin:0;font-size:.95rem;color:var(--gold-primary)}.generated-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:1rem;max-height:300px;overflow-y:auto;white-space:pre-wrap;line-height:1.6;color:var(--text-secondary);font-size:.9rem}.content-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.content-actions .action-button{flex:1;min-width:120px;padding:.5rem .75rem;font-size:.85rem}@media(max-width:600px){.campaign-planner-modal{max-width:100%;padding:1rem}.planner-mode-selector{flex-wrap:wrap}.planner-mode-selector .mode-button{flex:1 1 30%;min-width:0}.template-grid{grid-template-columns:1fr}.output-type-grid{grid-template-columns:1fr 1fr}.generated-content{max-height:200px}.content-actions{flex-direction:column}.content-actions .action-button{min-width:100%}}.plot-hook-modal{max-width:900px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.plot-hook-modal h2{margin:0;color:var(--gold-primary)}.plot-hook-body{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;padding-right:.5rem}.plot-hook-config{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem}.config-section{margin-bottom:1rem}.config-section:last-child{margin-bottom:0}.config-label{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.entity-count{font-weight:400;color:var(--text-muted);font-size:.75rem}.hook-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.hook-type-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.6rem .4rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.hook-type-btn:hover{border-color:var(--border-medium);background:var(--bg-glass-light)}.hook-type-btn.active{border-color:var(--gold-primary);background:#f6d3651a}.hook-type-icon{font-size:1.25rem}.hook-type-label{font-size:.7rem;color:var(--text-secondary)}.hook-type-btn.active .hook-type-label{color:var(--gold-primary);font-weight:600}.config-row{display:flex;gap:1rem;margin-bottom:1rem}.config-row .config-section{flex:1;margin-bottom:0}.complexity-options{display:flex;gap:.5rem}.complexity-btn{flex:1;padding:.5rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.complexity-btn:hover{border-color:var(--border-medium)}.complexity-btn.active{border-color:var(--gold-primary);background:#f6d3651a;color:var(--gold-primary)}.tone-select,.count-select{width:100%;padding:.5rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.entity-selector{position:relative}.entity-search{width:100%;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.entity-search:focus{outline:none;border-color:var(--gold-primary)}.entity-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-sm);max-height:200px;overflow-y:auto;z-index:10;margin-top:2px}.entity-result{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem .75rem;background:transparent;border:none;border-bottom:1px solid var(--border-subtle);cursor:pointer;text-align:left}.entity-result:last-child{border-bottom:none}.entity-result:hover{background:var(--bg-elevated)}.entity-result.selected{background:#f6d3651a}.entity-result .entity-name{color:var(--text-primary);font-size:.85rem}.entity-result .entity-type{color:var(--text-muted);font-size:.7rem}.selected-entities{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.selected-entity-tag{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#f6d36526;border:1px solid var(--gold-primary);border-radius:var(--radius-xs);color:var(--gold-light);font-size:.75rem}.selected-entity-tag button{background:none;border:none;color:var(--gold-light);cursor:pointer;padding:0;margin-left:.25rem;font-size:.9rem}.custom-prompt{width:100%;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;resize:vertical;min-height:50px}.custom-prompt:focus{outline:none;border-color:var(--gold-primary)}.btn-generate-hooks{width:100%;padding:.85rem 1.5rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-sm);color:var(--bg-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem}.btn-generate-hooks:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--glow-gold)}.btn-generate-hooks:disabled{opacity:.7;cursor:not-allowed}.btn-generate-hooks .spinner{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.generated-hooks{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem}.generated-hooks h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.1rem}.hooks-list{display:flex;flex-direction:column;gap:1rem}.hook-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:1rem;transition:all var(--transition-fast)}.hook-card:hover{border-color:var(--border-medium)}.hook-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.hook-icon{font-size:1.25rem}.hook-title{flex:1;margin:0;font-size:1rem;color:var(--gold-primary)}.hook-type-badge{padding:.2rem .5rem;background:var(--bg-glass);border-radius:var(--radius-xs);font-size:.7rem;color:var(--text-muted);text-transform:capitalize}.hook-section{margin-bottom:.75rem}.hook-section strong{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.hook-section p{margin:0;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.hook-section.dm-notes{background:#8b7cf71a;border:1px dashed var(--purple-primary);border-radius:var(--radius-xs);padding:.75rem}.hook-section.dm-notes strong{color:var(--purple-light)}.hook-section.dm-notes p{color:var(--text-primary)}.hook-entities{display:flex;flex-wrap:wrap;gap:.25rem}.hook-entity-tag{padding:.15rem .4rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xs);font-size:.75rem;color:var(--text-secondary)}.hook-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.hook-detail{font-size:.85rem;color:var(--text-secondary)}.hook-detail strong{display:inline;color:var(--text-muted)}.hook-actions{display:flex;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.btn-copy-hook,.btn-save-quest{padding:.4rem .75rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xs);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.btn-copy-hook:hover,.btn-save-quest:hover{border-color:var(--border-medium);color:var(--text-primary)}.btn-save-quest.saved{background:#56ab2f33;border-color:var(--success);color:var(--success)}.campaign-context-info{margin-top:.5rem}.campaign-context-info details{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.campaign-context-info summary{padding:.75rem 1rem;cursor:pointer;font-size:.85rem;color:var(--text-secondary)}.campaign-context-info summary:hover{color:var(--text-primary)}.context-preview{padding:0 1rem 1rem;font-size:.8rem}.context-preview p{margin:.25rem 0;color:var(--text-muted)}.context-preview .context-note{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-subtle);color:var(--text-secondary);font-style:italic}.plot-hook-config .error-message{background:#ef444426;border:1px solid var(--error);color:var(--error);padding:.75rem;border-radius:var(--radius-sm);font-size:.85rem;margin-top:.75rem}@media(max-width:768px){.plot-hook-modal{max-width:100%;margin:.5rem}.hook-type-grid{grid-template-columns:repeat(2,1fr)}.config-row{flex-direction:column;gap:.75rem}.complexity-options,.hook-actions{flex-direction:column}}.encounter-builder-modal{max-width:1100px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.encounter-builder-modal h2{margin:0 0 1rem;color:var(--gold-primary)}.encounter-tabs{display:flex;gap:0;background:var(--bg-secondary);border-radius:8px;overflow:hidden;margin-bottom:1rem}.encounter-tabs .tab-btn{flex:1;padding:.75rem 1rem;background:transparent;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:all .2s ease}.encounter-tabs .tab-btn:hover{background:var(--bg-glass-light);color:var(--text-primary)}.encounter-tabs .tab-btn.active{background:var(--gold-primary);color:var(--bg-primary);font-weight:600}.party-config-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-bottom:1rem}.party-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.party-config-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.toggle-label input{width:16px;height:16px}.simple-party-config{display:flex;gap:1.5rem}.simple-party-config .form-group{display:flex;align-items:center;gap:.5rem}.simple-party-config label{font-size:.85rem;color:var(--text-secondary)}.simple-party-config input{width:60px;padding:.4rem .5rem;font-size:.9rem;text-align:center}.detailed-party-config{display:flex;flex-direction:column;gap:.5rem}.party-members-list{display:flex;flex-direction:column;gap:.5rem;max-height:150px;overflow-y:auto}.party-member-row{display:flex;gap:.5rem;align-items:center}.party-member-row input[type=text]{flex:1;padding:.4rem .5rem;font-size:.85rem}.party-member-row input[type=number]{width:50px;padding:.4rem;font-size:.85rem;text-align:center}.remove-member-btn{width:24px;height:24px;padding:0;background:#ef444433;border:none;border-radius:4px;color:#ef4444;cursor:pointer;font-size:.8rem}.remove-member-btn:hover{background:#ef444466}.add-member-btn{padding:.5rem;background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:all .2s ease}.add-member-btn:hover{background:var(--bg-glass-light);border-color:var(--gold-primary);color:var(--gold-primary)}.xp-thresholds{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color);flex-wrap:wrap}.xp-thresholds .threshold{padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600}.xp-thresholds .threshold.easy{background:#10b98133;color:#10b981}.xp-thresholds .threshold.medium{background:#3b82f633;color:#3b82f6}.xp-thresholds .threshold.hard{background:#f59e0b33;color:#f59e0b}.xp-thresholds .threshold.deadly{background:#ef444433;color:#ef4444}.encounter-builder-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;flex:1;overflow:hidden}.monster-search-panel{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;overflow:hidden}.monster-search-panel h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary)}.monster-filters{display:flex;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.monster-search-input{flex:1;min-width:150px;padding:.5rem .75rem;font-size:.9rem}.monster-filters select{padding:.5rem;font-size:.85rem;min-width:100px}.monster-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.monster-list-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:6px;cursor:pointer;transition:all .15s ease}.monster-list-item:hover{background:var(--bg-glass-light);transform:translate(3px)}.monster-list-info{display:flex;flex-direction:column;gap:.15rem}.monster-list-info .monster-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.monster-list-info .monster-details{font-size:.75rem;color:var(--text-muted)}.add-monster-btn{width:28px;height:28px;padding:0;background:var(--gold-primary);border:none;border-radius:50%;color:var(--bg-primary);font-size:1.1rem;font-weight:700;cursor:pointer;opacity:0;transition:opacity .15s ease}.monster-list-item:hover .add-monster-btn{opacity:1}.monster-list-more{padding:.75rem;text-align:center;color:var(--text-muted);font-size:.85rem;background:var(--bg-secondary);border-radius:6px}.selected-monsters-panel{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;overflow:hidden}.encounter-header{margin-bottom:.75rem}.encounter-name-input{width:100%;padding:.75rem;font-size:1rem;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary)}.encounter-name-input::placeholder{color:var(--text-muted)}.encounter-difficulty{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:8px;margin-bottom:.75rem}.encounter-difficulty.none{background:var(--bg-secondary);border:1px dashed var(--border-color)}.encounter-difficulty.trivial{background:#9ca3af33;border:1px solid rgba(156,163,175,.3)}.encounter-difficulty.easy{background:#10b98126;border:1px solid rgba(16,185,129,.3)}.encounter-difficulty.medium{background:#3b82f626;border:1px solid rgba(59,130,246,.3)}.encounter-difficulty.hard{background:#f59e0b26;border:1px solid rgba(245,158,11,.3)}.encounter-difficulty.deadly{background:#ef444426;border:1px solid rgba(239,68,68,.3)}.difficulty-rating{display:flex;align-items:center;gap:.5rem}.rating-label{font-size:.85rem;color:var(--text-muted)}.rating-value{font-weight:700;font-size:1rem;text-transform:uppercase}.encounter-difficulty.trivial .rating-value{color:#9ca3af}.encounter-difficulty.easy .rating-value{color:#10b981}.encounter-difficulty.medium .rating-value{color:#3b82f6}.encounter-difficulty.hard .rating-value{color:#f59e0b}.encounter-difficulty.deadly .rating-value{color:#ef4444}.difficulty-xp{display:flex;gap:1rem;font-size:.8rem;color:var(--text-secondary)}.difficulty-xp .multiplier{color:var(--gold-primary)}.selected-monsters-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.no-monsters{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.selected-monster-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px}.monster-count-controls{display:flex;align-items:center;gap:.25rem}.monster-count-controls button{width:24px;height:24px;padding:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:.9rem}.monster-count-controls button:hover{background:var(--gold-primary);color:var(--bg-primary);border-color:var(--gold-primary)}.monster-count{width:24px;text-align:center;font-weight:600;color:var(--gold-primary)}.selected-monster-card .monster-info{flex:1;display:flex;flex-direction:column;gap:.15rem}.selected-monster-card .monster-name{font-weight:500;color:var(--text-primary)}.selected-monster-card .monster-stats{font-size:.75rem;color:var(--text-muted)}.remove-all-btn{width:24px;height:24px;padding:0;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem}.remove-all-btn:hover{color:#ef4444}.encounter-notes{width:100%;padding:.75rem;font-size:.9rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);resize:vertical;min-height:60px;margin-bottom:.75rem}.encounter-actions{display:flex;gap:.75rem}.encounter-actions button{flex:1;padding:.75rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.encounter-actions .clear-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.encounter-actions .clear-btn:hover:not(:disabled){background:#ef444433;border-color:#ef4444;color:#ef4444}.encounter-actions .save-btn{background:var(--gold-primary);border:none;color:var(--bg-primary)}.encounter-actions .save-btn:hover:not(:disabled){background:var(--gold-hover)}.encounter-actions button:disabled{opacity:.5;cursor:not-allowed}.random-encounter-tab{overflow-y:auto;padding:.5rem}.random-config{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem;margin-bottom:1rem}.random-config .form-group{margin-bottom:1.25rem}.random-config .form-group:last-of-type{margin-bottom:1.5rem}.random-config label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.environment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.environment-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease}.environment-btn:hover{background:var(--bg-glass-light)}.environment-btn.active{border-color:var(--gold-primary);background:#d4af371a}.env-icon{font-size:1.5rem}.env-name{font-size:.75rem;color:var(--text-secondary)}.environment-btn.active .env-name{color:var(--gold-primary);font-weight:600}.difficulty-selector{display:flex;gap:.5rem}.difficulty-btn{flex:1;padding:.75rem;background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.difficulty-btn.easy{color:#10b981}.difficulty-btn.medium{color:#3b82f6}.difficulty-btn.hard{color:#f59e0b}.difficulty-btn.deadly{color:#ef4444}.difficulty-btn.active{border-color:currentColor}.difficulty-btn.easy.active{background:#10b98126}.difficulty-btn.medium.active{background:#3b82f626}.difficulty-btn.hard.active{background:#f59e0b26}.difficulty-btn.deadly.active{background:#ef444426}.generate-btn{width:100%;padding:1rem;background:var(--gold-primary);border:none;border-radius:8px;color:var(--bg-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.generate-btn:hover{background:var(--gold-hover);transform:translateY(-1px)}.generated-preview{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.generated-preview h3{margin:0 0 .75rem;color:var(--text-primary)}.generated-preview .encounter-difficulty{margin-bottom:1rem}.preview-monsters{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.preview-monster{display:flex;justify-content:space-between;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:6px;font-size:.9rem}.preview-monster span:first-child{color:var(--text-primary)}.preview-monster span:last-child{color:var(--text-muted)}.preview-actions{display:flex;gap:.5rem;flex-wrap:wrap}.preview-actions button{flex:1;min-width:120px;padding:.75rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.regenerate-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.regenerate-btn:hover{border-color:var(--gold-primary);color:var(--gold-primary)}.edit-btn{background:#3b82f633;border:1px solid rgba(59,130,246,.3);color:#3b82f6}.edit-btn:hover{background:#3b82f64d}.templates-tab{overflow-y:auto;padding:.5rem}.no-templates{padding:3rem;text-align:center;color:var(--text-muted)}.no-templates p{margin:.5rem 0}.templates-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.template-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:10px;padding:1rem;cursor:pointer;transition:all .2s ease;position:relative}.template-card:hover{border-color:var(--gold-primary);transform:translateY(-2px)}.template-card.selected{border-color:var(--gold-primary);background:#d4af370d}.template-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.template-header h4{margin:0;color:var(--text-primary);font-size:1rem}.difficulty-badge{padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.difficulty-badge.trivial{background:#9ca3af33;color:#9ca3af}.difficulty-badge.easy{background:#10b98133;color:#10b981}.difficulty-badge.medium{background:#3b82f633;color:#3b82f6}.difficulty-badge.hard{background:#f59e0b33;color:#f59e0b}.difficulty-badge.deadly{background:#ef444433;color:#ef4444}.template-details{display:flex;gap:1rem;font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}.template-notes{font-size:.85rem;color:var(--text-secondary);margin:.5rem 0;line-height:1.4}.template-monsters{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem}.template-monster-tag{padding:.2rem .5rem;background:var(--bg-secondary);border-radius:4px;font-size:.75rem;color:var(--text-secondary)}.template-monster-more{padding:.2rem .5rem;color:var(--text-muted);font-size:.75rem}.load-template-btn{width:100%;padding:.5rem;background:var(--gold-primary);border:none;border-radius:6px;color:var(--bg-primary);font-weight:600;cursor:pointer;opacity:0;transition:all .2s ease}.template-card:hover .load-template-btn{opacity:1}.treasure-tab{overflow-y:auto;padding:.5rem}.treasure-config{display:flex;align-items:flex-end;gap:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-bottom:1rem;flex-wrap:wrap}.treasure-config .form-group{display:flex;flex-direction:column;gap:.25rem}.treasure-config .form-group label{font-size:.85rem;color:var(--text-secondary)}.treasure-config input[type=number]{width:80px;padding:.5rem;font-size:1rem;text-align:center}.treasure-config .checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);padding:.5rem 0}.treasure-config .generate-btn{flex:1;min-width:150px;padding:.75rem 1.5rem}.treasure-result{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.treasure-result h3{margin:0 0 .5rem;color:var(--gold-primary)}.treasure-total{padding:.75rem 1rem;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:6px;color:var(--gold-primary);font-weight:600;margin-bottom:1rem;text-align:center}.treasure-section{margin-bottom:1rem}.treasure-section h4{margin:0 0 .5rem;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);padding-bottom:.25rem}.coins-list{display:flex;flex-wrap:wrap;gap:.5rem}.coin-amount{padding:.4rem .75rem;border-radius:6px;font-weight:600;font-size:.9rem}.coin-amount.cp{background:#b4530933;color:#b45309}.coin-amount.sp{background:#9ca3af33;color:#9ca3af}.coin-amount.ep{background:#6b728033;color:#6b7280}.coin-amount.gp{background:#d4af3733;color:var(--gold-primary)}.coin-amount.pp{background:#a78bfa33;color:#a78bfa}.gems-list,.art-list{display:flex;flex-direction:column;gap:.35rem}.treasure-item{display:flex;justify-content:space-between;padding:.4rem .75rem;background:var(--bg-secondary);border-radius:6px;font-size:.9rem}.treasure-item .item-name{color:var(--text-primary)}.treasure-item .item-value{color:var(--gold-primary);font-weight:500}.magic-items-list{display:flex;flex-direction:column;gap:.75rem}.magic-item-card{padding:1rem;background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(139,92,246,.05) 100%);border:1px solid rgba(139,92,246,.2);border-radius:8px}.magic-item-card .item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.magic-item-card .item-name{font-weight:600;color:var(--text-primary)}.item-rarity{padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.item-rarity.common{background:#9ca3af33;color:#9ca3af}.item-rarity.uncommon{background:#10b98133;color:#10b981}.item-rarity.rare{background:#3b82f633;color:#3b82f6}.item-rarity.very-rare{background:#8b5cf633;color:#8b5cf6}.item-rarity.legendary{background:#f59e0b33;color:#f59e0b}.magic-item-card .item-type{font-size:.8rem;color:var(--text-muted);font-style:italic}.magic-item-card .item-desc{margin:.5rem 0;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.attunement-tag{display:inline-block;padding:.2rem .5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:4px;font-size:.75rem;color:#f87171}.treasure-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.treasure-actions button{flex:1;padding:.75rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-to-encounter-btn{background:#3b82f633;border:1px solid rgba(59,130,246,.3);color:#3b82f6}.add-to-encounter-btn:hover{background:#3b82f64d}@media(max-width:768px){.encounter-builder-layout{grid-template-columns:1fr}.monster-search-panel{max-height:300px}.environment-grid{grid-template-columns:repeat(4,1fr)}.difficulty-selector{flex-wrap:wrap}.difficulty-btn{flex:1 1 45%}.treasure-config{flex-direction:column;align-items:stretch}}.session-zero-modal{max-width:950px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.session-zero-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.session-zero-header h2{margin:0;color:var(--gold-primary);font-size:1.4rem}.session-zero-actions{display:flex;gap:.5rem;flex-wrap:wrap}.session-zero-actions button{padding:.5rem .85rem;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.session-zero-actions .summary-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.session-zero-actions .summary-btn:hover{border-color:var(--gold-primary);color:var(--gold-primary)}.session-zero-actions .export-btn{background:#3b82f633;border:1px solid rgba(59,130,246,.3);color:#3b82f6}.session-zero-actions .export-btn:hover{background:#3b82f64d}.session-zero-actions .save-btn{background:var(--gold-primary);border:none;color:var(--bg-primary)}.session-zero-actions .save-btn:hover{background:var(--gold-hover)}.session-zero-tabs{display:flex;gap:.25rem;background:var(--bg-secondary);border-radius:8px;padding:.25rem;margin-bottom:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.session-zero-tabs .tab-btn{flex:0 0 auto;padding:.6rem 1rem;background:transparent;border:none;border-radius:6px;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.session-zero-tabs .tab-btn:hover{background:var(--bg-glass-light);color:var(--text-primary)}.session-zero-tabs .tab-btn.active{background:var(--gold-primary);color:var(--bg-primary);font-weight:600}.session-zero-content{flex:1;overflow-y:auto;padding-right:.5rem}.section-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.safety-policies{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem}.policy-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem}.policy-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.policy-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:8px}.policy-header h4{margin:0;color:var(--text-primary)}.policy-card p{color:var(--text-secondary);font-size:.85rem;margin:0 0 1rem;line-height:1.5}.toggle-switch{display:flex;align-items:center;gap:.75rem;cursor:pointer}.toggle-switch input{display:none}.toggle-switch .slider{width:44px;height:24px;background:var(--bg-secondary);border-radius:12px;position:relative;transition:all .2s ease}.toggle-switch .slider:before{content:"";position:absolute;width:18px;height:18px;background:var(--text-muted);border-radius:50%;top:3px;left:3px;transition:all .2s ease}.toggle-switch input:checked+.slider{background:#10b98133}.toggle-switch input:checked+.slider:before{transform:translate(20px);background:#10b981}.toggle-switch .label{font-size:.9rem;color:var(--text-secondary)}.lines-veils-info{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;margin-bottom:1.5rem}.lines-veils-info h3{margin:0 0 1rem;color:var(--text-primary)}.lv-explanation{display:flex;flex-wrap:wrap;gap:1rem}.lv-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.setting-badge{padding:.25rem .75rem;border-radius:4px;font-weight:600;font-size:.75rem;text-transform:uppercase}.setting-badge.ok{background:#10b98133;color:#10b981}.setting-badge.veil{background:#f59e0b33;color:#f59e0b}.setting-badge.line{background:#ef444433;color:#ef4444}.safety-topics-section h4{margin:1.5rem 0 .75rem;color:var(--text-primary);font-size:.95rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.safety-topics-section h4:first-child{margin-top:0}.safety-topics-list{display:flex;flex-direction:column;gap:.5rem}.safety-topic-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:var(--bg-secondary);border-radius:6px;gap:.75rem}.topic-name{color:var(--text-primary);font-size:.9rem;flex:1;min-width:0;line-height:1.3}.topic-settings{display:flex;gap:.25rem;flex-shrink:0}.setting-btn{padding:.35rem .65rem;border:1px solid transparent;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease;background:var(--bg-card);color:var(--text-muted)}.setting-btn:hover{background:var(--bg-glass-light)}.setting-btn.ok.active{background:#10b98133;color:#10b981;border-color:#10b981}.setting-btn.veil.active{background:#f59e0b33;color:#f59e0b;border-color:#f59e0b}.setting-btn.line.active{background:#ef444433;color:#ef4444;border-color:#ef4444}.remove-topic-btn{width:24px;height:24px;padding:0;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem}.remove-topic-btn:hover{color:#ef4444}.add-custom-topic{display:flex;gap:.5rem;margin-top:1rem}.add-custom-topic input{flex:1;padding:.5rem .75rem;font-size:.9rem}.add-custom-topic button{padding:.5rem 1rem;background:var(--gold-primary);border:none;border-radius:6px;color:var(--bg-primary);font-weight:500;cursor:pointer}.add-custom-topic button:hover{background:var(--gold-hover)}.tone-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin-bottom:1.5rem}.tone-card{padding:1rem;background:var(--bg-card);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease}.tone-card:hover{border-color:var(--gold-primary)}.tone-card.selected{border-color:var(--gold-primary);background:#d4af371a}.tone-card h4{margin:0 0 .5rem;color:var(--text-primary);font-size:.95rem}.tone-card p{margin:0;color:var(--text-muted);font-size:.85rem;line-height:1.45}.tone-notes-section{margin-bottom:1.5rem}.tone-notes-section label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.tone-notes-section textarea{width:100%;padding:.75rem;font-size:.9rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);resize:vertical}.themes-section h3{margin:0 0 .5rem;color:var(--text-primary)}.themes-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.theme-tag{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:20px;color:#a78bfa;font-size:.85rem}.theme-tag button{width:18px;height:18px;padding:0;background:transparent;border:none;color:inherit;cursor:pointer;font-size:.9rem;opacity:.7}.theme-tag button:hover{opacity:1}.add-theme{display:flex;gap:.5rem}.add-theme input{flex:1;padding:.5rem .75rem;font-size:.9rem}.add-theme button{padding:.5rem 1rem;background:var(--gold-primary);border:none;border-radius:6px;color:var(--bg-primary);font-weight:500;cursor:pointer}.expectation-category{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;margin-bottom:1rem}.expectation-category h4{margin:0 0 1rem;color:var(--gold-primary);font-size:1rem}.expectation-items{display:flex;flex-direction:column;gap:1rem}.expectation-item{display:flex;flex-direction:column;gap:.35rem}.expectation-item label{color:var(--text-primary);font-size:.9rem}.expectation-item select,.expectation-item input[type=text]{padding:.5rem .75rem;font-size:.9rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary)}.slider-input{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.slider-input input[type=range]{flex:1;min-width:100px;height:6px;-webkit-appearance:none;background:var(--bg-secondary);border-radius:3px}.slider-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--gold-primary);border-radius:50%;cursor:pointer}.slider-label{font-size:.8rem;color:var(--text-muted);min-width:90px;line-height:1.3}.slider-label:last-child{text-align:right}.add-rule-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;margin-bottom:1.5rem}.add-rule-form .form-row{display:flex;gap:.75rem;margin-bottom:.75rem}.add-rule-form input[type=text]{flex:1;padding:.5rem .75rem;font-size:.9rem}.add-rule-form select{padding:.5rem .75rem;font-size:.9rem;min-width:150px}.add-rule-form textarea{width:100%;padding:.75rem;font-size:.9rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);resize:vertical;margin-bottom:.75rem}.add-rule-form button{padding:.75rem 1.5rem;background:var(--gold-primary);border:none;border-radius:6px;color:var(--bg-primary);font-weight:600;cursor:pointer}.add-rule-form button:disabled{opacity:.5;cursor:not-allowed}.house-rules-list{display:flex;flex-direction:column;gap:1.5rem}.rule-category h4{margin:0 0 .75rem;color:var(--gold-primary);font-size:.95rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.rule-card{background:var(--bg-secondary);border-radius:8px;padding:1rem;margin-bottom:.5rem}.rule-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.rule-header h5{margin:0;color:var(--text-primary)}.rule-actions{display:flex;gap:.5rem}.rule-actions button{padding:.25rem .5rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-muted);font-size:.75rem;cursor:pointer}.rule-actions button:hover{border-color:var(--gold-primary);color:var(--gold-primary)}.rule-card p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.rule-edit-form{display:flex;flex-direction:column;gap:.5rem}.rule-edit-form input,.rule-edit-form textarea{padding:.5rem .75rem;font-size:.9rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary)}.rule-edit-form button{align-self:flex-end;padding:.5rem 1rem;background:var(--gold-primary);border:none;border-radius:6px;color:var(--bg-primary);cursor:pointer}.no-rules{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.consent-agreement{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;margin-bottom:1.5rem}.consent-agreement h4{margin:0 0 1rem;color:var(--gold-primary)}.agreement-text{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin-bottom:1rem}.agreement-text p{margin:0 0 .5rem}.agreement-text ul{margin:0;padding-left:1.5rem}.agreement-text li{margin-bottom:.35rem}.consent-checkbox{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;cursor:pointer;color:var(--text-primary)}.consent-checkbox input{width:20px;height:20px}.signatures-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem}.signatures-section h4{margin:0 0 .5rem;color:var(--text-primary)}.signatures-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.signature-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:8px}.signature-name{color:var(--text-primary);font-weight:500}.signature-date{color:var(--text-muted);font-size:.85rem}.add-signature{display:flex;gap:.5rem}.add-signature input{flex:1;padding:.5rem .75rem;font-size:.9rem}.add-signature button{padding:.5rem 1rem;background:var(--gold-primary);border:none;border-radius:6px;color:var(--bg-primary);font-weight:500;cursor:pointer}@media(max-width:768px){.session-zero-modal{max-height:95vh}.session-zero-header{flex-direction:column;align-items:flex-start}.session-zero-header h2{font-size:1.2rem}.session-zero-actions{width:100%;justify-content:flex-start}.session-zero-tabs{overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.session-zero-tabs::-webkit-scrollbar{display:none}.safety-policies{grid-template-columns:1fr}.safety-topic-row{flex-wrap:wrap}.topic-name{flex:1 1 100%;margin-bottom:.5rem}.topic-settings{flex:1 1 100%;justify-content:flex-start}.tone-grid{grid-template-columns:1fr}.add-rule-form .form-row{flex-direction:column}.slider-input{flex-direction:column;align-items:stretch}.slider-label{text-align:left!important;min-width:auto}}.character-sheet-modal{max-width:900px;width:95%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;z-index:1100}.modal-overlay:has(.character-sheet-modal){z-index:1050}.character-sheet-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem;gap:1rem;flex-wrap:wrap;flex-shrink:0}.character-identity{display:flex;gap:1rem;align-items:center}.character-avatar{width:80px;height:80px;border-radius:8px;object-fit:cover;border:2px solid var(--gold-primary)}.character-name-section h2{margin:0 0 .25rem;color:var(--gold-primary)}.character-subtitle{margin:0;color:var(--text-primary);font-size:1rem}.character-meta{margin:.25rem 0 0;color:var(--text-secondary);font-size:.9rem}.character-sheet-actions{display:flex;gap:.5rem}.character-sheet-actions .action-btn{padding:.5rem 1rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s ease;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.character-sheet-actions .action-btn:hover{border-color:var(--gold-primary);color:var(--gold-primary)}.character-sheet-actions .action-btn.edit{background:#daa52026;border-color:var(--gold-primary);color:var(--gold-primary)}.character-sheet-actions .action-btn.save{background:var(--gold-primary);border-color:var(--gold-primary);color:var(--bg-primary)}.character-sheet-actions .action-btn.cancel{background:transparent}.character-sheet-tabs{display:flex;gap:.25rem;background:var(--bg-secondary);border-radius:8px;padding:.25rem;margin-bottom:1rem;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;flex-shrink:0;scrollbar-width:thin;scrollbar-color:var(--gold-primary) var(--bg-secondary)}.character-sheet-tabs::-webkit-scrollbar{height:4px}.character-sheet-tabs::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.character-sheet-tabs::-webkit-scrollbar-thumb{background:var(--gold-primary);border-radius:4px}.character-sheet-tabs .tab-btn{flex:0 0 auto;padding:.6rem 1rem;background:transparent;border:none;border-radius:6px;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.character-sheet-tabs .tab-btn:hover{background:var(--bg-glass-light);color:var(--text-primary)}.character-sheet-tabs .tab-btn.active{background:var(--gold-primary);color:var(--bg-primary);font-weight:600}.character-sheet-content{flex:1;overflow-y:auto;padding-right:.5rem}.ability-scores-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.75rem;margin-bottom:1.5rem}.ability-score-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:10px;padding:.75rem;text-align:center;transition:all .2s ease}.ability-score-card:hover{border-color:var(--gold-primary)}.ability-name{font-size:.75rem;font-weight:600;color:var(--gold-primary);margin-bottom:.25rem}.ability-score{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.ability-score-input{width:60px;font-size:1.25rem;font-weight:700;text-align:center;padding:.25rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary)}.ability-modifier{font-size:1.1rem;font-weight:600;color:var(--text-secondary);margin-top:.25rem}.stats-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.stat-group{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1rem}.stat-group h4{margin:0 0 .75rem;color:var(--gold-primary);font-size:.95rem}.stat-group p{margin:.5rem 0;font-size:.85rem;color:var(--text-secondary)}.stat-group strong{color:var(--text-primary)}.saves-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.save-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:var(--bg-secondary);border-radius:4px;font-size:.85rem}.save-item.proficient{background:#daa52026}.save-name{font-weight:600;color:var(--text-muted);min-width:30px}.save-value{color:var(--text-primary);font-weight:600}.proficiency-dot{color:var(--gold-primary);font-weight:700}.combat-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.combat-stat-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:10px;padding:1rem;text-align:center}.combat-stat-card.hp{border-color:#ef4444}.combat-stat-card.ac{border-color:#3b82f6}.combat-stat-card.initiative{border-color:#10b981}.combat-stat-card.speed{border-color:#f59e0b}.combat-stat-card.proficiency{border-color:var(--gold-primary)}.stat-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.temp-hp{font-size:.85rem;color:#3b82f6;margin-top:.25rem}.secondary-speed{font-size:.8rem;color:var(--text-secondary)}.hp-edit{display:flex;align-items:center;justify-content:center;gap:.5rem}.hp-edit input{width:60px;font-size:1.25rem;font-weight:700;text-align:center;padding:.25rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary)}.hit-dice-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1rem}.hit-dice-section h4{margin:0 0 .75rem;color:var(--gold-primary)}.hit-dice-list{display:flex;gap:.75rem;flex-wrap:wrap}.hit-die{padding:.5rem 1rem;background:var(--bg-secondary);border-radius:6px;font-weight:600;color:var(--text-primary)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.skill-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:6px;font-size:.85rem}.skill-item.proficient{background:#daa5201a}.skill-item.expertise{background:#daa52033;border:1px solid var(--gold-primary)}.skill-prof-indicator{width:16px;font-weight:700;color:var(--gold-primary)}.skill-modifier{font-weight:700;color:var(--text-primary);min-width:28px}.skill-name{flex:1;color:var(--text-primary)}.skill-ability{font-size:.75rem;color:var(--text-muted)}.skills-legend{display:flex;gap:1.5rem;margin-top:1rem;font-size:.8rem;color:var(--text-muted)}.features-list{display:flex;flex-direction:column;gap:.5rem}.feature-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px}.feature-item summary{padding:.75rem 1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:.75rem;min-width:0}.feature-item summary:hover{background:var(--bg-glass-light)}.feature-name{font-weight:600;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.feature-source{font-size:.8rem;color:var(--gold-primary);background:#daa52026;padding:.2rem .5rem;border-radius:4px;flex-shrink:0;white-space:nowrap}.feature-description{padding:0 1rem 1rem;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.currency-section{margin-bottom:1.5rem}.currency-section h4,.equipment-section h4{margin:0 0 .75rem;color:var(--gold-primary)}.currency-grid{display:flex;gap:.75rem;flex-wrap:wrap}.currency-item{display:flex;flex-direction:column;align-items:center;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;min-width:60px}.currency-item.gp{border-color:var(--gold-primary);background:#daa5201a}.currency-amount{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.currency-label{font-size:.75rem;color:var(--text-muted);font-weight:600}.equipment-list{display:flex;flex-direction:column;gap:.5rem}.equipment-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:6px;gap:.75rem;min-width:0}.equipment-item.equipped{background:#3b82f61a;border-left:3px solid #3b82f6}.equipment-item.magical{background:#8b5cf61a;border-left:3px solid #8b5cf6}.item-main{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;flex-wrap:wrap}.item-name{color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis}.equipped-badge,.attuned-badge{font-size:.7rem;padding:.15rem .4rem;border-radius:4px;font-weight:600}.equipped-badge{background:#3b82f633;color:#3b82f6}.attuned-badge{background:#8b5cf633;color:#8b5cf6}.item-damage{font-size:.85rem;color:var(--text-secondary)}.spellcasting-info{margin-bottom:1rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px}.spellcasting-class{color:var(--text-primary);font-size:.9rem}.spellcasting-class strong{color:var(--gold-primary)}.spell-slots{margin-bottom:1.5rem}.spell-slots h4{margin:0 0 .75rem;color:var(--gold-primary)}.slots-grid{display:flex;gap:.5rem;flex-wrap:wrap}.slot-item{display:flex;flex-direction:column;align-items:center;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:6px;min-width:50px}.slot-level{font-size:.7rem;color:var(--text-muted)}.slot-count{font-size:1rem;font-weight:700;color:var(--text-primary)}.spells-list{display:flex;flex-direction:column;gap:1rem}.spell-level-group h4{margin:0 0 .5rem;color:var(--gold-primary);font-size:.95rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.spells-at-level{display:flex;flex-direction:column;gap:.35rem}.spell-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px}.spell-item summary{padding:.5rem .75rem;cursor:pointer;display:flex;align-items:center;gap:.5rem}.spell-item summary:hover{background:var(--bg-glass-light)}.spell-name{flex:1;font-weight:500;color:var(--text-primary)}.prepared-badge,.concentration-badge,.ritual-badge{font-size:.65rem;padding:.15rem .35rem;border-radius:3px;font-weight:600}.prepared-badge{background:#10b98133;color:#10b981}.concentration-badge{background:#f59e0b33;color:#f59e0b}.ritual-badge{background:#8b5cf633;color:#8b5cf6}.spell-details{padding:.75rem;font-size:.85rem;color:var(--text-secondary);border-top:1px solid var(--border-color)}.spell-details p{margin:.25rem 0}.spell-description{margin-top:.75rem;line-height:1.5}.bio-tab{display:flex;flex-direction:column;gap:1rem}.bio-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.bio-section h4{margin:0 0 .5rem;color:var(--gold-primary);font-size:.95rem}.bio-section p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6;white-space:pre-wrap}.bio-section.backstory{background:#daa5200d}.no-character-sheet{padding:2rem;text-align:center}.empty-state{display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-icon{font-size:3rem}.empty-state h3{margin:0;color:var(--text-primary)}.empty-state p{margin:0;color:var(--text-secondary);max-width:400px}.empty-message{color:var(--text-muted);font-style:italic;text-align:center;padding:2rem}.import-guide-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001;padding:1rem}.import-guide-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;padding:1.5rem;position:relative}.import-guide-modal h3{margin:0 0 1.5rem;color:var(--gold-primary)}.import-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.import-step{display:flex;gap:1rem;align-items:flex-start}.step-number{width:32px;height:32px;border-radius:50%;background:var(--gold-primary);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.step-content{flex:1}.step-content h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1rem}.step-content p{margin:.25rem 0;color:var(--text-secondary);font-size:.9rem}.step-content code{display:block;background:var(--bg-secondary);padding:.5rem .75rem;border-radius:6px;font-family:monospace;font-size:.85rem;color:var(--text-primary);margin:.5rem 0;word-break:break-all}.step-note{font-size:.8rem;color:var(--text-muted);font-style:italic}.import-input-section{margin-top:1.5rem}.import-input-section label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.import-textarea{width:100%;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:monospace;font-size:.85rem;resize:vertical}.import-textarea:focus{outline:none;border-color:var(--gold-primary)}.import-error{margin-top:.75rem;padding:.75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:.9rem}.avatar-option{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:#daa5201a;border:1px solid rgba(218,165,32,.3);border-radius:6px;cursor:pointer;transition:all .2s ease}.avatar-option:hover{background:#daa52026;border-color:var(--gold-primary)}.avatar-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold-primary);cursor:pointer}.avatar-option span{color:var(--text-primary);font-size:.9rem}.import-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.import-button{padding:.6rem 1.25rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.import-button.primary{background:var(--gold-primary);border:none;color:var(--bg-primary)}.import-button.primary:hover:not(:disabled){background:var(--gold-hover)}.import-button:disabled{opacity:.5;cursor:not-allowed}.cancel-button{padding:.6rem 1.25rem;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-weight:500;cursor:pointer}.cancel-button:hover{border-color:var(--text-secondary);color:var(--text-primary)}.import-privacy-note{margin-top:1.5rem;padding:.75rem;background:#3b82f61a;border-radius:6px;font-size:.85rem;color:var(--text-secondary)}.import-privacy-note strong{color:#3b82f6}.entity-character-sheet-btn{background:#8b5cf626;border:1px solid rgba(139,92,246,.3);color:#a78bfa;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.entity-character-sheet-btn:hover{background:#8b5cf640;border-color:#a78bfa}.action-button.ddb-import{background:#8b5cf626;border-color:#8b5cf64d;color:#a78bfa}.action-button.ddb-import:hover{background:#8b5cf640;border-color:#a78bfa}@media(max-width:768px){.character-sheet-header{flex-direction:column}.ability-scores-grid{grid-template-columns:repeat(3,1fr)}.saves-grid,.combat-stats-grid{grid-template-columns:repeat(2,1fr)}.skills-grid{grid-template-columns:1fr}.character-sheet-tabs{-ms-overflow-style:none;scrollbar-width:none}.character-sheet-tabs::-webkit-scrollbar{display:none}}.speaker-identification-modal{max-width:900px;max-height:85vh;overflow-y:auto}.speaker-identification-modal .modal-subtitle{color:var(--text-secondary);margin-bottom:1.5rem}.speaker-id-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-subtle);padding-bottom:1rem}.speaker-id-tabs .tab-btn{padding:.6rem 1.2rem;background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.speaker-id-tabs .tab-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.speaker-id-tabs .tab-btn.active{background:var(--gradient-gold);color:var(--bg-primary);border-color:transparent;font-weight:600}.voice-profiles-section .section-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.voice-profiles-grid{display:flex;flex-direction:column;gap:1rem}.voice-profile-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.profile-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:var(--bg-primary);flex-shrink:0}.profile-info{flex:1;min-width:0}.profile-name{font-weight:600;color:var(--text-primary)}.profile-player{font-size:.85rem;color:var(--text-muted)}.profile-status{font-size:.8rem;margin-top:.25rem}.profile-status.recorded{color:var(--success)}.profile-actions{display:flex;gap:.5rem;align-items:center}.btn-record{padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem}.btn-record:hover{background:var(--bg-secondary);border-color:var(--gold-primary)}.btn-record:disabled{opacity:.5;cursor:not-allowed}.btn-recording{padding:.5rem 1rem;background:var(--crimson-primary);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.85rem;animation:pulse 1.5s infinite}.recording-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.btn-delete-profile{width:28px;height:28px;padding:0;background:transparent;border:1px solid var(--border-medium);border-radius:50%;color:var(--text-muted);cursor:pointer;font-size:1.1rem;line-height:1;transition:all var(--transition-fast)}.btn-delete-profile:hover{background:var(--crimson-primary);border-color:var(--crimson-primary);color:#fff}.no-transcript-message,.start-identification{text-align:center;padding:3rem 1rem}.start-identification p{color:var(--text-secondary);max-width:500px;margin:0 auto 1.5rem;line-height:1.6}.btn-identify{padding:1rem 2rem;font-size:1.1rem}.identification-progress{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;color:var(--text-secondary)}.progress-spinner{width:24px;height:24px;border:3px solid var(--border-medium);border-top-color:var(--gold-primary);border-radius:50%;animation:spin 1s linear infinite}.identification-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;padding:1rem;background:var(--bg-elevated);border-radius:var(--radius-md);margin-bottom:1.5rem}.confidence-filter{display:flex;align-items:center;gap:.75rem;flex:1}.confidence-filter label{color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.confidence-filter input[type=range]{flex:1;max-width:150px}.segments-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;margin-bottom:1.5rem;padding-right:.5rem}.segment-item{padding:1rem;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.segment-item.confirmed{border-color:var(--success);background:#56ab2f0d}.segment-item.low-confidence{opacity:.7;border-color:var(--warning)}.segment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.segment-speaker{padding:.25rem .75rem;border-left:3px solid;border-radius:0 var(--radius-xs) var(--radius-xs) 0;font-weight:600;font-size:.9rem}.speaker-name-editable{cursor:pointer}.speaker-name-editable:hover{text-decoration:underline}.segment-speaker select{background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-xs);color:var(--text-primary);padding:.25rem .5rem;font-size:.85rem}.segment-meta{display:flex;align-items:center;gap:.5rem}.confidence-badge{padding:.2rem .5rem;border-radius:var(--radius-xs);font-size:.75rem;font-weight:600;cursor:help}.confidence-badge.high{background:#56ab2f33;color:var(--success)}.confidence-badge.medium{background:#f59e0b33;color:var(--warning)}.confidence-badge.low{background:#ef444433;color:var(--error)}.btn-confirm-segment{width:24px;height:24px;padding:0;background:var(--bg-card);border:1px solid var(--border-medium);border-radius:50%;color:var(--success);cursor:pointer;font-size:.85rem;transition:all var(--transition-fast)}.btn-confirm-segment:hover{background:var(--success);color:#fff;border-color:var(--success)}.confirmed-badge{color:var(--success);font-size:.9rem}.segment-text{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.speaker-stats{background:var(--bg-elevated);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.5rem}.speaker-stats h4{margin-bottom:1rem;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.speaker-stats .stat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-card);border-radius:var(--radius-sm);border-left:3px solid}.speaker-stats .stat-name{font-weight:600;color:var(--text-primary)}.speaker-stats .stat-values{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted)}@media(max-width:768px){.speaker-identification-modal{max-width:100%;margin:.5rem;max-height:95vh}.identification-controls{flex-direction:column;align-items:stretch}.confidence-filter{flex-wrap:wrap}.stats-grid{grid-template-columns:1fr}}.pro-badge,.guild-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:var(--radius-xs);font-size:.65rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pro-badge{background:linear-gradient(135deg,#f6d365,#fda085);color:var(--bg-primary)}.guild-badge{background:linear-gradient(135deg,#8b7cf7,#667eea);color:#fff}.pro-badge.compact,.guild-badge.compact{padding:.1rem .35rem;font-size:.6rem}.usage-indicator{display:flex;flex-direction:column;gap:.4rem;padding:.75rem;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.usage-indicator.low{border-color:var(--warning);background:#f59e0b1a}.usage-indicator.empty{border-color:var(--error);background:#ef44441a}.usage-text{display:flex;justify-content:space-between;align-items:center}.usage-label{color:var(--text-secondary);font-size:.85rem}.usage-count{font-weight:600;color:var(--text-primary)}.usage-bar{height:4px;background:var(--bg-card);border-radius:2px;overflow:hidden}.usage-bar-fill{height:100%;background:var(--gradient-gold);border-radius:2px;transition:width var(--transition-base)}.usage-indicator.low .usage-bar-fill{background:var(--warning)}.usage-indicator.empty .usage-bar-fill{background:var(--error)}.usage-upgrade-btn{padding:.4rem .75rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-xs);color:var(--bg-primary);font-size:.8rem;font-weight:600;cursor:pointer;margin-top:.25rem}.inline-upgrade-prompt{background:linear-gradient(135deg,#f6d3651a,#fda0851a);border:1px solid rgba(246,211,101,.3);border-radius:var(--radius-md);padding:1rem;margin:1rem 0}.upgrade-prompt-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.upgrade-prompt-icon{font-size:1.5rem}.upgrade-prompt-text{flex:1;min-width:200px}.upgrade-prompt-text h4{margin:0 0 .25rem;color:var(--text-primary);font-size:.95rem}.upgrade-prompt-text p{margin:0;color:var(--text-secondary);font-size:.85rem}.upgrade-prompt-actions{display:flex;gap:.5rem}.btn-upgrade-prompt{padding:.5rem 1rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-sm);color:var(--bg-primary);font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-upgrade-prompt:hover{transform:translateY(-1px);box-shadow:var(--glow-gold)}.btn-dismiss{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer}.btn-dismiss:hover{background:var(--bg-elevated)}.feature-gate{position:relative}.feature-gate-overlay{position:absolute;inset:0;background:#0a0a0fe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-md)}.feature-gate-content{text-align:center;padding:2rem}.feature-gate-content h4{margin:1rem 0 .5rem;color:var(--text-primary)}.feature-gate-content p{color:var(--text-secondary);margin-bottom:1rem}.feature-gate-preview{filter:blur(3px);pointer-events:none;-webkit-user-select:none;user-select:none}.upgrade-modal{max-width:1000px;max-height:90vh;overflow-y:auto}.upgrade-modal-header{text-align:center;margin-bottom:2rem}.upgrade-modal-header h2{margin-bottom:.5rem}.upgrade-modal-header p{color:var(--text-secondary)}.billing-toggle{display:inline-flex;background:var(--bg-card);border-radius:var(--radius-lg);padding:.25rem;margin-top:1.5rem;border:1px solid var(--border-subtle)}.billing-option{position:relative;padding:.6rem 1.25rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;transition:all var(--transition-fast)}.billing-option.active{background:var(--gradient-gold);color:var(--bg-primary);box-shadow:0 2px 8px #d4af374d}.billing-option:hover:not(.active){color:var(--text-primary)}.save-badge{display:inline-block;margin-left:.5rem;padding:.15rem .4rem;background:#56ab2f33;color:var(--success);font-size:.7rem;font-weight:600;border-radius:var(--radius-sm)}.billing-option.active .save-badge{background:#ffffff40;color:var(--bg-primary)}.tier-price .price-amount{font-size:2.25rem;font-weight:800}.tier-price .price-period{font-size:1rem;font-weight:500;color:var(--text-secondary)}.price-billed{font-size:.8rem;color:var(--text-muted);margin-top:.25rem;font-weight:400}.price-savings{display:inline-block;margin-top:.5rem;padding:.25rem .6rem;background:#56ab2f26;color:var(--success);font-size:.8rem;font-weight:600;border-radius:var(--radius-sm)}.tier-comparison{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.tier-card{position:relative;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-base)}.tier-card:hover{border-color:var(--tier-color, var(--border-medium));transform:translateY(-2px)}.tier-card.popular{border-color:var(--gold-primary);box-shadow:var(--glow-gold)}.tier-card.current{border-color:var(--success)}.popular-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--gradient-gold);color:var(--bg-primary);padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700}.current-badge{position:absolute;top:-10px;right:1rem;background:var(--success);color:#fff;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.tier-header{text-align:center;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle);margin-bottom:1rem}.tier-header h3{color:var(--tier-color, var(--text-primary));margin-bottom:.5rem}.tier-price{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.tier-description{color:var(--text-muted);font-size:.85rem;margin-top:.5rem}.tier-features h4{font-size:.8rem;text-transform:uppercase;color:var(--text-muted);margin:1rem 0 .5rem;letter-spacing:.5px}.tier-features ul{list-style:none;padding:0;margin:0}.tier-features li{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;border-bottom:1px solid var(--border-subtle)}.tier-features li:last-child{border-bottom:none}.tier-features li.excluded{opacity:.5}.feature-check{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.7rem;flex-shrink:0}.feature-check.yes{background:#56ab2f33;color:var(--success)}.feature-check.no{background:#6b6b8a33;color:var(--text-muted)}.feature-name{flex:1;color:var(--text-secondary)}.feature-value{font-weight:600;color:var(--text-primary)}.tier-action{margin-top:1.5rem}.tier-action button{width:100%;padding:.75rem;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-upgrade{background:var(--gradient-gold);border:none;color:var(--bg-primary)}.btn-upgrade:hover{transform:translateY(-1px);box-shadow:var(--glow-gold)}.btn-current{background:var(--bg-card);border:1px solid var(--success);color:var(--success)}.upgrade-modal-footer{text-align:center;padding-top:1rem;border-top:1px solid var(--border-subtle)}.upgrade-modal-footer p{color:var(--text-secondary);font-size:.85rem;margin:.25rem 0}.upgrade-modal-footer .subtle{color:var(--text-muted);font-size:.75rem}.subscription-status{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast)}.subscription-status:hover{border-color:var(--border-medium);background:var(--bg-card)}.tier-indicator{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:var(--bg-primary)}.status-info{display:flex;flex-direction:column}.status-info .tier-name{font-weight:600;font-size:.85rem;color:var(--text-primary)}.usage-mini{font-size:.7rem;color:var(--text-muted)}.btn-upgrade-mini{padding:.25rem .5rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-xs);color:var(--bg-primary);font-size:.7rem;font-weight:600;cursor:pointer}.detailed-analysis-teaser{margin:1rem 0;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-medium)}.teaser-preview{position:relative}.teaser-blur-overlay{position:absolute;inset:0;background:#0a0a0fd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2}.teaser-content{text-align:center;padding:2rem;max-width:400px}.teaser-content h4{color:var(--gold-primary);margin-bottom:.75rem}.teaser-content p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.teaser-credits{margin:1rem 0;padding:.5rem;background:#f6d3651a;border-radius:var(--radius-xs)}.teaser-credits.used-up{background:#ef44441a;color:var(--error)}.teaser-sample{padding:1.5rem;background:var(--bg-elevated);filter:blur(3px)}.teaser-sample p{margin:.5rem 0;color:var(--text-secondary);font-size:.9rem}.session-time-warning{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:var(--radius-sm);margin:.5rem 0;animation:slideIn .3s ease-out}.session-time-warning.warning{background:#f59e0b1a;border:1px solid var(--warning)}.session-time-warning.critical{background:#ef44441a;border:1px solid var(--error);animation:pulse 2s infinite}.session-time-warning.over-limit{background:#ef444433;border:1px solid var(--error)}.warning-icon{font-size:1.25rem}.warning-text{flex:1}.warning-text strong{display:block;color:var(--text-primary);font-size:.9rem}.warning-text p{margin:0;color:var(--text-secondary);font-size:.8rem}.btn-upgrade-warning{padding:.4rem .75rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-xs);color:var(--bg-primary);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.upgrade-modal{max-width:100%;margin:.5rem}.tier-comparison{grid-template-columns:1fr}.upgrade-prompt-content{flex-direction:column;text-align:center}.upgrade-prompt-actions{width:100%;flex-direction:column}.session-time-warning{flex-wrap:wrap}.btn-upgrade-warning{width:100%}}@media print{*,*:before,*:after{background:#fff!important;color:#000!important;box-shadow:none!important;text-shadow:none!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.app-header,.tab-navigation,.tool-cards,.modal-backdrop,.modal-close,.action-btn,.btn-primary,.btn-secondary,.btn-gold,.btn-icon,.dice-roller,.combat-tracker,.tool-card,.sidebar,.navigation,.keyboard-hint,.upgrade-prompt,.tier-badge,[data-no-print],button:not(.print-include),input,textarea,select{display:none!important}@page{margin:.75in;size:letter}body{font-family:Georgia,Times New Roman,serif!important;font-size:11pt!important;line-height:1.5!important;color:#000!important;background:#fff!important;padding:0!important;margin:0!important}.print-container,.session-notes-print,.campaign-notes-print{display:block!important;width:100%!important;max-width:none!important;padding:0!important;margin:0!important}.session-card,.note-card,.quest-card,.entity-card{display:block!important;background:#fff!important;border:1px solid #333!important;border-radius:0!important;padding:12pt!important;margin-bottom:16pt!important;page-break-inside:avoid;break-inside:avoid}h1,h2,h3,h4,h5,h6{color:#000!important;font-family:Georgia,serif!important;page-break-after:avoid;break-after:avoid}h1{font-size:18pt!important;margin-bottom:12pt!important;border-bottom:2pt solid #000!important;padding-bottom:6pt!important}h2{font-size:16pt!important;margin-bottom:10pt!important;border-bottom:1pt solid #666!important;padding-bottom:4pt!important}h3{font-size:14pt!important;margin-bottom:8pt!important}h4{font-size:12pt!important;margin-bottom:6pt!important}.session-title,.note-title{font-size:16pt!important;font-weight:700!important;color:#000!important;margin-bottom:8pt!important;border-bottom:1pt solid #333!important;padding-bottom:4pt!important}.session-date,.note-date{font-style:italic!important;color:#555!important;font-size:10pt!important;margin-bottom:8pt!important}.session-summary,.session-content,.note-content,.analysis-content{font-size:11pt!important;line-height:1.6!important;color:#000!important}.entity-mention{font-weight:700!important;text-decoration:underline!important;color:#000!important}ul,ol{margin-left:18pt!important;margin-bottom:8pt!important}li{margin-bottom:4pt!important}table{width:100%!important;border-collapse:collapse!important;margin-bottom:12pt!important;font-size:10pt!important}th,td{border:1pt solid #333!important;padding:6pt 8pt!important;text-align:left!important}th{background:#e0e0e0!important;font-weight:700!important}.quest-status{font-weight:700!important;padding:2pt 6pt!important;border:1pt solid #333!important;display:inline-block!important;margin-bottom:6pt!important}.quest-status.active{border-color:#228b22!important}.quest-status.completed{border-color:#666!important}.quest-status.failed{border-color:#8b0000!important}.entity-type-badge{font-size:9pt!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.5pt!important;margin-bottom:4pt!important;display:block!important}.tag,.entity-tag{display:inline!important;font-size:9pt!important;padding:0!important;margin-right:4pt!important;background:none!important;border:none!important}.tag:before{content:"#"}.transcript-section{font-family:Courier New,monospace!important;font-size:10pt!important;background:#f5f5f5!important;border:1pt solid #ccc!important;padding:8pt!important;white-space:pre-wrap!important;page-break-inside:avoid}.analysis-section{margin-bottom:12pt!important;padding-bottom:8pt!important;border-bottom:1pt dashed #999!important}.analysis-section:last-child{border-bottom:none!important}.key-moments-list{list-style-type:disc!important;margin-left:18pt!important}.key-moment-item{margin-bottom:6pt!important}img{max-width:100%!important;height:auto!important;page-break-inside:avoid}.entity-image,.handout-image{max-width:2in!important;max-height:2in!important;float:right!important;margin-left:12pt!important;margin-bottom:8pt!important}a[href]:after{content:" (" attr(href) ")";font-size:9pt!important;color:#666!important}a[href^="#"]:after,a[href^=javascript]:after{content:""}.page-break,.print-page-break{page-break-after:always;break-after:page}.no-page-break{page-break-inside:avoid;break-inside:avoid}.print-campaign-header{display:block!important;text-align:center!important;margin-bottom:24pt!important;padding-bottom:12pt!important;border-bottom:2pt solid #000!important}.print-campaign-header h1{font-size:24pt!important;margin-bottom:4pt!important;border:none!important;padding:0!important}.print-campaign-header .campaign-subtitle{font-size:12pt!important;font-style:italic!important;color:#555!important}.print-campaign-header .print-date{font-size:10pt!important;color:#777!important;margin-top:8pt!important}.dm-only-content{border:2pt dashed #666!important;padding:8pt!important;margin:8pt 0!important}.dm-only-content:before{content:"DM NOTES"!important;display:block!important;font-weight:700!important;font-size:9pt!important;text-transform:uppercase!important;letter-spacing:1pt!important;margin-bottom:6pt!important;color:#555!important}.handout-print{page-break-inside:avoid;margin-bottom:24pt!important}.handout-title{font-size:14pt!important;font-weight:700!important;border-bottom:1pt solid #333!important;padding-bottom:4pt!important;margin-bottom:8pt!important}@page{@bottom-center{content:"Page " counter(page) " of " counter(pages);font-size:9pt;color:#666}}.relationship-graph,.graph-container,canvas{display:none!important}.fantasy-calendar{border:1pt solid #333!important}.calendar-day{border:1pt solid #ccc!important;padding:4pt!important;min-height:30pt!important}.inventory-table{width:100%!important}.inventory-item{border-bottom:1pt solid #ccc!important;padding:4pt 0!important}.currency-display{font-weight:700!important;margin-bottom:8pt!important}.map-pins-list{list-style:decimal!important;margin-left:18pt!important}.map-pin-item{margin-bottom:4pt!important}}.print-button{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:var(--transition-fast)}.print-button:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--gold-primary)}.print-button:before{content:"🖨️"}.transcription-credits-modal{max-width:700px;width:95%;max-height:90vh;overflow-y:auto}.transcription-credits-modal h2{color:var(--gold-primary);margin:0}.transcription-credits-modal h3{color:var(--text-primary);font-size:1.1rem;margin:0 0 1rem}.credit-balance-section{background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.credit-balance-card{display:flex;align-items:center;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle);margin-bottom:1rem}.balance-icon{font-size:2.5rem}.balance-info{flex:1}.balance-label{font-size:.85rem;color:var(--text-muted);margin-bottom:.25rem}.balance-amount{font-size:2.5rem;font-weight:700;color:var(--gold-primary);line-height:1}.balance-time{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.credit-breakdown{display:flex;flex-direction:column;gap:.5rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.breakdown-label{color:var(--text-secondary)}.breakdown-value{color:var(--text-primary);font-weight:500}.breakdown-item.used .breakdown-value{color:var(--text-muted)}.cost-explanation-section{background:#8b7cf71a;border:1px solid rgba(139,124,247,.3);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.5rem}.cost-explanation-section h3{color:var(--purple-light);font-size:1rem;margin-bottom:.75rem}.explanation-points{margin:0 0 .75rem 1.25rem;padding:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.explanation-points li{margin-bottom:.5rem}.comparison-note{margin:0;padding-top:.75rem;border-top:1px solid rgba(139,124,247,.2);font-size:.85rem;color:var(--text-muted);font-style:italic}.credit-packs-section{margin-bottom:1.5rem}.credit-packs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.credit-pack-card{position:relative;background:var(--bg-card);border:2px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem;text-align:center;cursor:pointer;transition:all var(--transition-fast)}.credit-pack-card:hover{border-color:var(--border-medium);transform:translateY(-2px)}.credit-pack-card.selected{border-color:var(--gold-primary);background:#f6d3650d}.credit-pack-card.popular{border-color:var(--gold-primary)}.popular-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--gradient-gold);color:var(--bg-primary);padding:.2rem .75rem;font-size:.7rem;font-weight:700;border-radius:var(--radius-sm);white-space:nowrap}.savings-badge{position:absolute;top:.5rem;right:.5rem;background:#56ab2f33;color:var(--success);padding:.15rem .4rem;font-size:.65rem;font-weight:600;border-radius:var(--radius-xs)}.pack-name{font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.pack-credits{font-size:1.5rem;font-weight:700;color:var(--gold-primary)}.pack-time{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.pack-price{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.btn-buy-pack{width:100%;padding:.5rem 1rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-sm);color:var(--bg-primary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.btn-buy-pack:hover{transform:scale(1.02);box-shadow:var(--glow-gold)}.usage-history-section{margin-bottom:1.5rem}.toggle-history-btn{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.toggle-history-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.history-list{margin-top:.75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);overflow:hidden}.history-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-card);border-bottom:1px solid var(--border-subtle)}.history-item:last-child{border-bottom:none}.history-date{font-size:.85rem;color:var(--text-muted)}.history-details{display:flex;gap:1rem;font-size:.85rem}.history-duration{color:var(--text-secondary)}.history-credits{color:var(--error);font-weight:500}.upgrade-prompt-section{background:#f6d3651a;border:1px solid rgba(246,211,101,.3);border-radius:var(--radius-md);padding:1rem 1.25rem;text-align:center}.upgrade-prompt-section p{margin:0 0 .75rem;font-size:.9rem;color:var(--text-secondary)}.btn-upgrade-prompt{padding:.5rem 1.5rem;background:var(--gradient-gold);border:none;border-radius:var(--radius-sm);color:var(--bg-primary);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-upgrade-prompt:hover{transform:scale(1.02)}.transcription-service-info{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin-bottom:1rem}.service-badge{padding:.25rem .5rem;background:var(--gradient-purple);color:#fff;font-size:.7rem;font-weight:600;border-radius:var(--radius-xs);text-transform:uppercase}.service-features{flex:1;display:flex;gap:1rem;font-size:.8rem;color:var(--text-muted)}.service-features span{display:flex;align-items:center;gap:.25rem}.credits-display{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.credits-display:hover{border-color:var(--gold-primary)}.credits-amount{font-weight:600;color:var(--gold-primary)}.credits-label{font-size:.75rem;color:var(--text-muted)}.transcription-cost-estimate{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f6d3651a;border:1px solid rgba(246,211,101,.2);border-radius:var(--radius-sm);margin-top:.75rem}.cost-estimate-label{font-size:.85rem;color:var(--text-secondary)}.cost-estimate-value{font-weight:600;color:var(--gold-primary)}.cost-estimate-value.insufficient{color:var(--error)}@media(max-width:600px){.credit-packs-grid{grid-template-columns:1fr}.credit-balance-card{flex-direction:column;text-align:center}.service-features{flex-direction:column;gap:.25rem}}.storefront-modal{max-width:1200px;width:95vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.storefront-tabs{display:flex;gap:.5rem;padding:0 1.5rem;border-bottom:1px solid var(--border-color, #333);margin-bottom:1rem}.storefront-tabs .tab-btn{padding:.75rem 1.25rem;background:transparent;border:none;color:var(--text-secondary, #888);cursor:pointer;font-size:.9rem;border-bottom:2px solid transparent;transition:all .2s}.storefront-tabs .tab-btn:hover{color:var(--text-primary, #fff)}.storefront-tabs .tab-btn.active{color:var(--accent-gold, #d4af37);border-bottom-color:var(--accent-gold, #d4af37)}.shop-selector{display:flex;gap:1rem;padding:0 1.5rem;margin-bottom:1rem}.shop-type-btn{padding:.75rem 1.5rem;background:var(--bg-secondary, #1a1a24);border:1px solid var(--border-color, #333);border-radius:8px;color:var(--text-secondary, #888);cursor:pointer;transition:all .2s;font-size:.95rem}.shop-type-btn:hover{border-color:var(--accent-gold, #d4af37);color:var(--text-primary, #fff)}.shop-type-btn.active{background:linear-gradient(135deg,#d4af3733,#d4af371a);border-color:var(--accent-gold, #d4af37);color:var(--accent-gold, #d4af37)}.storefront-content{flex:1;overflow-y:auto;padding:0 1.5rem 1.5rem}.shop-header{margin-bottom:1.5rem}.shop-description{color:var(--text-secondary, #888);font-style:italic;margin:0;line-height:1.5}.shop-controls{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.shop-controls .search-box{flex:1;min-width:200px}.shop-controls .search-box input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary, #1a1a24);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #fff);font-size:.9rem}.shop-controls .search-box input:focus{outline:none;border-color:var(--accent-gold, #d4af37)}.shop-controls select{padding:.75rem 1rem;background:var(--bg-secondary, #1a1a24);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #fff);font-size:.9rem;cursor:pointer}.shop-controls select:focus{outline:none;border-color:var(--accent-gold, #d4af37)}.category-toggles{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary, #1a1a24);border-radius:8px;margin-bottom:1rem;font-size:.85rem}.category-toggles>span{color:var(--text-secondary, #888);margin-right:.5rem}.category-toggle-group{display:flex;align-items:center;gap:.25rem}.category-toggle-group span{color:var(--text-primary, #fff);font-size:.8rem;min-width:80px;text-align:center}.toggle-btn{width:22px;height:22px;border-radius:4px;border:1px solid var(--border-color, #333);background:var(--bg-primary, #0d0d14);color:var(--text-secondary, #888);cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s}.toggle-btn.enable:hover{background:#4caf5033;border-color:#4caf50;color:#4caf50}.toggle-btn.disable:hover{background:#f4433633;border-color:#f44336;color:#f44336}.shop-table-container{overflow-x:auto;border-radius:8px;border:1px solid var(--border-color, #333)}.shop-table{width:100%;border-collapse:collapse;font-size:.9rem}.shop-table th{background:var(--bg-secondary, #1a1a24);color:var(--text-secondary, #888);padding:.75rem 1rem;text-align:left;font-weight:500;border-bottom:1px solid var(--border-color, #333);position:sticky;top:0;z-index:1}.shop-table th.toggle-col{width:50px;text-align:center}.shop-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #333);vertical-align:top}.shop-table tbody tr:hover{background:#d4af370d}.shop-item-row.disabled{opacity:.4}.shop-item-toggle{text-align:center}.shop-item-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.shop-item-name{font-weight:500;color:var(--text-primary, #fff)}.shop-item-name .item-name{display:block;margin-bottom:.25rem}.rarity-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;margin-left:.5rem}.rarity-badge.common{background:#80808033;color:#aaa}.rarity-badge.uncommon{background:#4caf5033;color:#4caf50}.rarity-badge.rare{background:#2196f333;color:#2196f3}.rarity-badge.very-rare{background:#9c27b033;color:#9c27b0}.rarity-badge.legendary{background:#ff980033;color:#ff9800}.rarity-label{font-weight:500}.rarity-label.common{color:#aaa}.rarity-label.uncommon{color:#4caf50}.rarity-label.rare{color:#2196f3}.rarity-label.very-rare{color:#9c27b0}.rarity-label.legendary{color:#ff9800}.attunement-badge{display:inline-block;padding:.2rem .4rem;background:#9c27b033;color:#9c27b0;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase;margin-left:.5rem}.shop-item-category,.shop-item-type{color:var(--text-secondary, #888);font-size:.85rem}.shop-item-damage,.shop-item-ac,.shop-item-weight{color:var(--text-secondary, #888);font-size:.85rem;text-align:center}.shop-item-price{white-space:nowrap}.price-display{display:flex;align-items:center;gap:.5rem}.price-display .custom-price{color:var(--accent-gold, #d4af37);font-weight:600}.price-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.shop-table tbody tr:hover .price-actions{opacity:1}.edit-price-btn,.reset-price-btn{padding:.2rem .4rem;background:transparent;border:1px solid var(--border-color, #333);border-radius:4px;color:var(--text-secondary, #888);cursor:pointer;font-size:.8rem;transition:all .2s}.edit-price-btn:hover{background:#d4af3733;border-color:var(--accent-gold, #d4af37);color:var(--accent-gold, #d4af37)}.reset-price-btn:hover{background:#f4433633;border-color:#f44336;color:#f44336}.price-edit{display:flex;align-items:center;gap:.25rem}.price-input{width:60px;padding:.25rem .5rem;background:var(--bg-primary, #0d0d14);border:1px solid var(--accent-gold, #d4af37);border-radius:4px;color:var(--text-primary, #fff);font-size:.85rem}.price-unit{color:var(--text-secondary, #888);font-size:.85rem}.price-save,.price-cancel{padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.price-save{background:#4caf5033;color:#4caf50}.price-cancel{background:#f4433633;color:#f44336}.shop-item-description{color:var(--text-secondary, #888);font-size:.85rem;max-width:300px}.shop-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;color:var(--text-secondary, #888);font-size:.85rem}.price-note{color:var(--accent-gold, #d4af37)}.storefront-config{padding:0 1.5rem 1.5rem;overflow-y:auto;flex:1}.config-section{background:var(--bg-secondary, #1a1a24);border-radius:8px;padding:1.25rem;margin-bottom:1.25rem}.config-section h3{margin:0 0 1rem;color:var(--text-primary, #fff);font-size:1rem;display:flex;align-items:center;gap:.5rem}.config-field{margin-bottom:1rem}.config-field:last-child{margin-bottom:0}.config-field label{display:block;margin-bottom:.5rem;color:var(--text-secondary, #888);font-size:.9rem}.config-field.checkbox label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-primary, #fff)}.config-field input[type=text],.config-field textarea{width:100%;padding:.75rem 1rem;background:var(--bg-primary, #0d0d14);border:1px solid var(--border-color, #333);border-radius:6px;color:var(--text-primary, #fff);font-size:.9rem;font-family:inherit}.config-field input[type=text]:focus,.config-field textarea:focus{outline:none;border-color:var(--accent-gold, #d4af37)}.config-field textarea{resize:vertical;min-height:60px}.multiplier-control{display:flex;align-items:center;gap:1rem}.multiplier-control input[type=range]{flex:1;height:6px;background:var(--bg-primary, #0d0d14);border-radius:3px;-webkit-appearance:none}.multiplier-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--accent-gold, #d4af37);border-radius:50%;cursor:pointer}.multiplier-control span{min-width:50px;text-align:right;color:var(--accent-gold, #d4af37);font-weight:600}.rarity-toggles{display:flex;flex-wrap:wrap;gap:.75rem}.rarity-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-primary, #0d0d14);border-radius:6px;cursor:pointer;transition:all .2s}.rarity-toggle:hover{background:#ffffff0d}.rarity-toggle.common{border-left:3px solid #aaa}.rarity-toggle.uncommon{border-left:3px solid #4caf50}.rarity-toggle.rare{border-left:3px solid #2196f3}.rarity-toggle.very-rare{border-left:3px solid #9c27b0}.rarity-toggle.legendary{border-left:3px solid #ff9800}.config-hint{margin:.5rem 0 0;color:var(--text-secondary, #888);font-size:.85rem;font-style:italic}.config-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color, #333)}.config-actions.preview-actions{margin-top:auto}.storefront-content.magic-shop .shop-header{background:linear-gradient(135deg,#9c27b01a,#3f51b51a);padding:1rem;border-radius:8px;margin-bottom:1.5rem}.magic-table .shop-item-name .item-name{color:var(--text-primary, #fff)}.inventory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.inventory-actions{display:flex;gap:.5rem}@media(max-width:768px){.storefront-modal{width:100%;max-height:100vh;border-radius:0}.shop-controls{flex-direction:column}.category-toggles{display:none}.shop-table{font-size:.8rem}.shop-table th,.shop-table td{padding:.5rem}.shop-item-description{display:none}.config-actions{flex-direction:column}.config-actions button{width:100%}}.user-menu-container{display:flex;align-items:center;gap:var(--space-sm)}.user-menu-loading{padding:var(--space-sm)}.spinner-small{width:20px;height:20px;border:2px solid var(--border-light);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.offline-badge{font-size:.75rem;color:var(--text-tertiary);background:var(--bg-surface);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-light)}.login-button{display:flex;align-items:center;gap:var(--space-xs);background:linear-gradient(135deg,#d4af37,#f4d03f);color:#1a1a24;border:none;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.login-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4af3766;background:linear-gradient(135deg,#f4d03f,#d4af37)}.login-button svg{width:18px;height:18px;stroke:#1a1a24}.user-menu-trigger{display:flex;align-items:center;gap:var(--space-xs);background:var(--bg-surface);border:1px solid var(--border-light);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.user-menu-trigger:hover{background:var(--bg-hover);border-color:var(--border-medium)}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.user-name{font-weight:500;color:var(--text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-badge{font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.account-badge.dm{background:rgba(var(--accent-primary-rgb),.2);color:var(--accent-primary)}.account-badge.player{background:#6495ed33;color:#6495ed}.chevron{width:16px;height:16px;color:var(--text-secondary);transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:var(--space-xs);background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000004d;min-width:240px;z-index:1000;overflow:hidden}.user-menu-header{padding:var(--space-md);background:var(--bg-surface)}.user-info{display:flex;flex-direction:column;gap:2px}.user-email{font-size:.85rem;color:var(--text-secondary)}.account-type{font-size:.8rem;font-weight:500}.account-type.dm{color:var(--accent-primary)}.account-type.player{color:#6495ed}.user-menu-divider{height:1px;background:var(--border-light)}.user-menu-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:background .15s ease;text-align:left}.user-menu-item:hover{background:var(--bg-hover)}.user-menu-item svg{width:18px;height:18px;color:var(--text-secondary)}.user-menu-item.logout{color:#ef4444}.user-menu-item.logout svg{color:#ef4444}.user-menu-item.logout:hover{background:#ef44441a}.user-menu-container{position:relative}@media(max-width:600px){.user-name{display:none}.user-menu-trigger{padding:var(--space-xs)}}
