.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);padding:2rem}.auth-container{width:100%;max-width:450px}.auth-brand{text-align:center;margin-bottom:3rem}.auth-logo{max-width:100%;height:auto;max-height:180px;object-fit:contain;filter:brightness(1.1)}.auth-brand h1{font-size:3rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-brand p{font-size:1.1rem;color:var(--text-muted)}.auth-form{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:16px;padding:2.5rem;animation:fadeIn .3s ease}.auth-form h2{font-size:1.75rem;margin-bottom:.5rem;text-align:center}.auth-subtitle{text-align:center;color:var(--text-muted);margin-bottom:2rem}.auth-error{padding:.875rem 1rem;background:#ef44441a;border:1px solid var(--danger);border-radius:8px;color:var(--danger);margin-bottom:1.5rem;font-size:.9rem}.auth-success{padding:.875rem 1rem;background:#22c55e1a;border:1px solid #22c55e;border-radius:8px;color:#22c55e;margin-bottom:1.5rem;font-size:.9rem}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon svg{position:absolute;left:1rem;color:var(--text-muted);pointer-events:none;flex-shrink:0}.input-with-icon input{padding-left:3.25rem!important;width:100%}.auth-form form{display:flex;flex-direction:column;gap:1.25rem}.link-button{background:none;border:none;color:var(--hope-color);font-size:.9rem;cursor:pointer;padding:0;text-align:left;transition:opacity .2s ease}.link-button:hover:not(:disabled){opacity:.7;text-decoration:underline}.link-button:disabled{opacity:.5;cursor:not-allowed}.auth-divider{position:relative;text-align:center;margin:1.5rem 0}.auth-divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border)}.auth-divider span{position:relative;background:var(--card-bg);padding:0 1rem;color:var(--text-muted);font-size:.9rem}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--text-muted);font-size:.9rem}.auth-footer .link-button{display:inline;font-weight:600}.auth-footer-text{text-align:center;margin-top:2rem;color:var(--text-muted);font-size:.85rem}.auth-footer-text p{margin:.5rem 0}.auth-credits a{color:var(--text-primary);text-decoration:none;transition:color .2s ease}.auth-credits a:hover{color:var(--hope-color)}.back-button{display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;padding:.5rem 0;margin-bottom:1.5rem;transition:color .2s ease}.back-button:hover{color:var(--hope-color)}@media(max-width:480px){.auth-page{padding:1rem}.auth-form{padding:2rem 1.5rem}.auth-brand h1{font-size:2.5rem}}.campaign-browser{padding:2rem;max-width:1200px;margin:0 auto}.browser-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.browser-header h2{font-size:2rem;margin:0}.browser-subtitle{color:var(--text-muted);margin:.25rem 0 0}.public-campaign-card{padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.public-campaign-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.campaign-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.campaign-card-header h3{font-size:1.5rem;margin:0;font-family:Cinzel,serif;flex:1}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.status-member{background:#22c55e26;color:#22c55e}.status-pending{background:#fbbf2426;color:#fbbf24}.status-denied{background:#ef444426;color:#ef4444}.campaign-description{color:var(--text-secondary);line-height:1.6;margin:0}.campaign-meta{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}.meta-item{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.95rem}.dm-label{font-weight:600;color:var(--text-secondary)}.pending-message,.member-message,.denied-message{padding:.875rem 1rem;border-radius:8px;font-size:.9rem;text-align:center}.pending-message{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);color:#fbbf24}.member-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e}.denied-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}@media(max-width:768px){.campaign-browser{padding:1rem}.campaign-card-header{flex-direction:column}.status-badge{align-self:flex-start}}.game-system-selector{margin-bottom:1.5rem}.game-system-selector .form-label{display:block;font-weight:600;margin-bottom:.25rem;color:var(--text-primary)}.game-system-selector .form-help{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.game-system-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.game-system-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;padding:1.25rem;cursor:pointer;transition:all .2s;text-align:left}.game-system-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.game-system-card.selected{border-color:var(--primary);background:var(--primary);box-shadow:0 0 0 3px #7c3aed1a}.game-system-card.selected h3{color:#fff}.game-system-card.selected .system-description{color:#ffffffe6}.system-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.system-header h3{margin:0;font-size:1.125rem;color:var(--text-primary)}.selected-badge{background:var(--primary);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:600}.system-description{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:.5rem;animation:fadeIn .2s ease}@media(min-width:768px){.modal-overlay{padding:1rem}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-small,.modal-medium,.modal-large{max-width:calc(100vw - 1rem)}@media(min-width:768px){.modal-small{max-width:400px}.modal-medium{max-width:600px}.modal-large{max-width:900px}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border)}@media(min-width:768px){.modal-header{padding:1.5rem}}.modal-header h2{font-size:1.25rem;margin:0}@media(min-width:768px){.modal-header h2{font-size:1.5rem}}.modal-body{padding:1rem;overflow-y:auto}@media(min-width:768px){.modal-body{padding:1.5rem}}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:var(--bg-tertiary)}.modal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.modal-actions{display:flex;flex-direction:column;gap:.75rem;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--border)}.modal-actions .btn{width:100%}@media(min-width:768px){.modal-actions{flex-direction:row;justify-content:flex-end;gap:1rem}.modal-actions .btn{width:auto}}.campaign-selector{padding:2rem;max-width:1200px;margin:0 auto}.campaign-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem}.campaign-selector-header h2{font-size:2rem;flex-shrink:0}.header-actions{display:flex;gap:.75rem;flex-shrink:0}.btn-sm{padding:.5rem 1rem;font-size:.9rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer}.checkbox-label span{font-weight:400;color:var(--text-primary)}.campaigns-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.campaigns-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}.campaign-card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--border);border-radius:12px;padding:1.5rem;transition:all .3s ease;display:flex;flex-direction:column;align-items:stretch;position:relative}.campaign-card-content{cursor:pointer;display:flex;flex-direction:column;align-items:center;text-align:center;padding:.5rem;flex:1}.campaign-card:hover{border-color:var(--hope-color);transform:translateY(-4px)}.campaign-card.active{border-color:var(--hope-color);background:linear-gradient(135deg,rgba(234,179,8,.1),var(--card-bg))}.campaign-delete-btn{position:absolute;top:.5rem;right:.5rem;padding:.5rem;background:transparent;color:var(--text-muted);border:1px solid transparent;transition:all .2s ease;opacity:0}.campaign-card:hover .campaign-delete-btn{opacity:1}.campaign-delete-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.campaign-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:1.5rem}.campaign-info h3{font-size:1.25rem;margin-bottom:.5rem}.campaign-info p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.campaign-selector-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;color:var(--text-muted);gap:1rem;width:100%;max-width:600px;margin:0 auto;padding:2rem}.campaign-selector-empty svg{color:var(--text-muted);opacity:.5}.campaign-selector-empty h2{font-size:2rem;margin:0;color:var(--text-primary)}.campaign-selector-empty p{font-size:1.1rem;margin:0}.campaign-selector-empty .btn{margin-top:.5rem}.empty-state-help{max-width:500px;font-size:1rem!important;color:var(--text-secondary)!important;line-height:1.6}.campaign-selector-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;color:var(--text-muted)}.loading-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--hope-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem}.campaign-members{padding:1.5rem}.campaign-members h3{margin-bottom:1.5rem;font-family:Cinzel,serif}.campaign-members h4{margin-bottom:1rem;font-size:1.1rem;font-family:Cinzel,serif}.members-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.member-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem}.member-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--accent-color);color:#fff}.member-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.member-name{font-weight:600;color:var(--text-primary)}.member-email{font-size:.875rem;color:var(--text-secondary)}.member-actions{display:flex;align-items:center;gap:1rem}.member-role{padding:.375rem .75rem;border-radius:.25rem;font-size:.875rem;font-weight:600;white-space:nowrap}.member-role.dm{background:var(--dm-primary);color:#fff}.member-role.player{background:var(--player-primary);color:#fff}.role-select{padding:.375rem .75rem;border:1px solid var(--border-color);border-radius:.25rem;background:var(--card-bg);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.role-select:hover{border-color:var(--hope-color)}.role-select:focus{outline:none;border-color:var(--hope-color);box-shadow:0 0 0 3px #eab3081a}.join-requests-section{margin-bottom:2rem;padding:1.5rem;background:#fbbf240d;border:2px solid rgba(251,191,36,.3);border-radius:12px}.join-requests-list{display:flex;flex-direction:column;gap:1rem}.join-request-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:8px}.request-info{display:flex;align-items:center;gap:1rem;flex:1}.request-info>div{display:flex;flex-direction:column;gap:.25rem}.request-name{font-weight:600;color:var(--text-primary)}.request-email{font-size:.875rem;color:var(--text-muted)}.request-actions{display:flex;gap:.5rem}.btn-success{background:#22c55e;color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.pending-invites{margin-bottom:2rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem}.pending-invite-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;color:var(--text-secondary)}.invite-form{padding:1.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem}.invite-form .input-group{display:flex;gap:.75rem}.invite-form input{flex:1}.invite-instructions{margin-top:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:.375rem;font-size:.875rem;color:var(--text-secondary);word-break:break-all}.invite-notice{display:flex;gap:1rem;padding:1rem;margin-bottom:1.5rem;background:#eab3081a;border-left:3px solid var(--hope-color);border-radius:.375rem}.invite-notice svg{flex-shrink:0;margin-top:.25rem;color:var(--hope-color)}.invite-notice strong{display:block;margin-bottom:.5rem;color:var(--text-primary)}.invite-notice p{margin:0;font-size:.875rem;line-height:1.5;color:var(--text-secondary)}.error-message{padding:.75rem;margin-bottom:1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:.375rem;color:#dc2626}.role-selection{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-primary)}.role-selection-container{max-width:800px;width:100%;text-align:center}.role-selection h1{font-size:2.5rem;margin-bottom:1rem;font-family:Cinzel,serif;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.role-selection-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:3rem}.role-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.role-option{background:var(--card-bg);border:3px solid var(--border);border-radius:16px;padding:3rem 2rem;cursor:pointer;transition:all .3s ease;text-align:center}.role-option:hover{transform:translateY(-8px);border-color:var(--hope-color)}.role-option.selected{border-color:var(--hope-color);background:linear-gradient(135deg,rgba(234,179,8,.1),var(--card-bg));box-shadow:0 8px 24px #eab30833}.role-option.selected .role-icon.dm{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary))}.role-option.selected .role-icon.player{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary))}.role-icon{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;background:var(--bg-secondary);color:var(--text-secondary);transition:all .3s ease}.role-icon.dm{background:linear-gradient(135deg,#8b5cf633,#a78bfa33)}.role-icon.player{background:linear-gradient(135deg,#eab30833,#f59e0b33)}.role-option.selected .role-icon{color:#fff}.role-option h3{font-size:1.5rem;margin-bottom:1rem;font-family:Cinzel,serif;color:var(--text-primary)}.role-option p{color:var(--text-secondary);line-height:1.6}.role-option.selected h3,.role-option.selected p{color:var(--text-primary)}.btn-large{padding:1rem 3rem;font-size:1.1rem;min-width:200px}.role-selection-note{margin-top:2rem;font-size:.875rem;color:var(--text-muted);font-style:italic}.sidebar{width:280px;min-height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:2rem 1.5rem;position:sticky;top:0;height:100vh}.sidebar-header{margin-bottom:2rem}.sidebar-title{font-size:1.75rem;margin-bottom:.25rem;background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar.dm-mode .sidebar-title{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{font-size:.9rem;color:var(--text-muted)}.mode-toggle{display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem;background:var(--card-bg);border-radius:12px}.mode-btn{flex:1;padding:.75rem 1rem;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-muted);font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease}.mode-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.player-mode .mode-btn.active{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));color:var(--bg-primary);border-color:var(--hope-color)}.dm-mode .mode-btn.active{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff;border-color:var(--fear-color)}.sidebar-nav{display:flex;flex-direction:column;gap:.75rem;flex:1;overflow-y:auto;overflow-x:hidden}.nav-group{display:flex;flex-direction:column;gap:.25rem}.nav-group-header{padding:.75rem 1rem;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-secondary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;justify-content:space-between;text-align:left;transition:all .2s ease;cursor:pointer}.nav-group-title{display:flex;align-items:center;gap:.5rem}.nav-group-header:hover{background:var(--card-bg);color:var(--text-primary)}.nav-group-header.has-active{color:var(--text-primary)}.player-mode .nav-group-header.has-active{color:var(--hope-color)}.dm-mode .nav-group-header.has-active{color:var(--fear-color)}.nav-group-items{display:flex;flex-direction:column;gap:.25rem;padding-left:.5rem;margin-top:.25rem}.nav-item{padding:.75rem 1rem;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-primary);font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:.75rem;text-align:left;transition:all .2s ease}.nav-item:hover{background:var(--card-bg);border-color:var(--border)}.player-mode .nav-item.active{background:linear-gradient(135deg,#eab30833,#f59e0b33);border-color:var(--hope-color);color:var(--hope-color)}.dm-mode .nav-item.active{background:linear-gradient(135deg,#8b5cf633,#a78bfa33);border-color:var(--fear-color);color:var(--fear-color)}.current-campaign{margin-bottom:1.5rem}.campaign-switcher{width:100%;padding:.875rem 1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:.9rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease}.campaign-switcher:hover{border-color:var(--hope-color);background:#eab3081a}.campaign-name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role-badge{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;background:var(--card-bg);border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.player-mode .user-role-badge{border-left:3px solid var(--hope-color)}.dm-mode .user-role-badge{border-left:3px solid var(--fear-color)}.logout-btn{width:100%;padding:.875rem 1rem;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:.95rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.75rem;cursor:pointer;transition:all .2s ease;margin-bottom:1.5rem}.logout-btn:hover{background:var(--danger);border-color:var(--danger);color:#fff}.sidebar-footer{margin-top:auto;padding-top:2rem;border-top:1px solid var(--border)}.sidebar-branding{text-align:center;padding:1rem 0}.sidebar-logo{max-width:120px;height:auto;opacity:.8;transition:opacity .2s ease}.sidebar-logo:hover{opacity:1}.sidebar-footer p{margin-bottom:.5rem}.sidebar-footer a{display:block;color:var(--text-primary);text-decoration:none;padding:.25rem;transition:color .2s ease}.sidebar-footer a:hover{color:var(--hope-color)}.dm-mode .sidebar-footer a:hover{color:var(--fear-color)}.mobile-menu-toggle{display:none}@media(max-width:767px){.sidebar{position:fixed;left:-280px;top:0;width:280px;height:100vh;transition:left .3s ease;z-index:1000;background:var(--bg-secondary);box-shadow:2px 0 10px #0000004d}.sidebar.mobile-open{left:0}.mobile-menu-toggle{display:flex!important;align-items:center;justify-content:center;position:fixed;top:1rem;left:1rem;z-index:1001;min-height:48px;min-width:48px;width:48px;height:48px;padding:0;background:var(--hope-color);border:2px solid var(--hope-color);border-radius:12px;color:var(--bg-primary);cursor:pointer;box-shadow:0 4px 12px #0000004d;transition:all .2s ease}.mobile-menu-toggle:hover,.mobile-menu-toggle:active{background:var(--hope-secondary);border-color:var(--hope-secondary);transform:scale(1.05)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}}@media(min-width:768px){.mobile-menu-toggle{display:none}.sidebar-backdrop{display:none!important}}.dice-roller{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.dice-roller h3{font-size:1.25rem;margin-bottom:1.5rem;text-align:center}.dice-controls{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1.5rem}.modifier-input{flex:1}.modifier-input label{display:block;font-size:.9rem;margin-bottom:.5rem;color:var(--text-muted)}.modifier-input input{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem}.dice-controls .btn{flex:2}.roll-result{padding:1.5rem;background:var(--bg-tertiary);border-radius:12px;border:2px solid var(--border);margin-bottom:1.5rem;animation:slideIn .5s ease}.roll-result.hope{border-color:var(--hope-color);background:linear-gradient(135deg,rgba(234,179,8,.1),transparent)}.roll-result.fear{border-color:var(--fear-color);background:linear-gradient(135deg,rgba(139,92,246,.1),transparent)}.dice-display{display:flex;justify-content:center;gap:2rem;margin-bottom:1.5rem}.die{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.5rem;border-radius:12px;min-width:100px}.hope-die{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));color:var(--bg-primary)}.fear-die{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff}.die-value{font-size:2rem;font-weight:700;font-family:Cinzel,serif}.die-label{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.roll-total{display:flex;flex-direction:column;align-items:center;gap:.75rem}.total-value{font-size:3rem;font-weight:700;font-family:Cinzel,serif;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.outcome-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:999px;font-weight:600;font-size:.9rem}.outcome-badge.hope{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));color:var(--bg-primary)}.outcome-badge.fear{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff}.modifier-display{text-align:center;margin-top:1rem;color:var(--text-muted);font-size:.9rem}.roll-history{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.roll-history h4{font-size:1rem;margin-bottom:1rem;color:var(--text-muted)}.history-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.history-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:6px;font-size:.85rem}.history-time{color:var(--text-muted);min-width:80px}.history-dice{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);flex:1;justify-content:center}.history-outcome{font-weight:700;min-width:40px;text-align:right}.history-outcome.hope{color:var(--hope-color)}.history-outcome.fear{color:var(--fear-color)}.d20-die{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff}.roll-result.critical{border-color:#22c55e;background:linear-gradient(135deg,rgba(34,197,94,.1),transparent)}.roll-result.critical-fail{border-color:#ef4444;background:linear-gradient(135deg,rgba(239,68,68,.1),transparent)}.outcome-badge.critical{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.outcome-badge.critical-fail{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.history-outcome.critical{color:#22c55e}.history-outcome.critical-fail{color:#ef4444}.dice-display.star-wars{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.d6-die{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:.75rem 1rem;min-width:60px}.wild-die{background:linear-gradient(135deg,#f59e0b,#d97706);border:2px solid #fbbf24}.roll-result.complication{border-color:#f59e0b;background:linear-gradient(135deg,rgba(245,158,11,.1),transparent)}.outcome-badge.success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.outcome-badge.complication{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.die-type-select{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer}.die-type-select:focus{outline:none;border-color:#6366f1}.roll-result.polyhedral{border-color:#6366f1;background:linear-gradient(135deg,rgba(99,102,241,.1),transparent)}.roll-formula{text-align:center;font-size:1.5rem;font-weight:700;font-family:Cinzel,serif;color:#6366f1;margin-bottom:1.5rem}.dice-display.polyhedral-display{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.polyhedral-die{background:var(--bg-secondary);color:var(--text-primary);padding:.75rem 1rem;min-width:70px;border:2px solid;border-radius:8px;transition:transform .2s ease}.polyhedral-die:hover{transform:scale(1.05)}.polyhedral-die .die-value{font-size:1.75rem}@media(max-width:767px){.polyhedral-die{min-width:60px;padding:.5rem .75rem}.polyhedral-die .die-value{font-size:1.5rem}.roll-formula{font-size:1.25rem}}.wiki-link{background:none;border:none;padding:0;margin:0;font-family:inherit;font-size:inherit;line-height:inherit;min-height:auto;cursor:pointer;color:#eab308;text-decoration:underline;text-decoration-style:dotted;text-decoration-color:#eab308;text-underline-offset:2px;font-weight:500;transition:all .2s ease;display:inline;transform:none;filter:none}.wiki-link:hover{color:#f59e0b;text-decoration-style:solid;text-decoration-color:#f59e0b;text-shadow:0 0 8px rgba(234,179,8,.3);transform:none;filter:none}.wiki-link:active{color:#eab308;transform:none;filter:none}.wiki-link-broken{color:#8b5cf6;text-decoration:underline;text-decoration-style:wavy;text-decoration-color:#8b5cf6;cursor:not-allowed;opacity:.7;background:none;border:none;padding:0;margin:0}.wiki-link-broken:hover{color:#a78bfa;text-decoration-color:#a78bfa}.npcs-view{max-width:1400px;margin:0 auto}.npcs-controls{margin-bottom:2rem}.search-box{position:relative;margin-bottom:1rem}.search-box svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-box input{width:100%;padding:.75rem 1rem .75rem 3rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem}.search-box input:focus{outline:none;border-color:var(--hope-color)}.filter-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.filter-tab{padding:.5rem 1rem;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.filter-tab:hover{background:var(--bg-tertiary);border-color:var(--hope-color)}.filter-tab.active{background:var(--hope-color);color:#fff;border-color:var(--hope-color)}.npcs-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.npcs-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}.npc-card{overflow:hidden}.npc-header{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:0}.npc-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;overflow:hidden;flex-shrink:0}.npc-avatar img{width:100%;height:100%;object-fit:cover}.npc-avatar span{font-family:Cinzel,serif;color:#fff}.npc-info{flex:1;min-width:0}.npc-info h3{font-size:1.25rem;margin-bottom:.5rem}.npc-occupation,.npc-location{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary);margin-bottom:.25rem}.relationship-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;margin-top:.5rem;text-transform:capitalize}.relationship-ally{background:#22c55e1a;color:var(--hope-color);border:1px solid var(--hope-color)}.relationship-neutral{background:#9ca3af1a;color:var(--text-secondary);border:1px solid var(--border)}.relationship-enemy{background:#ef44441a;color:var(--fear-color);border:1px solid var(--fear-color)}.npc-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.npc-section{margin-bottom:1.5rem}.npc-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted)}.npc-section p{line-height:1.7;white-space:pre-wrap}.npc-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.npc-actions .btn{flex:1}.npc-form{display:flex;flex-direction:column;gap:1.5rem}.avatar-section{display:flex;gap:1.5rem;align-items:center;padding:1.5rem;background:var(--bg-tertiary);border-radius:8px}.avatar-preview{width:120px;height:120px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;text-align:center}.form-hint{color:var(--text-muted);font-size:.85rem}@media(max-width:767px){.npc-avatar{width:60px;height:60px;font-size:1.5rem}.npc-info h3{font-size:1.1rem}.npc-actions{flex-direction:column}.npc-actions .btn{width:100%}.avatar-section{flex-direction:column;padding:1rem}.avatar-preview{width:100px;height:100px}}.locations-view{max-width:1400px;margin:0 auto}.world-map-section{margin-bottom:2rem}.world-map-section h3{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.world-map-container{display:flex;flex-direction:column;gap:1rem}.world-map-image{width:100%;height:auto;max-height:600px;object-fit:contain;border-radius:8px;border:1px solid var(--border)}.map-actions{display:flex;gap:.75rem}.world-map-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;text-align:center;color:var(--text-muted)}.locations-controls{margin-bottom:2rem}.locations-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.locations-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}.location-card{overflow:hidden}.location-header{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:0}.location-icon{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#10b981,#3b82f6);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.location-info{flex:1;min-width:0}.location-info h3{font-size:1.25rem;margin-bottom:.5rem}.location-type-badge{display:inline-flex;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;text-transform:capitalize;margin-bottom:.5rem}.location-city{background:#ef44441a;color:#ef4444;border:1px solid #ef4444}.location-town{background:#3b82f61a;color:#3b82f6;border:1px solid #3b82f6}.location-village{background:#22c55e1a;color:#22c55e;border:1px solid #22c55e}.location-dungeon{background:#8b5cf61a;color:#8b5cf6;border:1px solid #8b5cf6}.location-wilderness{background:#10b9811a;color:#10b981;border:1px solid #10b981}.location-landmark{background:#eab3081a;color:#eab308;border:1px solid #eab308}.location-other{background:#9ca3af1a;color:var(--text-secondary);border:1px solid var(--border)}.location-region{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.location-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.location-section{margin-bottom:1.5rem}.location-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted)}.location-section p{line-height:1.7;white-space:pre-wrap}.location-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.location-actions .btn{flex:1}.location-map-container{display:flex;flex-direction:column;gap:.75rem}.location-map-image{width:100%;height:auto;max-height:400px;object-fit:contain;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary)}.map-description{font-size:.875rem;color:var(--text-secondary);font-style:italic;margin:0}.location-form{display:flex;flex-direction:column;gap:1.5rem}.lore-card{overflow:hidden}.lore-card.hidden-entry{border-color:var(--fear-color);background:linear-gradient(135deg,rgba(139,92,246,.1),var(--card-bg))}.lore-header{display:flex;align-items:center;gap:1rem;cursor:pointer;padding:0}.lore-type-icon{width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.lore-info{flex:1;min-width:0}.lore-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.lore-title-row h3{font-size:1.15rem;margin:0}.lore-type{color:var(--text-muted);font-size:.85rem;text-transform:capitalize}.lore-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.lore-content{margin-bottom:1.5rem;line-height:1.7;white-space:pre-wrap}.lore-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.lore-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.lore-actions .btn{flex:1}.session-card{overflow:hidden}.session-header{display:flex;align-items:center;gap:1rem;cursor:pointer;padding:0}.session-number{width:80px;height:80px;border-radius:12px;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;flex-direction:column;font-weight:700;font-family:Cinzel,serif;color:#fff;flex-shrink:0;font-size:.85rem;text-align:center;line-height:1.3;position:relative}.session-status-badge{position:absolute;top:-8px;right:-8px;padding:.25rem .5rem;border-radius:8px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-family:system-ui,-apple-system,sans-serif}.status-planned{background:#3b82f6e6;color:#fff}.status-in-progress{background:#fbbf24e6;color:#fff}.status-completed{background:#22c55ee6;color:#fff}.session-info{flex:1;min-width:0}.session-info h3{font-size:1.25rem;margin-bottom:.5rem}.session-date{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem}.session-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.session-summary,.session-highlights,.session-encounters,.session-dm-notes{margin-bottom:1.5rem}.session-summary h4,.session-highlights h4,.session-encounters h4,.session-dm-notes h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.session-encounters{padding:1rem;background:#6366f10d;border:1px solid var(--hope-color);border-radius:8px}.encounter-links{display:flex;flex-wrap:wrap;gap:.75rem}.encounter-link{padding:.5rem 1rem;background:var(--hope-color);color:#fff;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:all .2s ease;display:inline-block}.encounter-link:hover{transform:translateY(-2px);box-shadow:0 4px 8px #6366f14d}.session-summary p{line-height:1.7;white-space:pre-wrap}.session-highlights ul{list-style:none;padding:0}.session-highlights li{background:var(--bg-tertiary);border-radius:8px;margin-bottom:.5rem;position:relative;padding:.75rem .75rem .75rem 2rem}.session-highlights li:before{content:"•";position:absolute;left:.75rem;color:var(--hope-color);font-size:1.5rem;line-height:1}.session-dm-notes{padding:1rem;background:#8b5cf61a;border:1px solid var(--fear-color);border-radius:8px}.session-dm-notes h4{color:var(--fear-color)}.session-dm-notes p{line-height:1.7;white-space:pre-wrap}.session-actions{display:flex;flex-direction:column;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.session-actions .btn{width:100%}@media(min-width:768px){.session-actions{flex-direction:row}.session-actions .btn{flex:1;width:auto}}@media(max-width:767px){.session-number{width:60px;height:60px;font-size:.75rem}.session-info h3{font-size:1.1rem}.session-details{padding-top:1rem;margin-top:1rem}}.timeline-view{padding:2rem;max-width:1200px;margin:0 auto}.timeline-controls{margin-bottom:2rem}.timeline-list{position:relative;padding-left:2rem}.timeline-list:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--hope-color),var(--fear-color));border-radius:2px}.timeline-event-card{position:relative;margin-bottom:1.5rem;margin-left:1rem}.timeline-event-header{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:0}.timeline-marker{position:absolute;left:-2.5rem;top:.5rem;width:16px;height:16px;background:var(--hope-color);border:3px solid var(--bg-primary);border-radius:50%;z-index:1;flex-shrink:0}.timeline-event-info{flex:1;min-width:0}.timeline-event-info h3{font-size:1.25rem;margin-bottom:.5rem}.event-date,.event-location{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary);margin-bottom:.25rem}.type-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;margin-top:.5rem;text-transform:capitalize}.type-event{background:#3b82f61a;color:#3b82f6;border:1px solid #3b82f6}.type-quest{background:#a855f71a;color:#a855f7;border:1px solid #a855f7}.type-milestone{background:#eab3081a;color:#eab308;border:1px solid #eab308}.type-other{background:#9ca3af1a;color:var(--text-secondary);border:1px solid var(--border)}.timeline-event-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.event-section{margin-bottom:1.5rem}.event-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted)}.event-section p{line-height:1.7;white-space:pre-wrap}.event-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.event-actions .btn{flex:1}.timeline-event-form{display:flex;flex-direction:column;gap:1.5rem}.timeline-toggles{display:flex;gap:.5rem;margin-bottom:1rem}.toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.toggle-btn:hover{background:var(--bg-tertiary)}.toggle-btn.active{background:var(--bg-secondary);border-color:var(--hope-color);color:var(--text-primary)}.timeline-enhanced{position:relative;padding:2rem 0}.timeline-rail{position:absolute;left:2rem;top:0;bottom:0;width:4px;background:linear-gradient(to bottom,var(--hope-color),var(--fear-color));border-radius:2px}.timeline-items{position:relative;padding-left:5rem}.timeline-item-wrapper{position:relative;margin-bottom:3rem}.timeline-node{position:absolute;left:-3rem;top:1.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:4px solid var(--bg-primary);z-index:2;transition:transform .2s}.timeline-node:hover{transform:scale(1.15)}.session-node{background:var(--hope-color);color:var(--bg-primary)}.event-node{background:var(--fear-color);color:var(--bg-primary)}.timeline-item-content{animation:slideIn .3s ease}@media(max-width:768px){.timeline-view{padding:1rem}.timeline-toggles{flex-wrap:wrap}.timeline-rail{left:1rem}.timeline-items{padding-left:3rem}.timeline-node{left:-2rem;width:28px;height:28px}.timeline-node svg{width:14px;height:14px}}.encounters-view{padding:2rem;max-width:1400px;margin:0 auto}.encounter-tool-link{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2rem;background:linear-gradient(135deg,#8b5cf60d,#3b82f60d);border:1px solid var(--hope-color)}.encounter-tool-link h3{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.encounter-tool-link p{color:var(--text-secondary);font-size:.9rem}.encounters-controls{margin-bottom:2rem}.encounters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.encounter-card{overflow:hidden}.encounter-header{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:0}.encounter-icon{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--fear-color),#dc2626);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.encounter-info{flex:1;min-width:0}.encounter-info h3{font-size:1.25rem;margin-bottom:.5rem}.difficulty-badge{display:inline-flex;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;text-transform:capitalize}.difficulty-easy{background:#22c55e1a;color:#22c55e;border:1px solid #22c55e}.difficulty-medium{background:#eab3081a;color:#eab308;border:1px solid #eab308}.difficulty-hard{background:#f973161a;color:#f97316;border:1px solid #f97316}.difficulty-deadly{background:#ef44441a;color:#ef4444;border:1px solid #ef4444}.encounter-level{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.encounter-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.encounter-section{margin-bottom:1.5rem}.encounter-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted)}.encounter-section p{line-height:1.7;white-space:pre-wrap}.encounter-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.encounter-actions .btn{flex:1}.encounter-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.full-width{width:100%;justify-content:center}.filter-tabs .filter-tab.difficulty-easy.active{background:#22c55e;color:#fff;border-color:#22c55e}.filter-tabs .filter-tab.difficulty-medium.active{background:#eab308;color:#fff;border-color:#eab308}.filter-tabs .filter-tab.difficulty-hard.active{background:#f97316;color:#fff;border-color:#f97316}.filter-tabs .filter-tab.difficulty-deadly.active{background:#ef4444;color:#fff;border-color:#ef4444}.notes-view{padding:2rem;max-width:1400px;margin:0 auto}.notes-controls{margin-bottom:2rem}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.note-card{overflow:hidden}.note-header{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;padding:0}.note-info{flex:1;min-width:0}.note-info h3{font-size:1.25rem;margin-bottom:.5rem}.note-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.category-badge{display:inline-flex;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;text-transform:capitalize}.category-quest{background:#a855f71a;color:#a855f7;border:1px solid #a855f7}.category-npc{background:#3b82f61a;color:#3b82f6;border:1px solid #3b82f6}.category-location{background:#10b9811a;color:#10b981;border:1px solid #10b981}.category-combat{background:#ef44441a;color:#ef4444;border:1px solid #ef4444}.category-other{background:#9ca3af1a;color:var(--text-secondary);border:1px solid var(--border)}.note-date,.note-author{font-size:.85rem;color:var(--text-muted)}.note-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.note-content{margin-bottom:1.5rem}.note-content p{line-height:1.7;white-space:pre-wrap}.note-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.note-actions .btn{flex:1}.note-form{display:flex;flex-direction:column;gap:1.5rem}.empty-subtitle{color:var(--text-muted);font-size:.95rem;margin-bottom:1rem}.entity-viewer-title{display:flex;align-items:center;gap:.75rem}.entity-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--hope-color);color:var(--bg-primary)}.entity-viewer-content{padding:0}.entity-viewer-content .card-actions{display:none}.entity-viewer-error{padding:2rem;text-align:center;color:var(--text-muted)}.entity-viewer-error p{margin:0;font-size:1.1rem}.relationship-graph-container{padding:2rem;max-width:1400px;margin:0 auto}.relationship-graph-empty{text-align:center;padding:4rem 2rem}.relationship-graph-empty svg{color:var(--text-muted);margin-bottom:1rem}.relationship-graph-empty h3{font-size:1.5rem;color:var(--text-primary);margin:1rem 0 .5rem}.relationship-graph-empty p{color:var(--text-secondary);margin:.5rem 0}.graph-hint{margin-top:1.5rem!important;font-size:.9rem;color:var(--text-muted)!important}.graph-hint code{background:var(--bg-tertiary);padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;color:var(--hope-color)}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.graph-header h2{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.8rem;color:var(--text-primary)}.graph-header svg{color:var(--hope-color)}.graph-subtitle{margin:.5rem 0 0;color:var(--text-muted);font-size:.95rem}.graph-controls{display:flex;gap:.5rem}.graph-legend{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;margin-bottom:1.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.legend-color{width:16px;height:16px;border-radius:50%;border:2px solid var(--bg-primary)}.graph-canvas{border:2px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000004d}.graph-canvas svg{display:block}.node-circle{transition:r .2s,stroke-width .2s}.node:hover .node-circle{r:10;stroke-width:3;filter:brightness(1.2)}.node-label{pointer-events:none;-webkit-user-select:none;user-select:none}.node:hover .node-label{font-weight:700}.node-type-label{pointer-events:none;-webkit-user-select:none;user-select:none}.graph-controls-panel{margin-bottom:1.5rem;padding:1.5rem}.graph-controls-header{margin-bottom:1rem}.graph-controls-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.125rem;color:var(--text-primary)}.graph-controls-header svg{color:var(--hope-color)}.graph-controls-section{margin-bottom:1.5rem}.graph-controls-section:last-child{margin-bottom:0}.graph-controls-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.graph-type-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:.75rem}.graph-type-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.graph-type-checkbox:hover{background:var(--bg-tertiary)}.graph-type-checkbox input[type=checkbox]{cursor:pointer}.graph-type-checkbox span{font-size:.938rem;color:var(--text-primary)}.graph-controls-actions{display:flex;gap:.5rem}.graph-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.graph-toggle:hover{background:var(--bg-tertiary)}.graph-toggle span{display:flex;align-items:center;gap:.5rem;font-size:.938rem;color:var(--text-primary)}.focus-mode-active{padding:.75rem;background:var(--bg-tertiary);border-radius:4px;border-left:3px solid var(--hope-color)}.focus-mode-active p{margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary)}.node{-webkit-user-select:none;user-select:none}@media(max-width:768px){.relationship-graph-container{padding:1rem}.graph-header{flex-direction:column;align-items:flex-start;gap:1rem}.graph-legend{gap:.75rem}.legend-item{font-size:.85rem}.graph-canvas svg{height:400px}}.dashboard-view{padding:1rem;display:flex;flex-direction:column;gap:1.5rem}@media(min-width:768px){.dashboard-view{padding:1.5rem}}@media(min-width:1024px){.dashboard-view{padding:2rem;gap:2rem}}.campaign-header{display:flex;flex-direction:column;gap:1rem;padding:1rem}@media(min-width:768px){.campaign-header{flex-direction:row;justify-content:space-between;align-items:flex-start;padding:1.5rem}}@media(min-width:1024px){.campaign-header{padding:2rem}}.campaign-info h1{font-size:1.75rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(min-width:768px){.campaign-info h1{font-size:2rem}}@media(min-width:1024px){.campaign-info h1{font-size:2.5rem}}.campaign-info p{font-size:.95rem;color:var(--text-muted);line-height:1.6}@media(min-width:768px){.campaign-info p{font-size:1.1rem}}.stats-row{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.stats-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}}.stat-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem}.stat-icon{width:64px;height:64px;border-radius:12px;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.stat-content h3{font-size:2rem;margin-bottom:.25rem}.stat-content p{color:var(--text-muted);font-size:.95rem}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}@media(min-width:1024px){.dashboard-grid{grid-template-columns:repeat(3,1fr)}}.dashboard-section h2{font-size:1.5rem;margin-bottom:1.5rem}.quick-actions-grid{display:flex;flex-direction:column;gap:1rem}.quick-action-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;text-decoration:none;color:var(--text-primary);transition:all .3s ease;position:relative}.quick-action-card:hover{transform:translate(8px)}.action-icon{font-size:2rem;flex-shrink:0}.action-content{flex:1}.action-content h4{font-size:1rem;margin-bottom:.25rem}.action-content p{font-size:.85rem;color:var(--text-muted)}.recent-sessions{display:flex;flex-direction:column;gap:1rem}.recent-session-card{display:flex;gap:1rem;padding:1.25rem}.session-badge{width:48px;height:48px;border-radius:8px;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0}.session-content{flex:1}.session-content h4{font-size:1.1rem;margin-bottom:.25rem}.session-date{color:var(--text-muted);font-size:.85rem;margin-bottom:.5rem}.session-preview{color:var(--text-muted);font-size:.9rem;line-height:1.5}.campaign-form{display:flex;flex-direction:column;gap:1.5rem}.character-card{overflow:hidden;padding:1rem}@media(min-width:768px){.character-card{padding:1.5rem}}.character-link-status{display:flex;align-items:center;gap:.5rem;color:var(--hope-color);font-size:.85rem;font-weight:500}.character-sheet-link{margin-bottom:1.5rem}.character-sheet-link .btn{width:100%;justify-content:center;padding:1rem 1.5rem;font-size:1rem}.notes-section{margin-bottom:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px}.notes-section h4{font-size:.95rem;margin-bottom:.75rem;color:var(--text-muted)}.notes-section p{line-height:1.7;white-space:pre-wrap}.character-header{display:flex;align-items:center;gap:1rem;cursor:pointer;padding:0}.character-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--hope-color),var(--fear-color));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;overflow:hidden;flex-shrink:0}.character-avatar img{width:100%;height:100%;object-fit:cover}.character-avatar span{font-family:Cinzel,serif;color:#fff;flex-shrink:0}.character-info{flex:1;min-width:0}.character-info h3{font-size:1.25rem;margin-bottom:.25rem}.player-name{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin-bottom:.25rem}.character-class{color:var(--hope-color);font-size:.9rem;font-weight:500;margin-bottom:.25rem}.character-ancestry{color:var(--text-muted);font-size:.85rem}.expand-btn{flex-shrink:0}.character-details{padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1.5rem;animation:slideIn .3s ease}.stats-section{margin-bottom:1.5rem}.stats-section h4{font-size:1rem;margin-bottom:1rem;color:var(--text-muted)}.traits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:768px){.traits-grid{grid-template-columns:repeat(3,1fr)}}.trait{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-tertiary);border-radius:8px}.trait-label{font-size:.85rem;color:var(--text-muted)}.trait-value{font-weight:700;font-size:1.1rem;color:var(--hope-color)}.vitals-section{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}@media(min-width:768px){.vitals-section{grid-template-columns:1fr 1fr}}.vital h4{font-size:.9rem;margin-bottom:.75rem;color:var(--text-muted)}.slots{display:flex;gap:.5rem}.slot{width:24px;height:24px;border-radius:4px;border:2px solid var(--border);transition:all .2s ease}.slot.filled.hp{background:var(--hope-color);border-color:var(--hope-color)}.slot.filled.stress{background:var(--fear-color);border-color:var(--fear-color)}.slot.empty{background:transparent}.combat-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}@media(min-width:768px){.combat-stats{grid-template-columns:repeat(3,1fr)}}.stat-box{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--bg-tertiary);border-radius:8px}.stat-label{font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem}.stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.experiences-section{margin-bottom:1.5rem}.experiences-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted)}.experiences-list{display:flex;flex-wrap:wrap;gap:.5rem}.backstory-section,.dm-notes-section{margin-bottom:1.5rem}.backstory-section h4,.dm-notes-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.dm-notes-section{padding:1rem;background:#8b5cf61a;border:1px solid var(--fear-color);border-radius:8px}.dm-notes-section h4{color:var(--fear-color)}.character-actions{display:flex;gap:.75rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border)}.character-actions .btn{flex:1;min-width:fit-content}.character-form{display:flex;flex-direction:column;gap:1.5rem}.avatar-section{display:flex;align-items:center;gap:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.avatar-preview{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid var(--border);background:var(--bg-tertiary);flex-shrink:0}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.85rem;text-align:center}.avatar-upload{display:flex;flex-direction:column;gap:.75rem;flex:1}.avatar-upload .btn{cursor:pointer;width:fit-content}.avatar-upload small{color:var(--text-muted);font-size:.85rem}.character-form-simple .input-group{margin-bottom:0}.external-link-inline{margin-left:.75rem;font-size:.85rem;color:var(--hope-color);text-decoration:none;display:inline-flex;align-items:center;gap:.35rem;font-weight:400;transition:opacity .2s ease}.external-link-inline:hover{opacity:.7}.input-hint{display:block;margin-top:.5rem;font-size:.85rem;color:var(--text-muted);font-style:italic}.form-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.form-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}.form-grid .full-width{grid-column:1 / -1}.traits-section h4,.slots-section h4{font-size:1.1rem;margin-bottom:1rem}.traits-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(min-width:768px){.traits-form-grid{grid-template-columns:repeat(3,1fr)}}.slots-section{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.slots-section{grid-template-columns:1fr 1fr}}.slot-group h4{font-size:.95rem;margin-bottom:.75rem;color:var(--text-muted)}.slot-toggles{display:flex;gap:.5rem}.slot-toggle{width:40px;height:40px;border-radius:6px;border:2px solid var(--border);background:transparent;color:var(--text-muted);font-weight:600;transition:all .2s ease}.slot-toggle:hover{border-color:var(--text-primary)}.slot-toggle.filled.hp{background:var(--hope-color);border-color:var(--hope-color);color:var(--bg-primary)}.slot-toggle.filled.stress{background:var(--fear-color);border-color:var(--fear-color);color:#fff}.experiences-form-section h4{font-size:1.1rem;margin-bottom:1rem}.experience-input-group{display:flex;gap:.75rem;margin-bottom:1rem}.experience-input-group input{flex:1;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary)}.experiences-tags{display:flex;flex-wrap:wrap;gap:.5rem}.experiences-tags .badge{display:flex;align-items:center;gap:.5rem}.experiences-tags .badge button{padding:0;background:transparent;border:none;color:inherit;display:flex;align-items:center;opacity:.7;transition:opacity .2s ease}.experiences-tags .badge button:hover{opacity:1}.form-actions{display:flex;flex-direction:column;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.form-actions .btn{width:100%}@media(min-width:768px){.form-actions{flex-direction:row;gap:1rem}.form-actions .btn{width:auto}}@media(max-width:767px){.avatar-section{flex-direction:column;gap:1rem;padding:1rem}.avatar-preview{width:100px;height:100px}}.generic-form{max-width:800px}.form-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-tertiary);border-radius:12px;border:1px solid var(--border)}.form-section h3{font-size:1.125rem;margin-bottom:1.25rem;color:var(--text-primary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.section-header h3{margin-bottom:0}.form-row{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}@media(min-width:768px){.form-row{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.form-row{grid-template-columns:repeat(3,1fr)}}.dynamic-fields-grid{display:flex;flex-direction:column;gap:.75rem}.dynamic-field-row{display:flex;gap:.5rem;align-items:center}.dynamic-field-row .field-name{flex:2}.dynamic-field-row .field-value{flex:1;max-width:120px}.dynamic-field-row .btn-icon{flex-shrink:0;min-width:44px;min-height:44px}.ability-field{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.ability-header{display:flex;gap:.5rem;align-items:center;margin-bottom:.75rem}.ability-name{flex:1;font-weight:600}.ability-field textarea{width:100%;resize:vertical}.empty-state{text-align:center;padding:2rem;color:var(--text-muted);font-style:italic}.btn-sm{padding:.5rem .75rem;font-size:.875rem}.btn-danger-ghost{background:transparent;color:#ef4444;border:1px solid transparent}.btn-danger-ghost:hover{background:#ef44441a;border-color:#ef4444}@media(max-width:767px){.form-section{padding:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.section-header .btn{width:100%}.dynamic-field-row{flex-wrap:wrap}.dynamic-field-row .field-name{flex:1 1 100%}.dynamic-field-row .field-value{flex:1 1 auto;max-width:none}.dynamic-field-row .btn-icon{flex:0 0 auto}.ability-header{flex-direction:column;align-items:stretch}.ability-header .btn-icon{align-self:flex-end}}.generic-card .character-class{font-size:.9rem;color:#6366f1;font-weight:500;margin-top:.25rem}.generic-card .character-level{font-size:.85rem;color:var(--text-muted);margin-top:.25rem}.stats-section{margin-bottom:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.stats-section h4{font-size:.95rem;margin-bottom:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.vitals-section{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-color:#6366f14d}.vitals-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.vital-box{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.vital-icon{color:#ef4444}.vital-info{display:flex;flex-direction:column;gap:.25rem}.vital-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.vital-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.attributes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:768px){.attributes-grid{grid-template-columns:repeat(3,1fr)}}.attribute-box{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border);text-align:center}.attribute-label{font-size:.85rem;color:var(--text-muted);font-weight:500}.attribute-value{font-size:1.5rem;font-weight:700;color:#6366f1}.skills-list{display:flex;flex-direction:column;gap:.5rem}.skill-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border)}.skill-name{font-weight:500;color:var(--text-primary)}.skill-value{font-weight:700;color:#8b5cf6;min-width:40px;text-align:right}.abilities-list{display:flex;flex-direction:column;gap:1rem}.ability-item{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.ability-name{display:block;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.ability-description{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0;white-space:pre-wrap}.notes-section,.backstory-section,.dm-notes-section{margin-bottom:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.notes-section h4,.backstory-section h4,.dm-notes-section h4{font-size:.95rem;margin-bottom:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;display:flex;align-items:center;gap:.5rem}.notes-section p,.backstory-section p,.dm-notes-section p{line-height:1.7;white-space:pre-wrap;margin:0}.dm-notes-section{background:#8b5cf60d;border-color:#8b5cf64d}@media(max-width:767px){.vitals-grid{grid-template-columns:1fr}.attributes-grid{grid-template-columns:repeat(2,1fr)}.vital-box{flex-direction:row}.stats-section{padding:.75rem}}.view-subtitle{color:var(--text-muted);font-size:.95rem}.search-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;margin-bottom:2rem}.search-bar input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:1rem;outline:none}.search-bar input::placeholder{color:var(--text-muted)}.characters-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.characters-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state p{font-size:1.1rem;margin-bottom:1.5rem}.wiki-link-input-wrapper{position:relative;width:100%}.wiki-link-textarea{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem;font-family:inherit;line-height:1.5;resize:vertical}.wiki-link-textarea:focus{outline:none;border-color:var(--hope-color);box-shadow:0 0 0 3px #eab3081a}.wiki-autocomplete-dropdown{background:var(--card-bg, #1a1a1a);border:2px solid var(--hope-color);border-radius:12px;box-shadow:0 8px 24px #000c,0 0 0 1px #000000e6;min-width:300px;max-width:400px;max-height:320px;display:flex;flex-direction:column;z-index:10000;overflow:hidden;animation:slideDown .2s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.autocomplete-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.85rem;font-weight:600}.autocomplete-results{overflow-y:auto;max-height:240px}.autocomplete-item{all:unset;display:block;padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s ease;width:100%;box-sizing:border-box}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item.selected{background:linear-gradient(135deg,rgba(234,179,8,.15),transparent)}.autocomplete-item-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.autocomplete-item-subtitle{font-size:.85rem;color:var(--text-muted)}.autocomplete-footer{display:flex;gap:1rem;padding:.5rem 1rem;background:var(--bg-secondary);border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted);justify-content:center}.autocomplete-footer span{white-space:nowrap}.lore-form{display:flex;flex-direction:column;gap:1.5rem}.tags-form-section label{display:block;font-weight:500;font-size:.95rem;margin-bottom:.5rem;color:var(--text-primary)}.tag-input-group{display:flex;gap:.75rem;margin-bottom:1rem}.tag-input-group input{flex:1;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary)}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.tags-list .badge{display:flex;align-items:center;gap:.5rem}.tags-list .badge button{padding:0;background:transparent;border:none;color:inherit;display:flex;align-items:center;opacity:.7;transition:opacity .2s ease}.tags-list .badge button:hover{opacity:1}.checkbox-group{padding:1rem;background:var(--bg-tertiary);border-radius:8px}.checkbox-group label{display:flex;align-items:center;gap:.75rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-group span{font-weight:500}.lore-filters{display:flex;gap:1rem;margin-bottom:2rem}.lore-filters .search-bar{flex:2}.type-filter{flex:1;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:10px}.type-filter select{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:1rem;outline:none;cursor:pointer}.lore-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.lore-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}.session-form{display:flex;flex-direction:column;gap:1.5rem}.form-hint{font-size:.85rem;color:var(--text-muted);margin-top:.25rem;display:block}.highlights-form-section label{display:block;font-weight:500;font-size:.95rem;margin-bottom:.5rem;color:var(--text-primary)}.highlight-input-group{display:flex;gap:.75rem;margin-bottom:1rem}.highlight-input-group input{flex:1;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary)}.highlights-list{list-style:none;padding:0;margin:0}.highlights-list li{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-tertiary);border-radius:8px;margin-bottom:.5rem}.highlights-list li span{flex:1}.highlights-list li button{padding:.25rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;transition:color .2s ease}.highlights-list li button:hover{color:var(--danger)}.sessions-list{display:flex;flex-direction:column;gap:1.5rem}.files-view{display:flex;flex-direction:column;gap:2rem}.upload-btn{cursor:pointer}.upload-progress{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.progress-info{display:flex;align-items:center;gap:.75rem;color:var(--text-primary);font-weight:500}.progress-bar{width:100%;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--hope-color),var(--fear-color));transition:width .3s ease;border-radius:4px}.progress-text{text-align:center;font-size:.9rem;color:var(--text-muted)}.files-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.files-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}.file-card{padding:0;overflow:hidden;display:flex;flex-direction:column;transition:all .2s ease}.file-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.file-preview{width:100%;height:200px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.file-preview img{width:100%;height:100%;object-fit:cover}.file-icon-large{color:var(--text-muted);opacity:.5}.file-info{padding:1rem;flex:1}.file-name{font-size:1rem;margin:0 0 .5rem;word-break:break-word;line-height:1.4}.file-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--text-muted)}.file-actions{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-secondary)}.file-actions .btn-icon{padding:.5rem}.file-actions a{display:flex;align-items:center;justify-content:center;text-decoration:none}.file-viewer{display:flex;justify-content:center;align-items:center;max-height:80vh;overflow:auto}.file-viewer img{max-width:100%;height:auto;border-radius:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:4rem 2rem;text-align:center}.empty-state svg{color:var(--text-muted);opacity:.5}.empty-state p{font-size:1.1rem;color:var(--text-muted);margin:0}.map-generator{margin-bottom:2rem;padding:1.5rem}.map-generator .form-group{display:flex;flex-direction:column;gap:.5rem}.map-generator label{font-weight:500;font-size:.9rem;color:var(--text-primary)}.map-generator .form-control{padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.95rem}.map-generator .form-control:focus{outline:none;border-color:var(--hope-color)}.map-generator .form-control:disabled{opacity:.5;cursor:not-allowed}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;line-height:1.5}.alert-warning{background:#eab3081a;border:1px solid rgba(234,179,8,.3);color:#eab308}.alert-info{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:#3b82f6}.generated-map{border:2px solid rgba(139,92,246,.3)}.badge-ai{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .5rem;margin-left:.5rem;background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff;border-radius:12px;font-size:.7rem;font-weight:600;vertical-align:middle}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tag{display:inline-block;padding:.25rem .75rem;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:capitalize}@media(max-width:768px){.files-view{padding:1rem}.files-grid{grid-template-columns:1fr}.view-header{flex-direction:column;gap:1rem}.view-header .btn{width:100%}.view-header>div:last-child{width:100%}.view-header>div:last-child>*{flex:1}}.tools-view{display:flex;flex-direction:column;gap:2rem}.tools-section{margin-bottom:2rem}.tools-section h3{font-size:1.25rem;margin-bottom:1.5rem;color:var(--text-muted)}.external-tools-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.external-tools-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}}.tool-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;text-decoration:none;color:var(--text-primary);transition:all .3s ease}.tool-card:hover{transform:translateY(-4px)}.tool-icon{font-size:2.5rem;flex-shrink:0}.tool-content{flex:1}.tool-content h4{font-size:1.05rem;margin-bottom:.5rem}.tool-content p{font-size:.9rem;color:var(--text-muted)}.external-icon{color:var(--text-muted);flex-shrink:0}.reference-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:1024px){.reference-grid{grid-template-columns:1fr}}.reference-list{display:flex;flex-direction:column;gap:1rem}.reference-item{padding:1.25rem;transition:all .2s ease}.reference-item.clickable{cursor:pointer}.reference-item.clickable:hover{transform:translateY(-2px);border-color:var(--hope-color);box-shadow:0 4px 12px #0000001a}.reference-item h4{font-size:1.1rem;margin-bottom:.75rem}.domains-list{display:flex;flex-wrap:wrap;gap:.5rem}.reference-tags{display:flex;flex-wrap:wrap;gap:.75rem}.badge.clickable{cursor:pointer;transition:all .2s ease}.badge.clickable:hover{transform:scale(1.05);opacity:.9}.reference-modal-content{padding:1rem 0}.modal-description{font-size:1.05rem;line-height:1.6;color:var(--text-primary);margin-bottom:1.5rem}.modal-section{margin-top:1.5rem}.modal-section h4{font-size:1rem;margin-bottom:.75rem;color:var(--text-secondary);text-transform:uppercase;font-weight:600;letter-spacing:.05em}.modal-section p{line-height:1.6;color:var(--text-primary)}.help-view{max-width:1200px;margin:0 auto;padding:2rem}.help-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--border)}.help-header svg{color:var(--hope-color);flex-shrink:0}.help-logo{max-width:200px;height:auto;max-height:80px;object-fit:contain;filter:brightness(1.1)}.help-header h1{font-size:2.5rem;margin:0;color:var(--text-primary)}.help-subtitle{font-size:1.1rem;color:var(--text-muted);margin:.5rem 0 0}.help-section{margin-bottom:2rem;padding:2rem}.help-section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.help-section-header svg{color:var(--hope-color);flex-shrink:0}.help-section-header h2{margin:0;font-size:1.8rem;color:var(--text-primary)}.help-content{color:var(--text-secondary);line-height:1.7}.help-content>p{font-size:1.1rem;margin-bottom:1.5rem}.help-content ul{margin:1rem 0 1rem 1.5rem;line-height:1.8}.help-content li{margin-bottom:.5rem}.help-feature{margin:2rem 0}.help-feature h3{font-size:1.3rem;color:var(--text-primary);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.help-steps{display:flex;flex-direction:column;gap:1.5rem;margin:1rem 0}.help-step{display:flex;gap:1rem;align-items:flex-start}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--hope-color);color:var(--bg-primary);font-weight:700;font-size:1rem;flex-shrink:0}.help-step>div{flex:1}.help-step strong{display:block;color:var(--text-primary);margin-bottom:.25rem;font-size:1.05rem}.help-step p{color:var(--text-muted);margin:0;font-size:.95rem}.help-tip{background:linear-gradient(135deg,rgba(234,179,8,.1),transparent);border-left:3px solid var(--hope-color);padding:1rem 1.5rem;border-radius:8px;margin:1.5rem 0}.help-tip strong{color:var(--hope-color);display:block;margin-bottom:.5rem}code{background:var(--bg-tertiary);padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:var(--hope-color);border:1px solid var(--border)}.entity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin:1.5rem 0}.entity-type{background:var(--bg-tertiary);padding:1.25rem;border-radius:8px;border:1px solid var(--border)}.entity-type strong{display:block;color:var(--text-primary);font-size:1.1rem;margin-bottom:.5rem}.entity-type p{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.5}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin:1.5rem 0}.shortcut{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.shortcut code{font-size:1rem;padding:.4rem .8rem;min-width:60px;text-align:center;flex-shrink:0}.shortcut span{color:var(--text-secondary);font-size:.9rem}.help-content a{color:var(--hope-color);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;transition:opacity .2s}.help-content a:hover{opacity:.8;text-decoration:underline}.help-footer{text-align:center;padding:3rem 2rem;margin-top:3rem;border-top:2px solid var(--border)}.help-footer p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1.5rem}.help-footer .btn{display:inline-flex;align-items:center;gap:.5rem}@media(max-width:768px){.help-view{padding:1rem}.help-header{flex-direction:column;align-items:flex-start;gap:1rem}.help-header h1{font-size:2rem}.help-section{padding:1.5rem}.entity-grid,.shortcuts-grid{grid-template-columns:1fr}.help-step{flex-direction:column}}.campaign-builder-view{padding:1rem;max-width:1400px;margin:0 auto}@media(min-width:768px){.campaign-builder-view{padding:1.5rem}}@media(min-width:1024px){.campaign-builder-view{padding:2rem}}.generation-mode-selector{margin-bottom:2rem}.mode-tabs{display:flex;flex-direction:column;gap:1rem}@media(min-width:768px){.mode-tabs{flex-direction:row;flex-wrap:wrap}}.mode-tab{flex:1;min-width:auto;display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--card-bg);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}@media(min-width:768px){.mode-tab{min-width:200px}}.mode-tab:hover:not(:disabled){border-color:var(--hope-color);background:var(--card-hover-bg)}.mode-tab.active{border-color:var(--hope-color);background:var(--hope-color-10)}.mode-tab:disabled{opacity:.5;cursor:not-allowed}.mode-tab.needs-key{border-color:var(--warning-color)}.mode-tab-content{display:flex;flex-direction:column;gap:.25rem;text-align:left}.mode-label{font-weight:600;font-size:1rem;color:#fff!important}.mode-description{font-size:.875rem;color:#fff!important;opacity:.9}.mode-warning{font-size:.75rem;color:#ffc107!important;font-weight:500}.template-generator,.prompt-generator,.api-generator{display:flex;flex-direction:column;gap:1.5rem}.generator-info{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;padding:.75rem;background:var(--card-bg);border-radius:8px;border:1px solid var(--border)}@media(min-width:768px){.generator-info{flex-direction:row;gap:1rem;padding:1rem}}.generator-info.warning{border-color:var(--warning-color);background:var(--warning-color-10)}.generator-info h4{margin:0 0 .25rem;color:#fff!important}.generator-info p{margin:0;font-size:.875rem;color:#fff!important;opacity:.9}.generator-requirements{display:flex;flex-direction:column;gap:1rem}.prompt-section,.response-section{display:flex;flex-direction:column;gap:.5rem}.prompt-header{display:flex;justify-content:space-between;align-items:center}.prompt-textarea,.response-textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:4px;background:var(--card-bg);color:var(--text);font-family:Courier New,monospace;font-size:.875rem;resize:vertical}.btn-sm.success{background:var(--success-color);border-color:var(--success-color)}.api-generator.no-key{text-align:center;padding:2rem}.quick-generator-modal{display:flex;flex-direction:column;gap:1.5rem;min-height:400px}.generator-content{flex:1;display:flex;flex-direction:column}.results-preview{margin-top:1.5rem;padding:1rem;background:var(--card-bg);border:2px solid var(--hope-color);border-radius:8px}@media(min-width:768px){.results-preview{padding:1.5rem}}.results-preview h3{margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.preview-fields{display:flex;flex-direction:column;gap:1rem}.preview-field{display:flex;flex-direction:column;gap:.25rem}.preview-field label{font-weight:600;font-size:.875rem;color:var(--text-secondary)}.preview-field .value{padding:.5rem;background:var(--bg);border-radius:4px;border:1px solid var(--border)}.preview-field textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text);font-family:inherit;resize:vertical;min-height:80px}.preview-field input,.preview-field select{padding:.5rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text)}.generator-error{padding:1rem;background:var(--error-color-10);border:1px solid var(--error-color);border-radius:4px;color:var(--error-color)}.generator-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;text-align:center}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--hope-color);border-radius:50%;animation:spin 1s linear infinite}.messaging-view{display:flex;height:calc(100vh - 80px);gap:0;overflow:hidden}.conversation-sidebar{width:320px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-secondary)}.conversation-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--bg-primary)}.conversation-header h2{margin:0;font-size:1.5rem}.conversation-header .view-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--text-muted)}.new-conversation-menu{margin:1rem;padding:0;overflow:hidden}.new-conversation-option{width:100%;padding:1rem;display:flex;align-items:center;gap:1rem;background:var(--bg-primary);border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s;text-align:left}.new-conversation-option:last-child{border-bottom:none}.new-conversation-option:hover{background:var(--bg-tertiary)}.new-conversation-option svg{color:var(--hope-color);flex-shrink:0}.new-conversation-option div{flex:1}.new-conversation-option strong{display:block;margin-bottom:.25rem}.new-conversation-option small{color:var(--text-muted);font-size:.813rem}.conversation-list{flex:1;overflow-y:auto}.conversation-item{width:100%;padding:1rem;display:flex;align-items:center;gap:.75rem;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s;text-align:left}.conversation-item:hover{background:var(--bg-tertiary)}.conversation-item.active{background:var(--bg-tertiary);border-left:3px solid var(--hope-color)}.conversation-item.unread{background:#eab3080d}.conversation-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.conversation-icon.announcement{background:linear-gradient(135deg,var(--hope-color),#eab308);color:#fff}.conversation-icon.dm{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border)}.conversation-info{flex:1;min-width:0}.conversation-name{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.conversation-name strong{font-size:.938rem}.unread-badge{width:8px;height:8px;background:var(--fear-color);border-radius:50%;flex-shrink:0}.conversation-preview{margin:0;font-size:.813rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:.75rem;color:var(--text-muted);flex-shrink:0}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.chat-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:1rem}.chat-placeholder svg{opacity:.3}.chat-placeholder h3{margin:0;font-size:1.5rem}.chat-placeholder p{margin:0;font-size:.938rem}.chat-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem;background:var(--bg-secondary)}.chat-header-icon{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--hope-color)}.chat-header-info{flex:1}.chat-header-info h3{margin:0;font-size:1.125rem}.chat-subtitle{margin:.25rem 0 0;font-size:.813rem;color:var(--text-muted)}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.empty-state-small{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state-small p{margin:.5rem 0}.empty-subtitle{font-size:.875rem;color:var(--text-muted)}.message{display:flex;margin-bottom:.5rem}.message.own{justify-content:flex-end}.message.other{justify-content:flex-start}.message-bubble{max-width:70%;padding:.75rem 1rem;border-radius:1rem;position:relative}.message.own .message-bubble{background:linear-gradient(135deg,var(--hope-color),#eab308);color:#fff;border-bottom-right-radius:.25rem}.message.other .message-bubble{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:.25rem}.message-sender{font-size:.75rem;font-weight:600;margin-bottom:.25rem;opacity:.8}.message-content{font-size:.938rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.message-timestamp{font-size:.688rem;margin-top:.25rem;opacity:.7;text-align:right}.message-input{border-top:1px solid var(--border);padding:1rem 1.5rem;background:var(--bg-secondary)}.message-input textarea{width:100%;min-height:44px;max-height:150px;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:.938rem;resize:none;margin-bottom:.5rem}.message-input textarea:focus{outline:none;border-color:var(--hope-color)}.message-input-footer{display:flex;justify-content:space-between;align-items:center}.char-count{font-size:.75rem;color:var(--text-muted)}.char-count.warning{color:var(--fear-color);font-weight:600}.message-input-disabled{border-top:1px solid var(--border);padding:1rem 1.5rem;background:var(--bg-secondary);text-align:center;color:var(--text-muted);font-size:.875rem}.message-input-disabled p{margin:0}.btn-sm{padding:.5rem 1rem;font-size:.875rem}@media(max-width:767px){.messaging-view{flex-direction:column}.conversation-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border)}.chat-area{width:100%}.message-bubble{max-width:85%}}.conversation-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:8px}.conversation-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:var(--bg-secondary)}.conversation-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.conversation-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.wizard-progress{margin-bottom:2rem}.progress-steps{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:var(--card-bg);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s;min-width:80px;flex:1}.progress-step:hover:not(:disabled){border-color:var(--hope-color);background:var(--card-hover-bg)}.progress-step.current{border-color:var(--hope-color);background:var(--hope-color-10)}.progress-step.completed{border-color:var(--success-color);background:var(--success-color-10)}.progress-step:disabled{opacity:.4;cursor:not-allowed}.step-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg);border:2px solid var(--border);font-weight:600;font-size:.875rem}.progress-step.current .step-number{border-color:var(--hope-color);background:var(--hope-color);color:#fff}.progress-step.completed .step-number{border-color:var(--success-color);background:var(--success-color);color:#fff}.step-name{font-size:.75rem;font-weight:500;text-align:center;color:var(--text-secondary)}.progress-step.current .step-name{color:var(--hope-color);font-weight:600}.progress-step.completed .step-name{color:var(--success-color)}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--hope-color),var(--success-color));transition:width .3s ease;border-radius:4px}@media(max-width:768px){.progress-steps{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.5rem}.progress-step{min-width:60px;flex:0 0 auto}.step-name{display:none}}.step-navigation{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;margin-top:2rem;border-top:2px solid var(--border)}.nav-buttons{display:flex;gap:1rem}@media(max-width:768px){.step-navigation{flex-direction:column;gap:1rem}.nav-buttons{width:100%;flex-direction:column}.nav-buttons button{width:100%}.step-navigation>button{width:100%}}.wizard-step{display:flex;flex-direction:column;gap:2rem}.step-header{text-align:center}.step-header h2{margin:0 0 .5rem;color:var(--hope-color)}.step-description{margin:0;color:var(--text-secondary);font-size:1.125rem}.step-content{background:var(--card-bg);border:2px solid var(--border);border-radius:12px;padding:2rem}.api-settings{padding:2rem;max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.settings-header{text-align:center;margin-bottom:1rem}.settings-header h2{margin:0 0 .5rem}.settings-subtitle{margin:0;color:var(--text-secondary)}.api-info{background:var(--card-bg);border-left:4px solid var(--hope-color)}.api-info h3{margin:0 0 .5rem}.api-info p{margin:0 0 1rem;color:var(--text-secondary)}.api-info ul{margin:0;padding-left:1.5rem}.api-info li{margin-bottom:.5rem;color:var(--text-secondary)}.api-section{display:flex;flex-direction:column;gap:1.5rem}.api-section-header{display:flex;justify-content:space-between;align-items:flex-start}.api-section-header h3{margin:0 0 .25rem}.api-description{margin:0;color:var(--text-secondary);font-size:.875rem}.key-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500}.key-status.success{background:var(--success-color-10);color:var(--success-color);border:1px solid var(--success-color)}.key-input-section{display:flex;flex-direction:column;gap:1rem}.key-input-wrapper{display:flex;gap:.5rem}.key-input{flex:1;padding:.75rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text);font-family:monospace;font-size:.875rem}.btn-icon{padding:.75rem;background:var(--card-bg);border:1px solid var(--border);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:all .2s}.btn-icon:hover{background:var(--card-hover-bg);border-color:var(--hope-color)}.key-actions{display:flex;gap:1rem}.test-result{border-left:4px solid;animation:slideIn .3s ease}.test-result.success{border-color:var(--success-color);background:var(--success-color-10)}.test-result.error{border-color:var(--error-color);background:var(--error-color-10)}.test-result-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.test-result.success .test-result-header{color:var(--success-color)}.test-result.error .test-result-header{color:var(--error-color)}.test-result p{margin:0 0 .5rem;color:var(--text)}.test-response{margin-top:.5rem;padding:.5rem;background:var(--bg);border-radius:4px}.test-response small{display:block;margin-bottom:.25rem;color:var(--text-secondary);font-weight:600}.test-response code{display:block;font-family:monospace;font-size:.875rem;color:var(--text)}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.api-settings{padding:1rem}.api-section-header{flex-direction:column;gap:1rem}.key-actions{flex-direction:column}.key-actions button{width:100%}}.app{display:flex;min-height:100vh;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.main-content{flex:1;overflow-y:auto;min-height:100vh}.app.player-mode .btn-primary{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));color:var(--bg-primary)}.app.dm-mode .btn-primary{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff}.main-content::-webkit-scrollbar{width:10px}.main-content::-webkit-scrollbar-track{background:var(--bg-primary)}.main-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}.main-content::-webkit-scrollbar-thumb:hover{background:#fff3}.loading-view{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--text-muted)}.loading-view .loading-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--hope-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem}.loading-view p{font-size:1.1rem}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:767px){.app{flex-direction:column}.main-content{margin-left:0;padding-top:60px;min-width:0}}:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--text-primary: #e8e6e3;--text-muted: rgba(232, 230, 227, .7);--hope-color: #eab308;--hope-secondary: #f59e0b;--fear-color: #8b5cf6;--fear-secondary: #a78bfa;--danger: #ef4444;--border: rgba(255, 255, 255, .1);--card-bg: rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Crimson Pro,Georgia,serif;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);color:var(--text-primary);min-height:100vh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:Cinzel,serif;font-weight:600;line-height:1.3}button{font-family:Crimson Pro,Georgia,serif;cursor:pointer;transition:all .2s ease}input,textarea,select{font-family:Crimson Pro,Georgia,serif}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.container{max-width:100%;margin:0 auto;padding:1rem}@media(min-width:768px){.container{padding:1.5rem}}@media(min-width:1024px){.container{max-width:1400px;padding:2rem}}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:all .3s ease}.card:hover{border-color:#fff3;transform:translateY(-2px)}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:500;font-size:.95rem;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease;min-height:44px}.btn:hover{transform:translateY(-2px);filter:brightness(1.1)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));color:var(--bg-primary)}.btn-primary.dm-mode{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-icon{padding:.5rem;background:transparent;border:1px solid var(--border);color:var(--text-primary)}.btn-icon:hover{background:var(--card-bg)}.input-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.input-group label{font-weight:500;font-size:.95rem;color:var(--text-primary)}.input-group input,.input-group textarea,.input-group select{padding:.875rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.95rem;min-height:44px}.input-group input:focus,.input-group textarea:focus,.input-group select:focus{outline:none;border-color:var(--hope-color)}.dm-mode .input-group input:focus,.dm-mode .input-group textarea:focus,.dm-mode .input-group select:focus{border-color:var(--fear-color)}.input-group textarea{resize:vertical;min-height:100px}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:500;background:var(--card-bg);border:1px solid var(--border)}.badge-hope{background:linear-gradient(135deg,var(--hope-color),var(--hope-secondary));color:var(--bg-primary);border:none}.badge-fear{background:linear-gradient(135deg,var(--fear-color),var(--fear-secondary));color:#fff;border:none}.badge-danger{background:var(--danger);color:#fff;border:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .3s ease}.slide-in{animation:slideIn .3s ease}.mobile-only{display:block}.desktop-only{display:none}@media(min-width:768px){.mobile-only{display:none}.desktop-only{display:block}}.flex-mobile-column{flex-direction:column}@media(min-width:768px){.flex-mobile-column{flex-direction:row}}.grid-mobile-1-tablet-2-desktop-3{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.grid-mobile-1-tablet-2-desktop-3{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media(min-width:1024px){.grid-mobile-1-tablet-2-desktop-3{grid-template-columns:repeat(3,1fr);gap:2rem}}.view-header{display:flex;flex-direction:column;gap:1rem;align-items:stretch;margin-bottom:1.5rem}.view-header h1{font-size:1.5rem}.view-header .btn{width:100%}@media(min-width:768px){.view-header{flex-direction:row;justify-content:space-between;align-items:center}.view-header h1{font-size:2rem}.view-header .btn{width:auto}}.characters-view,.lore-view,.sessions-view,.tools-view,.files-view,.npcs-view,.locations-view,.timeline-view{padding:1rem}@media(min-width:768px){.characters-view,.lore-view,.sessions-view,.tools-view,.files-view,.npcs-view,.locations-view,.timeline-view{padding:1.5rem}}@media(min-width:1024px){.characters-view,.lore-view,.sessions-view,.tools-view,.files-view,.npcs-view,.locations-view,.timeline-view{padding:2rem}}
