:root{--color-bg: #f4f4f5;--color-bg-panel: #ffffff;--color-bg-header: #1e293b;--color-bg-sidebar: #f8fafc;--color-bg-hover: #f1f5f9;--color-bg-selected: #eff6ff;--color-bg-code: #f8fafc;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-inverse: #f8fafc;--color-text-link: #2563eb;--color-primary: #3b82f6;--color-primary-dark:#1d4ed8;--color-danger: #ef4444;--color-danger-bg: #fef2f2;--color-warning: #f59e0b;--color-warning-bg: #fffbeb;--color-success: #10b981;--color-success-bg: #f0fdf4;--color-mythos: #7c3aed;--color-mythos-bg: #f5f3ff;--pin-antagonist: #f97316;--pin-danger: #ef4444;--pin-safe: #22c55e;--pin-discovery: #3b82f6;--pin-neutral: #6b7280;--pin-monster: #7c3aed;--badge-antagonist-bg: #fff7ed;--badge-antagonist-text: #c2410c;--badge-monster-bg: #f5f3ff;--badge-monster-text: #6d28d9;--badge-npc-bg: #f0fdf4;--badge-npc-text: #166534;--danger-low-bg: #f0fdf4;--danger-low-text: #166534;--danger-low-border:#bbf7d0;--danger-med-bg: #fffbeb;--danger-med-text: #92400e;--danger-med-border:#fde68a;--danger-high-bg: #fef2f2;--danger-high-text: #991b1b;--danger-high-border:#fecaca;--color-border: #e2e8f0;--color-border-strong: #cbd5e1;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 3px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 10px;--radius-full:9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--header-height: 52px;--sidebar-width: 320px;--panel-width: 400px;--map-min-height: 500px;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-semibold);white-space:nowrap}.badge-antagonist{background:var(--badge-antagonist-bg);color:var(--badge-antagonist-text)}.badge-monster{background:var(--badge-monster-bg);color:var(--badge-monster-text)}.badge-npc{background:var(--badge-npc-bg);color:var(--badge-npc-text)}.danger-low{background:var(--danger-low-bg);color:var(--danger-low-text);border:1px solid var(--danger-low-border)}.danger-medium{background:var(--danger-med-bg);color:var(--danger-med-text);border:1px solid var(--danger-med-border)}.danger-high{background:var(--danger-high-bg);color:var(--danger-high-text);border:1px solid var(--danger-high-border)}.section-heading{font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-3)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.stat-cell{background:var(--color-bg-sidebar);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-2);text-align:center}.stat-cell .stat-label{font-size:10px;font-weight:var(--font-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;display:block}.stat-cell .stat-value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text-primary);display:block;line-height:1.2;margin-top:2px}.skill-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.skill-table td{padding:var(--space-1) var(--space-2);border-bottom:1px solid var(--color-border)}.skill-table td:first-child{color:var(--color-text-secondary)}.skill-table td:last-child{font-weight:var(--font-semibold);text-align:right}.skill-table tr:last-child td{border-bottom:none}.skill-check-item{display:flex;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-sm)}.skill-check-item:last-child{border-bottom:none}.skill-check-pill{flex-shrink:0;display:inline-flex;align-items:center;padding:1px 8px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-semibold);background:var(--color-bg-code);border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap}.skill-check-pill.difficult{background:var(--danger-med-bg);color:var(--danger-med-text);border-color:var(--danger-med-border)}.skill-check-pill.extreme{background:var(--danger-high-bg);color:var(--danger-high-text);border-color:var(--danger-high-border)}.sanity-item{display:flex;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-mythos-bg);border:1px solid #ddd6fe;border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-2)}.sanity-loss-value{flex-shrink:0;font-weight:var(--font-bold);color:var(--color-mythos);min-width:60px}.clue-card{background:var(--color-bg-code);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-2);font-size:var(--text-sm)}.clue-card.discovered{border-left-color:var(--color-success);opacity:.7}.clue-card-title{font-weight:var(--font-semibold);margin-bottom:var(--space-1);color:var(--color-text-primary)}.clue-card-desc{color:var(--color-text-secondary)}.combat-attack-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-sm);gap:var(--space-4)}.combat-attack-row:last-child{border-bottom:none}.combat-attack-name{color:var(--color-text-secondary);flex:1}.combat-attack-skill{color:var(--color-text-primary);font-weight:var(--font-medium)}.combat-attack-dmg{color:var(--color-danger);font-weight:var(--font-bold)}.tracked-item{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) 0;cursor:pointer;font-size:var(--text-sm)}.tracked-item input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:var(--color-success);width:15px;height:15px;cursor:pointer}.tracked-item label{cursor:pointer;color:var(--color-text-secondary);line-height:1.4}.tracked-item input:checked+label{text-decoration:line-through;color:var(--color-text-muted)}.impression-box{background:var(--color-bg-code);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--text-sm);font-style:italic;color:var(--color-text-secondary);line-height:1.6}.toggle-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.toggle-tab{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary)}.toggle-tab.active{background:var(--color-bg-selected);border-color:var(--color-primary);color:var(--color-primary)}.behavior-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.behavior-list li{display:flex;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.4}.behavior-list li:before{content:"›";color:var(--color-primary);font-weight:var(--font-bold);flex-shrink:0}.event-card{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-3)}.event-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.event-card.completed{opacity:.5;background:var(--color-bg)}.event-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-2)}.event-card-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary)}.event-card-timing{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap}.event-card-desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.scrollable{overflow-y:auto;scrollbar-gutter:stable}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-3);color:var(--color-text-muted);text-align:center;padding:var(--space-8)}.empty-state-icon{font-size:2.5rem}.empty-state p{font-size:var(--text-sm);max-width:200px}.auth-loading,.auth-locked{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.auth-loading{flex-direction:column;gap:var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm)}.auth-loading span{font-size:2rem}.auth-locked-box{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8);background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center}.auth-locked-icon{font-size:3rem}.auth-locked-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0}.auth-locked-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.auth-locked-btn{margin-top:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:opacity var(--transition-fast)}.auth-locked-btn:hover{opacity:.88}.header{height:var(--header-height);background:var(--color-bg-header);display:flex;align-items:center;gap:var(--space-4);padding:0 var(--space-5);flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.08)}.header-brand{display:flex;align-items:center;gap:var(--space-3);margin-right:var(--space-4);flex-shrink:0}.header-logo{font-size:1.5rem}.header-title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text-inverse);line-height:1.2}.header-subtitle{font-size:var(--text-xs);color:#ffffff73;letter-spacing:.04em}.header-nav{display:flex;gap:var(--space-1);flex:1}.nav-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);background:transparent;color:#ffffff8c;font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.nav-tab:hover{background:#ffffff14;color:var(--color-text-inverse)}.nav-tab.active{background:#ffffff24;color:var(--color-text-inverse)}.nav-icon{font-size:1rem}.nav-label{font-size:var(--text-sm)}.header-actions{flex-shrink:0;display:flex;align-items:center;gap:var(--space-2)}.header-session{display:flex;flex-direction:column;align-items:flex-end;margin-right:var(--space-2)}.header-session-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-inverse);line-height:1.2;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-session-date{font-size:var(--text-xs);color:#ffffff73}.btn-header{padding:var(--space-2) var(--space-3);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);background:transparent;color:#ffffffb3;font-size:var(--text-xs);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-header:hover{background:#ffffff14;color:var(--color-text-inverse)}.btn-header--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-header--primary:hover{opacity:.88;background:var(--color-primary)}.btn-header--dim{color:#fff6;border-color:#ffffff1f}.btn-header--dim:hover{color:#ffffffb3;border-color:#fff3}.btn-header--finish{color:#fca5a5;border-color:#ef44444d}.btn-header--finish:hover{background:#ef444426;color:#fecaca;border-color:#ef444480}.camp-map-wrapper{position:relative;flex:1;display:flex;flex-direction:column;background:var(--color-bg);overflow:hidden;min-width:0}.camp-map-svg{flex:1;width:100%;height:100%;display:block}.location-pin circle{transition:r var(--transition-fast),opacity var(--transition-fast)}.location-pin:hover circle:nth-child(2){r:13}.map-style-toggle{position:absolute;top:var(--space-4);right:var(--space-4);padding:var(--space-2) var(--space-4);background:#ffffffeb;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all var(--transition-fast);color:var(--color-text-primary)}.map-style-toggle:hover{background:#fff;box-shadow:var(--shadow-lg)}.map-style-toggle--real{background:#281e14d9;border-color:#ffffff26;color:#d4b896}.map-style-toggle--real:hover{background:#281e14f2}.map-legend{position:absolute;bottom:var(--space-4);left:var(--space-4);background:#ffffffeb;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.legend-title{font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.legend-items{display:flex;flex-direction:column;gap:3px}.legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-secondary)}.legend-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0;border:1.5px solid white;box-shadow:var(--shadow-sm)}.legend-dot-ring{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0;border:2px dashed var(--pin-monster)}.stat-block{display:flex;flex-direction:column;gap:var(--space-2)}.stat-note{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.map-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50;padding:var(--space-6)}.map-modal-box{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:620px;max-width:100%;max-height:82vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #00000040;overflow:hidden}.map-modal-titlebar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.map-modal-title{flex:1;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-modal-back{background:none;border:none;color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);white-space:nowrap;transition:background var(--transition-fast)}.map-modal-back:hover{background:var(--color-bg-selected)}.map-modal-close{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0}.map-modal-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.map-modal-body{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:0}.map-view{display:flex;flex:1;overflow:hidden;height:100%}.investigators-view{display:grid;grid-template-columns:repeat(4,1fr);flex:1;overflow:hidden;height:100%}.investigators-sidebar{background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;min-width:0}.investigators-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.inv-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.inv-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.inv-card.selected{border-color:var(--color-primary);background:var(--color-bg-selected);box-shadow:var(--shadow-md)}.inv-card-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.inv-card-body{flex:1;min-width:0}.inv-card-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:2px}.inv-card-role{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.4}.inv-card-meta{font-size:var(--text-xs);color:var(--color-text-subtle, var(--color-text-muted));margin-top:2px}.inv-panel{grid-column:span 3;display:flex;flex-direction:column;border-left:1px solid var(--color-border);overflow:hidden;position:relative;background:var(--color-bg-panel)}.inv-panel-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg-sidebar)}.inv-panel-icon{font-size:2.5rem;line-height:1;flex-shrink:0}.inv-panel-name{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.inv-panel-meta{font-size:var(--text-sm);color:var(--color-text-muted)}.inv-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg-sidebar)}.inv-tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.inv-tab-btn:hover{color:var(--color-text-primary)}.inv-tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.inv-panel-body{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6)}.inv-trasfondo{display:flex;flex-direction:column;gap:var(--space-5)}.inv-section-label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:var(--space-2)}.inv-section-text{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.65;margin-bottom:var(--space-3)}.inv-section-text:last-child{margin-bottom:0}.inv-relaciones{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.inv-relacion-item{font-size:var(--text-sm);line-height:1.65;padding-left:var(--space-3);border-left:2px solid var(--color-primary)}.inv-relacion-nombre{font-weight:var(--font-semibold);color:var(--color-text-primary)}.inv-relacion-texto{color:var(--color-text-secondary, var(--color-text-primary))}.inv-stats{display:flex;flex-direction:column;gap:var(--space-5)}.inv-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.inv-stat-cell{background:var(--color-bg-sidebar);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);text-align:center}.inv-stat-label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:var(--space-1)}.inv-stat-value{font-size:var(--text-2xl, 1.5rem);font-weight:var(--font-bold);color:var(--color-primary);line-height:1.1}.inv-stat-half{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.inv-derived{display:flex;gap:var(--space-4);flex-wrap:wrap;padding:var(--space-4);background:var(--color-bg-sidebar);border:1px solid var(--color-border);border-radius:var(--radius-md)}.inv-derived-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.inv-derived-label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.inv-skills-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.inv-skill-th{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);text-align:right;border-bottom:2px solid var(--color-border)}.inv-skill-th-name{text-align:left}.inv-skill-row{border-bottom:1px solid var(--color-border)}.inv-skill-row:last-child{border-bottom:none}.inv-skill-row:hover{background:var(--color-bg-hover)}.inv-skill-name{padding:var(--space-2) var(--space-3);color:var(--color-text-primary)}.inv-skill-val{padding:var(--space-2) var(--space-3);text-align:right;font-weight:var(--font-semibold);font-variant-numeric:tabular-nums;white-space:nowrap}.inv-skill-val-normal{color:var(--color-primary)}.inv-skill-val-hard{color:var(--color-text-muted)}.inv-skill-val-extreme{color:var(--color-text-subtle, var(--color-text-muted));opacity:.7}.inv-pdf-frame{flex:1;width:100%;border:none}.detail-panel{width:var(--panel-width);flex-shrink:0;background:var(--color-bg-panel);border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.miller-columns .detail-panel{width:auto;position:relative}.panel-close-btn{position:absolute;top:var(--space-3);right:var(--space-3);z-index:10;width:24px;height:24px;border-radius:50%;border:none;background:var(--color-bg-hover);color:var(--color-text-muted);font-size:11px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.panel-close-btn:hover{background:var(--color-danger-bg);color:var(--color-danger)}.detail-content{flex:1;padding:var(--space-5);display:flex;flex-direction:column;gap:0;overflow-y:auto}.detail-header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.detail-icon{font-size:2rem;line-height:1;flex-shrink:0;margin-top:2px}.detail-name{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-primary);line-height:1.2;margin-bottom:var(--space-2)}.detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.detail-section{margin-bottom:var(--space-5)}.detail-text{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.6}.gm-notes-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-chevron{font-size:var(--text-xs);color:var(--color-text-muted)}.gm-notes-box{background:#fffbf0;border:1px solid #fde68a;border-left:3px solid var(--color-warning);border-radius:var(--radius-md);padding:var(--space-3);margin-top:var(--space-2)}.gm-note-para{margin-bottom:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.6}.gm-note-para:last-child{margin-bottom:0}.npc-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.npc-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-sidebar);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans)}.npc-chip:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-bg-selected)}.event-chip{border-radius:var(--radius-md)}.event-complete-toggle{margin-bottom:var(--space-5);padding:var(--space-3);background:var(--color-bg-sidebar);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-2)}.characters-view{display:grid;grid-template-columns:repeat(4,1fr);flex:1;overflow:hidden;height:100%}.characters-sidebar{background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;min-width:0}.characters-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.sidebar-title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text-primary)}.char-grid{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.char-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.char-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.char-card.selected{border-color:var(--color-primary);background:var(--color-bg-selected);box-shadow:var(--shadow-md)}.char-card.type-antagonist.selected{border-color:var(--pin-antagonist);background:#fff7ed}.char-card.type-monster.selected{border-color:var(--pin-monster);background:var(--color-mythos-bg)}.char-card-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.char-card-body{flex:1;min-width:0}.char-card-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:2px}.char-card-role{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.4}.events-view{display:grid;grid-template-columns:repeat(4,1fr);flex:1;overflow:hidden;height:100%}.events-sidebar{background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;min-width:0}.events-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.events-progress-bar{height:3px;background:var(--color-border);flex-shrink:0}.events-progress-fill{height:100%;background:var(--color-success);transition:width var(--transition-normal)}.events-list{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.event-list-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative}.event-list-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.event-list-item.selected{border-color:var(--color-primary);background:var(--color-bg-selected)}.event-list-item.completed{opacity:.55;background:var(--color-bg)}.event-list-icon{font-size:1.4rem;line-height:1;flex-shrink:0;margin-top:2px}.event-list-body{flex:1;min-width:0}.event-list-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:2px;line-height:1.3}.event-list-timing{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-1)}.event-done-mark{color:var(--color-success);font-weight:var(--font-bold);flex-shrink:0;font-size:var(--text-base)}.miller-columns{grid-column:span 3;display:grid;grid-template-columns:repeat(3,1fr);overflow:hidden}.miller-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm)}.miller-empty-icon{font-size:2.5rem;opacity:.3}.reference-view{display:grid;grid-template-columns:repeat(4,1fr);flex:1;overflow:hidden;height:100%}.ref-sidebar{background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;padding:var(--space-4) var(--space-3);gap:var(--space-1)}.ref-nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;border-radius:var(--radius-md);background:none;cursor:pointer;text-align:left;transition:background var(--transition-fast);color:var(--color-text-primary)}.ref-nav-item:hover{background:var(--color-bg-hover)}.ref-nav-item.active{background:var(--color-bg-selected);color:var(--color-primary);font-weight:var(--font-semibold)}.ref-nav-icon{font-size:1.25rem;flex-shrink:0}.ref-nav-label{font-size:var(--text-sm);line-height:1.3}.ref-content{grid-column:span 3;overflow-y:auto;background:var(--color-bg)}.ref-content-inner{max-width:860px;margin:0 auto;padding:var(--space-6) var(--space-8);display:flex;flex-direction:column;gap:var(--space-5)}.ref-content-title{font-size:var(--text-2xl, 1.5rem);font-weight:var(--font-bold);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:2px solid var(--color-border);margin-bottom:var(--space-2)}.ref-content-heading{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text-primary);margin-top:var(--space-4);margin-bottom:var(--space-2)}.ref-text-block{display:flex;flex-direction:column;gap:var(--space-3)}.ref-paragraph{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.7}.ref-readout{margin:0;padding:var(--space-5) var(--space-6);background:var(--color-bg-panel);border-left:4px solid var(--color-primary);border-radius:0 var(--radius-md) var(--radius-md) 0;display:flex;flex-direction:column;gap:var(--space-3)}.ref-readout p{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.75;font-style:italic;margin:0}.ref-note{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md)}.ref-note-icon{font-size:1rem;flex-shrink:0;margin-top:2px}.ref-note p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;margin:0}.ref-list{display:flex;flex-direction:column;gap:var(--space-2);padding-left:var(--space-5)}.ref-list li{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.65}.ref-hooks{display:flex;flex-direction:column;gap:var(--space-3)}.ref-hook-item{padding:var(--space-4) var(--space-5);background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.ref-hook-title{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.ref-hook-text{font-size:var(--text-sm);color:var(--color-text-secondary, var(--color-text-muted));line-height:1.65;margin:0}.ref-mechanics{display:flex;flex-direction:column;gap:var(--space-5)}.ref-cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-4)}.ref-card{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.ref-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.ref-card-icon{font-size:1.5rem}.ref-card-title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text-primary)}.ref-combat{margin-top:var(--space-3)}.ref-skill-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.ref-skill-table thead tr{background:var(--color-bg-sidebar)}.ref-skill-table th{padding:var(--space-2) var(--space-3);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.ref-skill-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);vertical-align:top}.ref-skill-table tr:last-child td{border-bottom:none}.ref-td-loc{color:var(--color-text-muted);white-space:nowrap;font-size:var(--text-xs)}.ref-td-skill{font-weight:var(--font-semibold);color:var(--color-text-primary);white-space:nowrap}.ref-td-diff{color:var(--color-warning);white-space:nowrap;font-size:var(--text-xs)}.ref-td-desc{color:var(--color-text-secondary)}.ref-subheading{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:var(--space-4) 0 var(--space-1);padding-bottom:var(--space-1);border-bottom:1px solid var(--color-border)}.ref-scale{display:flex;gap:2px;margin:var(--space-2) 0 var(--space-3);flex-wrap:wrap}.ref-scale-item{flex:1;min-width:80px;display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-1);border-radius:var(--radius-sm);text-align:center}.ref-scale-label{font-size:10px;font-weight:var(--font-semibold);line-height:1.3}.ref-scale-note{font-size:9px;opacity:.7;margin-top:2px}.ref-scale-item--worst{background:#7f1d1d;color:#fca5a5}.ref-scale-item--fail{background:#431407;color:#fed7aa}.ref-scale-item--ok{background:#1e3a5f;color:#bfdbfe}.ref-scale-item--good{background:#14532d;color:#bbf7d0}.ref-scale-item--great{background:#14532d;color:#86efac}.ref-scale-item--best{background:#365314;color:#d9f99d}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200}.modal-box{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-8);width:420px;max-width:calc(100vw - 2rem);box-shadow:0 20px 60px #0000004d}.modal-title{font-size:var(--text-xl, 1.25rem);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0 0 var(--space-2)}.modal-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-2) 0 var(--space-5);line-height:1.5}.modal-warning{font-size:var(--text-xs);color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);line-height:1.5}.modal-form{display:flex;flex-direction:column;gap:var(--space-4)}.modal-label{display:flex;flex-direction:column;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary)}.modal-input{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast)}.modal-input:focus{border-color:var(--color-primary)}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-2)}.modal-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;border:none;transition:all var(--transition-fast)}.modal-btn--cancel{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted)}.modal-btn--cancel:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.modal-btn--confirm{background:var(--color-primary);color:#fff}.modal-btn--confirm:hover:not(:disabled){opacity:.88}.modal-btn--confirm:disabled{opacity:.4;cursor:not-allowed}.modal-checkbox-label{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-primary);cursor:pointer}.notes-panel{position:fixed;right:0;top:var(--header-height);bottom:0;width:360px;background:var(--color-bg-panel);border-left:1px solid var(--color-border);display:flex;flex-direction:column;z-index:100;box-shadow:-4px 0 20px #0000001f}.notes-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}.notes-panel-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-primary)}.notes-panel-close{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.notes-panel-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.notes-panel-input{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-3);flex-shrink:0}.notes-textarea{width:100%;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);font-size:var(--text-sm);line-height:1.5;resize:none;outline:none;font-family:inherit;box-sizing:border-box;transition:border-color var(--transition-fast)}.notes-textarea:focus{border-color:var(--color-primary)}.notes-add-btn{align-self:flex-end;padding:var(--space-2) var(--space-4);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:opacity var(--transition-fast)}.notes-add-btn:hover:not(:disabled){opacity:.88}.notes-add-btn:disabled{opacity:.35;cursor:not-allowed}.notes-list{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.notes-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-8) 0}.note-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.note-item-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.note-item-time{font-size:var(--text-xs);color:var(--color-text-muted)}.note-item-delete{background:none;border:none;color:var(--color-text-muted);font-size:.65rem;cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);line-height:1;transition:all var(--transition-fast)}.note-item-delete:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.note-item-text{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.6;margin:0;white-space:pre-wrap;word-break:break-word}.notes-fab{bottom:var(--space-6);right:var(--space-6);width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;border:none;font-size:1.25rem;cursor:pointer;box-shadow:0 4px 16px #00000040;display:flex;align-items:center;justify-content:center;z-index:99;transition:all var(--transition-fast);position:fixed}.notes-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #0000004d}.notes-fab--active{background:var(--color-bg-header)}.notes-fab-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-main{flex:1;overflow:hidden;display:flex}.pdf-viewer{flex:1;width:100%;height:100%;border:none}
