@keyframes alertSlideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes alertSlideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}@keyframes alertProgress{0%{width:100%}to{width:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}:root{--bg-primary:#0d0d0f;--bg-secondary:#16161a;--bg-tertiary:#1e1e24;--bg-elevated:#252530;--text-primary:#e8e6e3;--text-secondary:#94929d;--text-muted:#5c5a66;--border:#2a2a35;--border-subtle:#1f1f28;--accent:#c9a962;--accent-dim:#8a7644;--accent-glow:rgba(201, 169, 98, 0.15);--townsfolk:#4a8ed4;--townsfolk-bg:rgba(74, 142, 212, 0.12);--outsider:#5ac4c4;--outsider-bg:rgba(90, 196, 196, 0.12);--minion:#b08968;--minion-bg:rgba(176, 137, 104, 0.12);--demon:#c45c5c;--demon-bg:rgba(196, 92, 92, 0.15);--traveller:#7a6a8a;--traveller-bg:rgba(122, 106, 138, 0.12);--tag-bg:rgba(255, 255, 255, 0.08);--tag-text:#94929d;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--transition:0.2s ease}[data-theme=light]{--bg-primary:#faf9f7;--bg-secondary:#f2f0ed;--bg-tertiary:#e8e6e3;--bg-elevated:#ffffff;--text-primary:#1a1a1e;--text-secondary:#5c5a66;--text-muted:#94929d;--border:#e0ded9;--border-subtle:#eae8e4;--accent:#8a6d2f;--accent-dim:#b8954a;--accent-glow:rgba(138, 109, 47, 0.1);--townsfolk:#3a7ec4;--townsfolk-bg:rgba(58, 126, 196, 0.1);--outsider:#4aabab;--outsider-bg:rgba(74, 171, 171, 0.1);--minion:#96724a;--minion-bg:rgba(150, 114, 74, 0.1);--demon:#b04040;--demon-bg:rgba(176, 64, 64, 0.1);--traveller:#5a4a6a;--traveller-bg:rgba(90, 74, 106, 0.1);--tag-bg:rgba(0, 0, 0, 0.06);--tag-text:#5c5a66}*{margin:0;padding:0;box-sizing:border-box}body{font-family:"Crimson Pro",Georgia,serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background var(--transition),color var(--transition)}body::before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.02;pointer-events:none;z-index:0}.container{max-width:900px;margin:0 auto;padding:0 24px;position:relative;z-index:1}p{margin-bottom:20px}li{margin-left:20px}li a,p a{color:var(--text-secondary);transition:color var(--transition)}.filter-bar-text a,.header-link:hover,li a:hover,p a:hover{color:var(--accent)}.print-logo{display:none;font-size:1.5rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-decoration:none}header{padding:32px 0 48px;border-bottom:1px solid var(--border-subtle)}.header-content{display:flex;justify-content:space-between;align-items:center}.logo,.page-interaction-title h1 a{text-decoration:none;align-items:center}.logo{font-size:1.5rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-primary);display:flex;gap:12px}.header-actions,.logo-icon{display:flex;align-items:center}.logo-icon{width:32px;height:32px;background:var(--accent);border-radius:50%;justify-content:center;color:var(--bg-primary)}.header-actions{gap:24px}.header-link{color:var(--text-secondary);text-decoration:none;font-size:.95rem;transition:color var(--transition)}.theme-toggle{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.print-btn:hover,.theme-toggle:hover{border-color:var(--accent-dim);color:var(--accent)}main{padding:56px 0}.page-header{text-align:center;margin-bottom:48px}.page-header h1{font-size:2rem;font-weight:500;margin-bottom:12px}.hero-text p,.page-header p{color:var(--text-secondary);font-size:1.1rem}.page-interaction-header{margin-bottom:40px}.page-interaction-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:16px}.page-interaction-title{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.page-interaction-title h1{font-size:2rem;font-weight:500;margin:0}.page-interaction-title h1 a{display:inline-flex;gap:8px}.filter-bar-text a:hover,.page-interaction-title h1 a:hover{text-decoration:underline}h1 a.townsfolk{color:var(--townsfolk)}h1 a.outsider{color:var(--outsider)}h1 a.minion{color:var(--minion)}h1 a.demon{color:var(--demon)}h1 a.traveller{color:var(--traveller)}.page-interaction-title h1 a svg{width:18px;height:18px;opacity:.7}.page-interaction-actions{display:flex;gap:12px}.filter-bar,.print-btn{background:var(--bg-secondary);border:1px solid var(--border);align-items:center}.print-btn{display:inline-flex;gap:8px;padding:10px 16px;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:all var(--transition);cursor:pointer;font-family:inherit}.print-btn:hover{background:var(--bg-tertiary)}.btn-contribute svg,.print-btn svg{width:16px;height:16px}.filter-bar{border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:40px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}.filter-bar-text{color:var(--text-secondary);font-size:.95rem}.filter-bar-text a,li a,p a{text-decoration:none}.filter-input{padding:12px 18px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all var(--transition);min-width:220px}.filter-input:focus,.input-group input:focus,.input-group textarea:focus{outline:0;border-color:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}.filter-input::placeholder{color:var(--text-muted);opacity:.6}.character-section{margin-bottom:32px}.section-header{gap:12px}.section-title{font-weight:500;padding:6px 14px;border-radius:var(--radius-sm)}.section-count{font-size:.8rem;color:var(--text-muted);font-family:"JetBrains Mono",monospace}.character-section.townsfolk .section-title{background:var(--townsfolk-bg);color:var(--townsfolk)}.character-section.outsider .section-title{background:var(--outsider-bg);color:var(--outsider)}.character-section.minion .section-title{background:var(--minion-bg);color:var(--minion)}.character-section.demon .section-title{background:var(--demon-bg);color:var(--demon)}.character-section.traveller .section-title{background:var(--traveller-bg);color:var(--traveller)}.character-section.tag .section-title{background:var(--tag-bg);color:var(--tag-text)}.character-list{display:flex;flex-wrap:wrap;gap:8px}.character-badge{display:inline-block;text-decoration:none;transition:all var(--transition);border:1px solid transparent}.character-badge:hover{transform:translateY(-1px)}.character-badge.highlighted{border-color:currentColor;transform:translateY(-1px)}.character-section .character-badge.disabled{background:0 0!important;border:1px solid var(--accent)}.character-section.townsfolk .character-badge{background:var(--townsfolk-bg);color:var(--townsfolk)}.character-section.townsfolk .character-badge.highlighted,.character-section.townsfolk .character-badge:hover{background:rgba(74,142,212,.2)}.character-section.outsider .character-badge{background:var(--outsider-bg);color:var(--outsider)}.character-section.outsider .character-badge.highlighted,.character-section.outsider .character-badge:hover{background:rgba(90,196,196,.2)}.character-section.minion .character-badge{background:var(--minion-bg);color:var(--minion)}.character-section.minion .character-badge.highlighted,.character-section.minion .character-badge:hover{background:rgba(176,137,104,.2)}.character-section.demon .character-badge{background:var(--demon-bg);color:var(--demon)}.character-section.demon .character-badge.highlighted,.character-section.demon .character-badge:hover{background:rgba(196,92,92,.25)}.character-section.traveller .character-badge{background:var(--traveller-bg);color:var(--traveller)}.character-section.traveller .character-badge.highlighted,.character-section.traveller .character-badge:hover{background:rgba(154,127,173,.2)}.character-section.tag .character-badge{background:var(--tag-bg);color:var(--tag-text)}.character-section.tag .character-badge.highlighted,.character-section.tag .character-badge:hover{background:rgba(62,62,62,.2)}.hero-text{text-align:center;margin-bottom:48px}.hero-text h1{font-size:2rem;font-weight:500;margin-bottom:12px}.hero-text a,.page-header a{color:var(--text-secondary);text-decoration:none;font-style:italic;transition:color var(--transition)}.hero-text a:hover,.input-group label a:hover,.page-header a:hover{color:var(--accent)}.search-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;margin-bottom:48px;position:relative;z-index:100}.tab,.tabs{display:flex}.tabs{gap:4px;margin-bottom:28px;border-bottom:1px solid var(--border);padding-bottom:16px}.tab{padding:10px 20px;border:0;background:0 0;color:var(--text-secondary);font-family:inherit;font-size:1rem;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition);position:relative;align-items:center;gap:8px}.input-group input,.input-group textarea,.tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab.active{color:var(--accent);background:var(--accent-glow)}.input-group label,.tab .badge{text-transform:uppercase;font-family:"JetBrains Mono",monospace}.tab .badge{font-size:.6rem;letter-spacing:.05em;color:var(--accent);background:var(--accent-glow);padding:2px 6px;border-radius:4px;margin-left:8px}.tab-content{display:none}.tab-content.active{display:block}.form-row-inline{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.form-row-inline .input-group{flex:1;min-width:200px}.form-row-inline.single .input-group{flex:2}.form-actions-inline{display:flex;gap:8px;align-items:flex-end;padding-bottom:1px}.input-group{display:flex;flex-direction:column;gap:8px;position:relative}.input-group label{font-size:.85rem;color:var(--text-muted);letter-spacing:.08em}.input-group label a{color:var(--text-muted);text-decoration:none}.input-group input,.input-group textarea{padding:14px 18px;border:1px solid var(--border);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:all var(--transition);width:100%}.input-group textarea{min-height:100px;resize:vertical}.input-group input::placeholder,.input-group textarea::placeholder{color:var(--text-muted);opacity:.5}.form-connector{color:var(--text-muted);font-style:italic;padding-bottom:14px;text-align:center;white-space:nowrap}.btn{padding:12px 20px;border:0;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;cursor:pointer;transition:all var(--transition);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;line-height:1.2}.btn-primary{background:var(--accent);color:var(--bg-primary);font-weight:500}.btn-primary:hover{background:var(--accent-dim);transform:translateY(-1px)}.btn-primary.disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-elevated);color:var(--text-primary)}.selection-display{display:none;align-items:center;gap:8px}.selection-display.active{display:flex}.selection-badge{padding:12px 18px;border-radius:var(--radius-md);font-weight:500;display:flex;align-items:center;gap:8px}.autocomplete-item .char-badge.townsfolk,.selection-badge.townsfolk{background:var(--townsfolk-bg);color:var(--townsfolk)}.autocomplete-item .char-badge.outsider,.selection-badge.outsider{background:var(--outsider-bg);color:var(--outsider)}.autocomplete-item .char-badge.minion,.selection-badge.minion{background:var(--minion-bg);color:var(--minion)}.autocomplete-item .char-badge.demon,.selection-badge.demon{background:var(--demon-bg);color:var(--demon)}.autocomplete-item .char-badge.traveller,.selection-badge.traveller{background:var(--traveller-bg);color:var(--traveller)}.autocomplete-item .char-badge.tag,.selection-badge.tag{background:var(--tag-bg);color:var(--tag-text)}.selection-close{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.selection-close:hover{background:var(--demon-bg);border-color:var(--demon);color:var(--demon)}.autocomplete-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);max-height:300px;overflow-y:auto;z-index:1000;display:none;box-shadow:0 8px 32px rgba(0,0,0,.3)}.autocomplete-list.active{display:block}.autocomplete-item{padding:12px 16px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-subtle)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item.active,.autocomplete-item:hover{background:var(--outsider-bg)}.autocomplete-item .char-badge{font-size:.75rem;font-family:"JetBrains Mono",monospace;padding:4px 10px;border-radius:var(--radius-sm);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.grimoire-content{color:var(--text-secondary)}.drawer-body p,.grimoire-content p{margin-bottom:16px}.grimoire-content ol{margin:16px 0;padding-left:24px}.grimoire-content li{margin-bottom:8px}.grimoire-content .btn-bookmarklet{background:var(--townsfolk);color:#fff;margin:16px 0}.grimoire-content h3{color:var(--text-primary);font-size:1.1rem;margin:24px 0 12px}.recent-section{margin-bottom:48px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);font-family:"JetBrains Mono",monospace}.footer-links a,.section-action{transition:color var(--transition)}.section-action{font-size:.85rem;color:var(--text-secondary);text-decoration:none;cursor:pointer}.footer-copyright a:hover,.footer-links a:hover,.section-action:hover{color:var(--accent)}.recent-grid{display:flex;flex-wrap:wrap;gap:10px}.recent-item{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:all var(--transition)}.recent-item:hover{border-color:var(--border);background:var(--bg-tertiary);transform:translateY(-1px)}.character-badge{font-size:.75rem;font-family:"JetBrains Mono",monospace;padding:3px 8px;border-radius:var(--radius-sm);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.character-badge.townsfolk{background:var(--townsfolk-bg);color:var(--townsfolk)}.character-badge.outsider{background:var(--outsider-bg);color:var(--outsider)}.character-badge.minion{background:var(--minion-bg);color:var(--minion)}.character-badge.demon{background:var(--demon-bg);color:var(--demon)}.character-badge.traveller{background:var(--traveller-bg);color:var(--traveller)}.character-badge.tag{background:var(--tag-bg);color:var(--tag-text)}.recent-item .type{font-size:.85rem;color:var(--text-secondary)}.recent-item .link-icon{color:var(--text-muted);font-size:.8rem}.quick-links{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:64px}.quick-link{padding:24px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition)}.quick-link:hover{border-color:var(--border);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}.quick-link-icon{width:40px;height:40px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;background:var(--accent-glow);border-radius:var(--radius-md);color:var(--accent)}.quick-link-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:4px}.quick-link-desc{font-size:.9rem;color:var(--text-secondary)}footer{border-top:1px solid var(--border-subtle);padding:40px 0}.footer-content{display:flex;justify-content:space-between;align-items:flex-start}.footer-info{max-width:400px}.footer-brand{font-size:1rem;font-weight:500;color:var(--text-primary);margin-bottom:12px}.footer-text{font-size:.9rem;color:var(--text-muted);line-height:1.7}.footer-links{display:flex;gap:32px}.footer-links a{font-size:.9rem}.footer-bottom{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.footer-copyright{font-size:.85rem;color:var(--text-muted)}.footer-copyright a,.footer-legal a,.footer-links a{color:var(--text-secondary);text-decoration:none}.footer-legal{display:flex;gap:24px}.footer-legal a{font-size:.85rem;color:var(--text-muted);transition:color var(--transition)}.footer-legal a:hover{color:var(--text-secondary)}.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;opacity:0;visibility:hidden;transition:all var(--transition)}.drawer-overlay.active{opacity:1;visibility:visible}.drawer{position:fixed;top:0;left:0;width:400px;max-width:90vw;height:100vh;background:var(--bg-secondary);z-index:1001;transform:translateX(-100%);transition:transform .3s ease;overflow-y:auto}.drawer.active{transform:translateX(0)}.drawer-header{padding:24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.drawer-title{font-size:1.2rem;font-weight:500}.drawer-close{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:0 0;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.drawer-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.drawer-body{padding:24px;color:var(--text-secondary);line-height:1.8}.drawer-body a{color:var(--accent)}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.tag-list .tag{background:var(--tag-bg);color:var(--tag-text);padding:4px 10px;border-radius:var(--radius-sm);font-size:.85rem}.interactions-list{display:flex;flex-direction:column;gap:16px}.interaction-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition)}.interaction-card:hover{border-color:var(--border);box-shadow:0 4px 20px rgba(0,0,0,.15)}.interaction-card.townsfolk{border-left:3px solid var(--townsfolk)}.interaction-card.outsider{border-left:3px solid var(--outsider)}.interaction-card.minion{border-left:3px solid var(--minion)}.interaction-card.demon{border-left:3px solid var(--demon)}.interaction-card.traveller{border-left:3px solid var(--traveller)}.interaction-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.interaction-with{display:flex;align-items:center;gap:8px}.interaction-with-label{font-size:.85rem;color:var(--text-muted)}.interaction-character{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-sm);text-decoration:none;font-size:.9rem;font-weight:500;transition:all var(--transition)}.interaction-character:hover{transform:translateY(-1px)}.interaction-description{font-size:1.05rem;line-height:1.7;color:var(--text-primary);margin-bottom:16px}.interaction-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.interaction-tags{display:flex;flex-wrap:wrap;gap:6px}.interaction-tag{display:inline-block;padding:4px 10px;background:var(--tag-bg);color:var(--tag-text);border-radius:var(--radius-sm);font-size:.8rem;text-decoration:none;transition:all var(--transition)}.interaction-tag:hover{background:var(--accent-glow);color:var(--accent)}.interaction-meta{font-size:.8rem;color:var(--text-muted)}.contribute-section{margin-top:40px;padding-top:32px;border-top:1px solid var(--border-subtle)}.btn-contribute{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border:1px solid var(--townsfolk);border-radius:var(--radius-md);background:var(--townsfolk-bg);color:var(--townsfolk);text-decoration:none;font-size:.95rem;transition:all var(--transition)}.btn-contribute:hover{background:rgba(74,142,212,.2);transform:translateY(-1px)}@media (max-width:1024px){.container{padding:0 20px}.quick-links{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){header{padding:24px 0 32px}.logo{font-size:1.2rem;letter-spacing:.08em}.logo-icon{width:28px;height:28px}.header-link{display:none}main{padding:40px 0}.hero-text h1,.page-header h1,.page-interaction-title h1{font-size:1.6rem}.page-interaction-header-top{flex-direction:column;gap:16px}.page-interaction-actions{width:100%}.print-btn{flex:1;justify-content:center}.filter-bar{flex-direction:column;align-items:stretch;gap:16px}.filter-input{width:100%;min-width:auto}.hero-text{margin-bottom:32px}.hero-text p{font-size:1rem}.search-section{padding:24px 20px}.tabs{flex-direction:column;gap:4px;margin-bottom:20px;padding-bottom:16px}.tab{padding:12px 16px;font-size:.95rem;text-align:left;width:100%;justify-content:flex-start}.tab .badge{margin-left:auto}.form-row-inline{flex-direction:column}.form-row-inline .input-group{width:100%;min-width:auto}.form-connector{display:none}.form-actions-inline{width:100%;margin-top:8px}.form-actions-inline .btn{flex:1}.section-header{flex-direction:column;align-items:flex-start;gap:8px}.recent-grid{gap:8px}.recent-item{padding:8px 12px;font-size:.9rem}.character-badge{font-size:.7rem;padding:2px 6px}.quick-links{grid-template-columns:1fr;gap:12px;margin-bottom:48px}.quick-link{padding:20px}.footer-content{flex-direction:column;gap:28px}.footer-links{flex-wrap:wrap;gap:16px 24px}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.footer-legal{justify-content:center}.interaction-card{padding:20px}.interaction-header{flex-direction:column;gap:12px}.interaction-footer{flex-direction:column;align-items:flex-start}}@media (max-width:480px){.container{padding:0 16px}.logo{font-size:1rem}.hero-text h1{font-size:1.4rem}.search-section{padding:20px 16px;border-radius:var(--radius-md)}.tab{padding:10px 14px;font-size:.9rem}.recent-item{width:100%;justify-content:space-between}.quick-link-icon{width:36px;height:36px}.quick-link-icon svg{width:20px;height:20px}.quick-link-title{font-size:1rem}.interaction-title{flex-direction:column;align-items:flex-start;gap:8px}.interaction-tags{gap:4px}.interaction-tag{padding:3px 8px;font-size:.75rem}}@media (hover:none) and (pointer:coarse){.autocomplete-item,.btn,.quick-link,.recent-item,.tab{min-height:44px}.theme-toggle{width:44px;height:44px}}.alert-container{position:fixed;top:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:12px;max-width:400px}.alert{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 48px 16px 20px;box-shadow:0 8px 32px rgba(0,0,0,.3);position:relative;animation:alertSlideIn .3s ease}.alert.hiding{animation:alertSlideOut .3s ease forwards}.alert-content{display:flex;align-items:flex-start;gap:12px}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-message{font-size:.95rem;line-height:1.5;color:var(--text-primary)}.alert-close{position:absolute;top:12px;right:12px;width:24px;height:24px;border:0;background:0 0;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition)}.alert-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.alert-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--accent);border-radius:0 0 var(--radius-md) var(--radius-md);animation:alertProgress 15s linear forwards}.alert.success{border-color:var(--outsider)}.alert.success .alert-icon{color:var(--outsider)}.alert.success .alert-progress{background:var(--outsider)}.alert.danger{border-color:var(--demon)}.alert.danger .alert-icon{color:var(--demon)}.alert.danger .alert-progress{background:var(--demon)}.alert.warning{border-color:var(--accent)}.alert.warning .alert-icon{color:var(--accent)}.alert.warning .alert-progress{background:var(--accent)}.alert.info{border-color:var(--townsfolk)}.alert.info .alert-icon{color:var(--townsfolk)}.alert.info .alert-progress{background:var(--townsfolk)}@media (max-width:480px){.alert-container{top:16px;right:16px;left:16px;max-width:none}}.quick-links,.recent-section,.search-section{animation:fadeIn .5s ease forwards}.recent-section{animation-delay:.1s}.quick-links{animation-delay:.2s}.character-section,.filter-bar{animation:fadeIn .5s ease forwards}.character-section:nth-child(2){animation-delay:.05s}.character-section:nth-child(3){animation-delay:.1s}.character-section:nth-child(4){animation-delay:.15s}.character-section:nth-child(5){animation-delay:.2s}.interaction-card{animation:fadeIn .4s ease forwards}.interaction-card:nth-child(1){animation-delay:.05s}.interaction-card:nth-child(2){animation-delay:.1s}.interaction-card:nth-child(3){animation-delay:.15s}.interaction-card:nth-child(4){animation-delay:.2s}.interaction-card:nth-child(5){animation-delay:.25s}@media print{.btn-contribute,.filter-bar,.header-actions,.interaction-footer,.logo,.page-interaction-actions,.quick-links,.recent-section,.search-section,.theme-toggle,footer{display:none!important}.interaction-card,body{background:#fff;color:#000!important}.interaction-card{break-inside:avoid;border:0;box-shadow:none;padding:0}.interactions-list{gap:1px}.interaction-card.demon,.interaction-card.minion,.interaction-card.outsider,.interaction-card.townsfolk,.interaction-card.traveller{border-left:0 none}.interaction-header{color:#000!important;margin-bottom:2px}.print-logo{display:block}}
