@charset "UTF-8";html body[data-theme=dark]{article,aside,div,footer,header,input,main,nav,section,select,textarea{color:#fff;color:var(--text-dark)}input,select,textarea{background-color:#2a2a2a;background-color:var(--input-bg-dark);border-color:#444;border-color:var(--border-dark)}a{color:#4fa6e0;color:var(--primary-dark)}.menu,.modal,.tooltip,[class*=dropdown],[class*=modal],[class*=popup],div[role=dialog]{background-color:#2a2a2a;background-color:var(--bg-dark-card);border-color:#444;border-color:var(--border-dark);color:#fff;color:var(--text-dark)}.content-card,.homepage,.main-content,.preferences-page,.user-profile-container,main{background-color:#121212!important;background-color:var(--bg-dark)!important}.card,.content-card,.homepage-content,.welcome-section{background-color:#2a2a2a!important;background-color:var(--bg-dark-card)!important;color:#fff!important;color:var(--text-dark)!important}}html body[data-theme=dark]{article,aside,div,footer,header,input,main,nav,section,select,textarea{color:#fff;color:var(--text-dark)}input,select,textarea{background-color:#2a2a2a;background-color:var(--input-bg-dark);border-color:#444;border-color:var(--border-dark)}a{color:#4fa6e0;color:var(--primary-dark)}.menu,.modal,.tooltip,[class*=dropdown],[class*=modal],[class*=popup],div[role=dialog]{background-color:#2a2a2a;background-color:var(--bg-dark-card);border-color:#444;border-color:var(--border-dark);color:#fff;color:var(--text-dark)}.content-card,.homepage,.main-content,.preferences-page,.user-profile-container,main{background-color:#121212!important;background-color:var(--bg-dark)!important}.card,.content-card,.homepage-content,.welcome-section{background-color:#2a2a2a!important;background-color:var(--bg-dark-card)!important;color:#fff!important;color:var(--text-dark)!important}}.chat-input textarea:disabled{background:#f1f1f1;background:var(--bg-disabled,#f1f1f1);color:#888;color:var(--text-secondary,#888);cursor:not-allowed;opacity:.6}.chat-input button:disabled{background:#ccc;background:var(--button-disabled-bg,#ccc);color:#666;color:var(--text-secondary,#666);cursor:not-allowed;opacity:.6}.chat-input button:hover{background:var(--button-hover)}.presenter-chat-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;padding:16px 16px env(safe-area-inset-bottom,0);position:fixed;z-index:1200}.presenter-chat-window{border-radius:12px;bottom:auto!important;height:45vh!important;margin-bottom:55px;max-height:45vh!important;max-width:600px;overflow:hidden;position:relative;width:95vw}.presenter-chat-window .chat-header{font-size:1rem;padding:14px 18px}.presenter-chat-window .chat-close,.presenter-chat-window .chat-min{font-size:20px;height:32px;width:32px}.presenter-chat-window .chat-messages{padding:.8rem}.presenter-chat-window .chat-input textarea{font-size:1rem;height:35px}.presenter-chat-window .chat-input button{font-size:1rem;height:35px;padding:0 .6rem}.presenter-chat-window .chat-input{border-top:1px solid var(--border-color);display:flex;padding-bottom:env(safe-area-inset-bottom,0)}@media (max-width:600px){.presenter-chat-overlay{align-items:flex-end;justify-content:center;padding:0}.presenter-chat-window{border-radius:12px 12px 0 0;height:45vh!important;margin-bottom:55px;width:100vw}}.toast-container{align-items:center;display:flex;flex-direction:column;left:50%;pointer-events:none;position:fixed;top:12px;transform:translateX(-50%);z-index:10000}.toast{animation:slideDown .35s ease-out forwards,fadeOut .35s ease-in 7.65s forwards;background:#000000d9;border-radius:4px;box-shadow:0 2px 6px #0000004d;color:#fff;cursor:pointer;font-size:.9rem;margin-top:6px;min-width:220px;padding:10px 16px;pointer-events:auto;text-align:center}.toast.success{background:#28a745}.toast.error{background:#dc3545}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-15px)}to{opacity:1;transform:translate(-50%)}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--font-primary:"Quicksand",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--primary-light:#3498db;--primary-light-rgb:52,152,219;--secondary-light:#2ecc71;--secondary-light-rgb:46,204,113;--accent-light:#e74c3c;--accent-light-rgb:231,76,60;--bg-light:#c0ebff;--bg-light-rgb:192,235,255;--bg-light-alt:#f5f5f5;--bg-light-alt-rgb:245,245,245;--bg-light-card:#fff;--bg-light-card-rgb:255,255,255;--text-light:#333;--text-light-rgb:51,51,51;--text-light-secondary:#666;--text-light-secondary-rgb:102,102,102;--text-light-tertiary:#999;--text-light-tertiary-rgb:153,153,153;--border-light:#ddd;--border-light-rgb:221,221,221;--shadow-light:#0000001a;--shadow-light-rgb:0,0,0;--input-bg-light:#fff;--input-bg-light-rgb:255,255,255;--hover-light:#f0f7ff;--hover-light-rgb:240,247,255;--button-light:#4a4a4a;--button-light-rgb:74,74,74;--button-hover-light:#6a6a6a;--button-hover-light-rgb:106,106,106;--button-text-light:#fff;--button-text-light-rgb:255,255,255;--success-light:#2ecc71;--success-light-rgb:46,204,113;--error-light:#e74c3c;--error-light-rgb:231,76,60;--warning-light:#f39c12;--warning-light-rgb:243,156,18;--info-light:#3498db;--info-light-rgb:52,152,219;--primary-dark:#4fa6e0;--primary-dark-rgb:79,166,224;--secondary-dark:#43d47e;--secondary-dark-rgb:67,212,126;--accent-dark:#e95e4f;--accent-dark-rgb:233,94,79;--bg-dark:#121212;--bg-dark-rgb:18,18,18;--bg-dark-alt:#1e1e1e;--bg-dark-alt-rgb:30,30,30;--bg-dark-card:#2a2a2a;--bg-dark-card-rgb:42,42,42;--text-dark:#fff;--text-dark-rgb:255,255,255;--text-dark-secondary:#ccc;--text-dark-secondary-rgb:204,204,204;--text-dark-tertiary:grey;--text-dark-tertiary-rgb:128,128,128;--border-dark:#444;--border-dark-rgb:68,68,68;--shadow-dark:#00000080;--shadow-dark-rgb:0,0,0;--input-bg-dark:#2a2a2a;--input-bg-dark-rgb:42,42,42;--hover-dark:#2c3a47;--hover-dark-rgb:44,58,71;--button-dark:#5c5c5c;--button-dark-rgb:92,92,92;--button-hover-dark:#7a7a7a;--button-hover-dark-rgb:122,122,122;--button-text-dark:#fff;--button-text-dark-rgb:255,255,255;--success-dark:#43d47e;--success-dark-rgb:67,212,126;--error-dark:#e95e4f;--error-dark-rgb:233,94,79;--warning-dark:#f5b041;--warning-dark-rgb:245,176,65;--info-dark:#4fa6e0;--info-dark-rgb:79,166,224;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-md:1.125rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:1.875rem;--font-size-3xl:2.25rem;--font-size-4xl:3rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-base:1.5;--line-height-relaxed:1.75;--space-0:0;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-8:3rem;--space-10:4rem;--space-12:6rem;--radius-sm:2px;--radius-md:4px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 4px #0000001a;--shadow-lg:0 4px 8px #00000026;--shadow-xl:0 8px 16px #0003;--shadow-2xl:0 12px 24px #00000040;--shadow-inner:inset 0 2px 4px #0000001a;--transition-fast:150ms;--transition-base:300ms;--transition-slow:500ms;--transition-timing-default:ease;--transition-timing-bounce:cubic-bezier(0.68,-0.55,0.27,1.55);--transition-timing-smooth:cubic-bezier(0.4,0,0.2,1);--z-index-dropdown:1000;--z-index-sticky:1100;--z-index-fixed:1200;--z-index-modal-backdrop:1300;--z-index-modal:1400;--z-index-popover:1500;--z-index-tooltip:1600}body[data-theme=light]{--primary:var(--primary-light);--primary-rgb:var(--primary-light-rgb);--secondary:var(--secondary-light);--secondary-rgb:var(--secondary-light-rgb);--accent:var(--accent-light);--accent-rgb:var(--accent-light-rgb);--bg-color:var(--bg-light);--bg-rgb:var(--bg-light-rgb);--bg-alt:var(--bg-light-alt);--bg-alt-rgb:var(--bg-light-alt-rgb);--bg-card:var(--bg-light-card);--bg-card-rgb:var(--bg-light-card-rgb);--text-color:var(--text-light);--text-rgb:var(--text-light-rgb);--text-secondary:var(--text-light-secondary);--text-secondary-rgb:var(--text-light-secondary-rgb);--text-tertiary:var(--text-light-tertiary);--text-tertiary-rgb:var(--text-light-tertiary-rgb);--border-color:var(--border-light);--border-rgb:var(--border-light-rgb);--shadow:var(--shadow-light);--shadow-rgb:var(--shadow-light-rgb);--input-bg:var(--input-bg-light);--input-bg-rgb:var(--input-bg-light-rgb);--hover-bg:var(--hover-light);--hover-bg-rgb:var(--hover-light-rgb);--button-bg:var(--button-light);--button-bg-rgb:var(--button-light-rgb);--button-hover:var(--button-hover-light);--button-hover-rgb:var(--button-hover-light-rgb);--button-text:var(--button-text-light);--button-text-rgb:var(--button-text-light-rgb);--success:var(--success-light);--success-rgb:var(--success-light-rgb);--error:var(--error-light);--error-rgb:var(--error-light-rgb);--warning:var(--warning-light);--warning-rgb:var(--warning-light-rgb);--info:var(--info-light);--info-rgb:var(--info-light-rgb)}body[data-theme=dark]{--primary:var(--primary-dark);--primary-rgb:var(--primary-dark-rgb);--secondary:var(--secondary-dark);--secondary-rgb:var(--secondary-dark-rgb);--accent:var(--accent-dark);--accent-rgb:var(--accent-dark-rgb);--bg-color:var(--bg-dark);--bg-rgb:var(--bg-dark-rgb);--bg-alt:var(--bg-dark-alt);--bg-alt-rgb:var(--bg-dark-alt-rgb);--bg-card:var(--bg-dark-card);--bg-card-rgb:var(--bg-dark-card-rgb);--text-color:var(--text-dark);--text-rgb:var(--text-dark-rgb);--text-secondary:var(--text-dark-secondary);--text-secondary-rgb:var(--text-dark-secondary-rgb);--text-tertiary:var(--text-dark-tertiary);--text-tertiary-rgb:var(--text-dark-tertiary-rgb);--border-color:var(--border-dark);--border-rgb:var(--border-dark-rgb);--shadow:var(--shadow-dark);--shadow-rgb:var(--shadow-dark-rgb);--input-bg:var(--input-bg-dark);--input-bg-rgb:var(--input-bg-dark-rgb);--hover-bg:var(--hover-dark);--hover-bg-rgb:var(--hover-dark-rgb);--button-bg:var(--button-dark);--button-bg-rgb:var(--button-dark-rgb);--button-hover:var(--button-hover-dark);--button-hover-rgb:var(--button-hover-dark-rgb);--button-text:var(--button-text-dark);--button-text-rgb:var(--button-text-dark-rgb);--success:var(--success-dark);--success-rgb:var(--success-dark-rgb);--error:var(--error-dark);--error-rgb:var(--error-dark-rgb);--warning:var(--warning-dark);--warning-rgb:var(--warning-dark-rgb);--info:var(--info-dark);--info-rgb:var(--info-dark-rgb)}body{background-color:var(--bg-color);font-family:Quicksand,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:1rem;line-height:1.5;margin:0;padding:0;transition:background-color .3s ease,color .3s ease;transition:background-color var(--transition-base) var(--transition-timing-default),color var(--transition-base) var(--transition-timing-default)}.app-header{background-color:#175480!important;box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-md);padding:.75rem 1rem;padding:var(--space-3) var(--space-4)}.app-header button{color:var(--button-text)}.user-welcome{color:var(--text-color);font-size:1.125rem;font-size:var(--font-size-md)}.profile-link{background-color:var(--hover-bg);border-radius:4px;border-radius:var(--radius-md);color:var(--primary);padding:.5rem .75rem;padding:var(--space-2) var(--space-3);transition:background-color .15s ease,color .15s ease;transition:background-color var(--transition-fast) var(--transition-timing-default),color var(--transition-fast) var(--transition-timing-default)}.profile-link:hover{background-color:var(--bg-alt);color:var(--secondary)}.back-button{background-color:var(--bg-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-color);padding:.5rem .75rem;padding:var(--space-2) var(--space-3);transition:background-color .15s ease;transition:background-color var(--transition-fast) var(--transition-timing-default)}.back-button:hover{background-color:var(--hover-bg)}.modal,.modal-body,.modal-content,.modal-footer,.modal-header,.user-modal,.user-modal-body,.user-modal-content{background-color:var(--bg-card);border-color:var(--border-color);border-radius:8px;border-radius:var(--radius-lg);color:var(--text-color)!important}.modal h1,.modal h2,.modal h3,.modal h4,.modal h5,.modal h6,.user-modal h1,.user-modal h2,.user-modal h3,.user-modal h4,.user-modal h5,.user-modal h6{color:var(--text-color)!important}table{border-collapse:collapse;border-color:var(--border-color);margin:1rem 0;margin:var(--space-4) 0;width:100%}td,th{border-color:var(--border-color);padding:.75rem;padding:var(--space-3);text-align:left}th{font-weight:600;font-weight:var(--font-weight-semibold)}th,tr:nth-child(2n){background-color:var(--bg-alt)}.form-group label{font-weight:var(--font-weight-medium);margin-bottom:.25rem;margin-bottom:var(--space-1)}.form-control{border-color:var(--border-color);font-size:1rem;padding:.5rem .75rem}.success{color:var(--success)}.warning{color:var(--warning)}.info{color:var(--info)}.is-active{background-color:var(--hover-bg);border-color:var(--primary)}.is-disabled{cursor:not-allowed;opacity:.6;pointer-events:none}html body[data-theme=dark]{article,aside,div,footer,header,input,main,nav,section,select,textarea{color:#fff;color:var(--text-dark)}input,select,textarea{background-color:#2a2a2a;background-color:var(--input-bg-dark);border-color:#444;border-color:var(--border-dark)}a{color:#4fa6e0;color:var(--primary-dark)}.menu,.modal,.tooltip,[class*=dropdown],[class*=modal],[class*=popup],div[role=dialog]{background-color:#2a2a2a;background-color:var(--bg-dark-card);border-color:#444;border-color:var(--border-dark);color:#fff;color:var(--text-dark)}.content-card,.homepage,.main-content,.preferences-page,.user-profile-container,main{background-color:#121212!important;background-color:var(--bg-dark)!important}.card,.content-card,.homepage-content,.welcome-section{background-color:#2a2a2a!important;background-color:var(--bg-dark-card)!important;color:#fff!important;color:var(--text-dark)!important}}.mt-0{margin-top:0;margin-top:var(--space-0)}.mt-1{margin-top:.25rem;margin-top:var(--space-1)}.mt-2{margin-top:.5rem;margin-top:var(--space-2)}.mt-3{margin-top:.75rem;margin-top:var(--space-3)}.mt-4{margin-top:1rem;margin-top:var(--space-4)}.mt-5{margin-top:1.5rem;margin-top:var(--space-5)}.mt-6{margin-top:2rem;margin-top:var(--space-6)}.mb-0{margin-bottom:0;margin-bottom:var(--space-0)}.mb-1{margin-bottom:.25rem;margin-bottom:var(--space-1)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--space-2)}.mb-3{margin-bottom:.75rem;margin-bottom:var(--space-3)}.mb-4{margin-bottom:1rem;margin-bottom:var(--space-4)}.mb-5{margin-bottom:1.5rem;margin-bottom:var(--space-5)}.mb-6{margin-bottom:2rem;margin-bottom:var(--space-6)}.ml-0{margin-left:0;margin-left:var(--space-0)}.ml-1{margin-left:.25rem;margin-left:var(--space-1)}.ml-2{margin-left:.5rem;margin-left:var(--space-2)}.ml-3{margin-left:.75rem;margin-left:var(--space-3)}.ml-4{margin-left:1rem;margin-left:var(--space-4)}.ml-5{margin-left:1.5rem;margin-left:var(--space-5)}.ml-6{margin-left:2rem;margin-left:var(--space-6)}.mr-0{margin-right:0;margin-right:var(--space-0)}.mr-1{margin-right:.25rem;margin-right:var(--space-1)}.mr-2{margin-right:.5rem;margin-right:var(--space-2)}.mr-3{margin-right:.75rem;margin-right:var(--space-3)}.mr-4{margin-right:1rem;margin-right:var(--space-4)}.mr-5{margin-right:1.5rem;margin-right:var(--space-5)}.mr-6{margin-right:2rem;margin-right:var(--space-6)}.p-0{padding:0;padding:var(--space-0)}.p-1{padding:.25rem;padding:var(--space-1)}.p-2{padding:.5rem;padding:var(--space-2)}.p-3{padding:.75rem;padding:var(--space-3)}.p-4{padding:1rem;padding:var(--space-4)}.p-5{padding:1.5rem;padding:var(--space-5)}.p-6{padding:2rem;padding:var(--space-6)}.py-0{padding-bottom:0;padding-bottom:var(--space-0);padding-top:0;padding-top:var(--space-0)}.py-1{padding-bottom:.25rem;padding-bottom:var(--space-1);padding-top:.25rem;padding-top:var(--space-1)}.py-2{padding-bottom:.5rem;padding-bottom:var(--space-2);padding-top:.5rem;padding-top:var(--space-2)}.py-3{padding-bottom:.75rem;padding-bottom:var(--space-3);padding-top:.75rem;padding-top:var(--space-3)}.py-4{padding-bottom:1rem;padding-bottom:var(--space-4);padding-top:1rem;padding-top:var(--space-4)}.py-5{padding-bottom:1.5rem;padding-bottom:var(--space-5);padding-top:1.5rem;padding-top:var(--space-5)}.py-6{padding-bottom:2rem;padding-bottom:var(--space-6);padding-top:2rem;padding-top:var(--space-6)}.px-0{padding-left:0;padding-left:var(--space-0);padding-right:0;padding-right:var(--space-0)}.px-1{padding-left:.25rem;padding-left:var(--space-1);padding-right:.25rem;padding-right:var(--space-1)}.px-2{padding-left:.5rem;padding-left:var(--space-2);padding-right:.5rem;padding-right:var(--space-2)}.px-3{padding-left:.75rem;padding-left:var(--space-3);padding-right:.75rem;padding-right:var(--space-3)}.px-4{padding-left:1rem;padding-left:var(--space-4);padding-right:1rem;padding-right:var(--space-4)}.px-5{padding-left:1.5rem;padding-left:var(--space-5);padding-right:1.5rem;padding-right:var(--space-5)}.px-6{padding-left:2rem;padding-left:var(--space-6);padding-right:2rem;padding-right:var(--space-6)}body{font-family:var(--font-primary);font-size:var(--font-size-base);line-height:var(--line-height-base)}body,h1,h2,h3,h4,h5,h6{color:var(--text-color)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin-bottom:var(--space-4);margin-top:0}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-base)}p{line-height:var(--line-height-relaxed);margin-bottom:var(--space-4);margin-top:0}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast) var(--transition-timing-default)}a:hover{color:var(--secondary)}b,strong{font-weight:var(--font-weight-bold)}em,i{font-style:italic}small{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.font-light{font-weight:var(--font-weight-light)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.leading-none{line-height:1}.leading-tight{line-height:var(--line-height-tight)}.leading-normal{line-height:var(--line-height-base)}.leading-relaxed{line-height:var(--line-height-relaxed)}.leading-loose{line-height:2}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.text-primary{color:var(--primary)}.text-secondary{color:var(--secondary)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-error{color:var(--error)}.text-warning{color:var(--warning)}.text-info{color:var(--info)}.text-muted{color:var(--text-secondary)}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-wrap{white-space:normal}.text-nowrap{white-space:nowrap}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.underline{text-decoration:underline}.line-through{text-decoration:line-through}.no-underline{text-decoration:none}.italic{font-style:italic}.not-italic{font-style:normal}.tracking-tighter{letter-spacing:-.05em}.tracking-tight{letter-spacing:-.025em}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}ol,ul{margin-bottom:var(--space-4);margin-top:0;padding-left:var(--space-5)}ul{list-style-type:disc}ol{list-style-type:decimal}li{margin-bottom:var(--space-2)}dl{margin-bottom:var(--space-4);margin-top:0}dt{font-weight:var(--font-weight-bold);margin-bottom:var(--space-1)}dd{margin-bottom:var(--space-3);margin-left:0}blockquote{background-color:var(--bg-alt);border-left:4px solid var(--primary);font-style:italic;margin:var(--space-4) 0;padding:var(--space-4)}blockquote p:last-child{margin-bottom:0}code{font-family:monospace;font-size:.9em;padding:var(--space-1) var(--space-2)}code,pre{background-color:var(--bg-alt);border-radius:var(--radius-md)}pre{margin-bottom:var(--space-4);margin-top:0;overflow-x:auto;padding:var(--space-4)}pre code{background-color:initial;border-radius:0;padding:0}hr{background-color:var(--border-color);border:0;height:1px;margin:var(--space-4) 0}.page-title{color:var(--text-color);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-5)}.section-title{font-size:var(--font-size-xl);margin-bottom:var(--space-4)}.card-title,.section-title{color:var(--text-color);font-weight:var(--font-weight-semibold)}.card-title{font-size:var(--font-size-lg);margin-bottom:var(--space-2)}.text-label{font-weight:var(--font-weight-semibold);letter-spacing:.05em;margin-bottom:var(--space-1);text-transform:uppercase}.text-caption,.text-label{color:var(--text-secondary);font-size:var(--font-size-sm)}@media (max-width:768px){h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}.page-title{font-size:var(--font-size-2xl)}.section-title{font-size:var(--font-size-lg)}}.welcome-message{color:var(--text-secondary);font-size:15px;margin-bottom:24px;text-align:center}.container{margin-left:auto;margin-right:auto;max-width:1200px;padding-left:var(--space-4);padding-right:var(--space-4);width:100%}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.container-xl{max-width:1280px}.container-fluid{max-width:100%}.flex{display:flex}.inline-flex{display:inline-flex}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-wrap-reverse{flex-wrap:wrap-reverse}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.self-auto{align-self:auto}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.self-center{align-self:center}.self-stretch{align-self:stretch}.content-center{align-content:center}.content-start{align-content:flex-start}.content-end{align-content:flex-end}.content-between{align-content:space-between}.content-around{align-content:space-around}.flex-1{flex:1 1}.flex-auto{flex:1 1 auto}.flex-initial{flex:0 1 auto}.flex-none{flex:none}.flex-grow-0{flex-grow:0}.flex-grow{flex-grow:1}.flex-shrink-0{flex-shrink:0}.flex-shrink{flex-shrink:1}.grid{display:grid}.inline-grid{display:inline-grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.grid-cols-none{grid-template-columns:none}.gap-0{gap:0}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-bottom:auto;margin-top:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.static{position:static}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-auto{z-index:auto}.inset-0{bottom:0;left:0;right:0;top:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.visible{visibility:visible}.invisible{visibility:hidden}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}.w-full{width:100%}.w-auto{width:auto}.h-full{height:100%}.h-auto{height:auto}.min-h-full{min-height:100%}.min-h-screen,.page-container{min-height:100vh}.page-container{display:flex;flex-direction:column}.main-header{align-items:center;background-color:#175480;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;padding:var(--space-4)}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:var(--space-6);width:100%}.main-footer{background-color:var(--bg-alt);padding:var(--space-4);text-align:center}.content-section{margin-bottom:var(--space-6)}.content-section-header{margin-bottom:var(--space-4)}.content-divider{background-color:var(--border-color);height:1px;margin:var(--space-6) 0}.center-content{align-items:center;display:flex;justify-content:center}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.return-buttons{display:flex;justify-content:space-between;margin-top:20px;width:100%}.main-nav{align-items:center;display:flex;gap:1.5rem}.main-tabs{display:flex;gap:.5rem;position:relative}.welcome-section{border-radius:8px;box-shadow:0 2px 10px var(--shadow);padding:1.5rem}.main-header .user-welcome{color:var(--accent);margin-right:1rem;white-space:nowrap}.fullwidth-content{background-color:var(--bg-color);display:flex;flex:1 1;margin:0;padding:0;width:100%}.fullscreen-homepage-content,.homepage-content{background-color:initial;border-radius:0;box-shadow:none;height:100%}.fullscreen-homepage-content,.homepage-content,.welcome-banner{display:flex;flex-direction:column;flex-grow:1;padding:0;position:relative;width:100%}.welcome-banner{align-items:center;height:calc(100vh - 65px);justify-content:center;margin:0;overflow:hidden}.welcome-banner h2{font-size:2rem;margin-bottom:.5rem}.welcome-banner h2,.welcome-banner p{color:var(--text-color);position:relative;z-index:2}.welcome-banner .splash-image{height:100%;left:0;max-height:calc(100vh - 65px);object-fit:contain;object-position:center;position:absolute;top:0;width:100%}.featured-content{color:var(--text-color);margin:0 auto;max-width:800px}.featured-content h3{font-size:1.4rem;margin-bottom:1rem}.featured-content h3,.featured-content p,.featured-content ul{color:var(--text-color)}.featured-content ul{margin-top:1rem;padding-left:1.5rem}.featured-content li{color:var(--text-color);line-height:1.5;margin-bottom:.75rem}.choice-buttons{gap:var(--space-2);margin-top:var(--space-4)}.no-choices{background-color:var(--bg-alt);border-radius:var(--radius-md);color:var(--text-muted);margin-top:var(--space-4);padding:var(--space-3)}.error-container{align-items:center;background-color:#000c;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.error-content{background-color:var(--bg-alt);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:var(--text-color);max-width:500px;padding:var(--space-5);text-align:center;width:90%}.error-content h2{color:var(--error);margin-bottom:var(--space-3)}.error-content p{margin-bottom:var(--space-4)}.profile-menu-container{position:relative;z-index:100}.profile-button{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--text-color);cursor:pointer;display:flex;padding:6px 12px;transition:background-color .2s}.profile-button:hover{background-color:var(--hover-bg)}.profile-button img{border-radius:50%;height:48px;margin-right:12px;object-fit:cover;width:48px}.profile-button span{font-size:1rem;font-weight:var(--font-weight-medium)}.profile-button .arrow-icon{font-size:12px;margin-left:6px;transition:transform .2s}.profile-button:hover .arrow-icon{transform:translateY(2px)}.profile-dropdown{background:var(--bg-card)!important;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;position:absolute;right:0;top:calc(100% - 10px);width:220px;z-index:101}.profile-name{border-bottom:1px solid var(--border-color);display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:var(--space-2) var(--space-3)}.profile-email{color:var(--text-muted);font-size:var(--font-size-xs);margin:0;padding:0 var(--space-3) var(--space-2);word-break:break-all}.profile-menu-items{display:flex;flex-direction:column;padding:var(--space-1) var(--space-2) var(--space-2)}.profile-menu-item{border-radius:var(--radius-sm);color:var(--text-color)!important;display:block;font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);text-decoration:none;transition:background-color var(--transition-fast);width:100%}.profile-menu-item:hover{background-color:var(--hover-bg);color:var(--text-color)!important}.profile-menu-container .logout-button{background:none!important;border:none!important;border-radius:var(--radius-sm);color:var(--text-color)!important;cursor:pointer;display:block;padding:var(--space-2) var(--space-3);text-align:left;width:100%}.profile-menu-container .logout-button:hover{background-color:var(--hover-bg)!important;color:var(--text-color)!important}.user-avatar{align-items:center;background-color:var(--bg-alt);border-radius:50%;color:var(--text-color);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);height:48px;justify-content:center;overflow:hidden;width:48px}.user-avatar img{height:100%;object-fit:cover;width:100%}.dropdown{background-color:initial;border:none;box-shadow:none;margin:0;padding:0}.dropdown-content{box-shadow:0 2px 6px var(--shadow);display:none;min-width:240px;padding:.25rem 0;right:0;z-index:1000}.dropdown:hover .dropdown-content{display:block}.dropdown-item{background-color:initial;margin:0}.dropdown-header{color:#888;color:var(--text-secondary,#888);font-size:.75rem;padding:.45rem 1.1rem;pointer-events:none}.chat-window{background:var(--bg-card);border-radius:8px 8px 0 0;bottom:0;box-shadow:0 4px 12px var(--shadow);display:flex;flex-direction:column;height:33vh;max-height:77vh;min-height:160px;position:fixed;width:350px}.chat-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;font-size:.85rem;font-weight:600;justify-content:space-between;padding:10px 12px}.chat-header span{color:var(--text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;height:22px;justify-content:center;transition:background-color .2s;width:22px}.chat-close:hover{background-color:var(--hover-bg);color:var(--text-color)}.chat-messages{background:var(--bg-alt);display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:.5rem}.bubble-container{margin-bottom:4px;margin-top:3px;position:relative}.bubble-container.has-reactions{margin-bottom:18px}.bubble-container .chat-bubble.show-time{margin-bottom:8px}.chat-bubble{border-radius:6px;font-size:.85rem;margin-bottom:0;max-width:70%;padding:.4rem .6rem;position:relative}.chat-bubble p{-webkit-hyphens:auto;hyphens:auto;margin:0;overflow-wrap:break-word;word-break:break-word}.chat-bubble.me{margin-left:auto}.chat-bubble.me,.chat-bubble.them{background:var(--bg-color);color:var(--text-color)}.chat-time{bottom:-16px;color:var(--text-secondary);display:none;font-size:.65rem;left:50%;position:absolute;text-align:center;transform:translateX(-50%);white-space:nowrap;width:auto}.chat-bubble.show-time .chat-time{display:block}.chat-input{border-top:1px solid var(--border-color);display:flex}.chat-input textarea{background:var(--input-bg);border:none;color:var(--text-color);flex:1 1;font-size:.8rem;height:25px;padding:.15rem;resize:none}.chat-input button{background:var(--button-bg);color:var(--button-text);height:25px;padding:0 .4rem}.chat-controls{display:flex;gap:6px}.chat-min{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;height:22px;justify-content:center;transition:background-color .2s;width:22px}.chat-min:hover{background-color:var(--hover-bg);color:var(--text-color)}.bubble-container:hover .reaction-trigger,.chat-bubble:hover+.reaction-trigger{opacity:1}.reaction-trigger{cursor:pointer;font-size:18px;opacity:0;position:absolute;top:50%;transform:translateY(-50%);transition:opacity .2s}.bubble-container.them .reaction-trigger{right:-24px}.bubble-container.me .reaction-trigger{left:-24px}.reaction-menu{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 6px var(--shadow);display:flex;gap:4px;left:50%;padding:4px;position:absolute;top:-30px;transform:translateX(-50%);z-index:10}.bubble-container.them .reaction-menu{margin-right:0}.bubble-container.me .reaction-menu{margin-left:0}.reaction-menu span{cursor:pointer;font-size:20px}.reaction-display{display:flex;flex-wrap:wrap;font-size:14px;gap:3px;position:absolute;top:calc(100% - 4px);z-index:1}.bubble-container.me .reaction-display{justify-content:flex-end;right:6px}.bubble-container.them .reaction-display{justify-content:flex-start;left:6px}.reaction-display span{background-color:var(--bg-alt);border-radius:12px;cursor:default;display:inline-block;margin-right:2px;padding:1px 5px}.message-dropdown{background:#0000!important;bottom:20px;position:fixed;right:20px;z-index:1000}.message-btn{align-items:center;background:var(--button-bg);border:1px solid var(--border-color);border-radius:50%;box-shadow:none;color:var(--button-text);display:flex;font-size:24px;height:60px;justify-content:center;transition:background-color .2s;width:60px}.message-btn:hover{background-color:var(--button-hover)}.badge{background:var(--error);border-radius:50%;box-shadow:0 2px 5px var(--shadow);color:#fff;display:flex;font-weight:700;height:20px;min-width:20px;position:absolute;right:-10px;top:-10px}.message-popup{animation:slide-up .2s ease-out;background:var(--bg-card)!important;border-radius:12px;bottom:75px;box-shadow:0 2px 20px var(--shadow);max-height:400px;overflow:hidden;position:absolute;right:0;width:320px}.popup-header{border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:15px}.popup-header h4{color:var(--text-color);font-size:18px;margin:0}.conversation-list{list-style:none;margin:0;max-height:350px;overflow-y:auto;padding:0}.conversation-item{border-bottom:1px solid var(--border-color);cursor:pointer;padding:12px 15px;transition:background-color .2s}.conversation-item:hover{background-color:var(--hover-bg)}.conv-meta{align-items:center;display:flex;margin-bottom:5px}.conv-other{color:var(--text-color);font-weight:600;margin-right:8px}.conv-unread{align-items:center;background:#f03e3e;border-radius:12px;color:#fff;display:inline-flex;font-size:12px;font-weight:700;height:20px;justify-content:center;margin-right:10px;min-width:20px;padding:3px 8px;text-align:center}.conv-snippet{color:var(--text-secondary);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-icon{height:108px;width:108px}.story-view .encounter-container .encounter-content,.story-view .encounter-content{left:50%!important;opacity:1!important;pointer-events:auto!important;position:absolute!important;top:50%!important;transform:translate(-50%,-50%)!important;visibility:visible!important;z-index:999!important}.story-view .encounter-description,.story-view .encounter-title{display:block!important;opacity:1!important;visibility:visible!important}.story-view{--fade-duration:600ms;align-items:center;background-color:#000;display:flex;flex-direction:column;height:100vh;justify-content:center;min-height:80vh;overflow:hidden;position:relative;width:100%}.single-player-game-active .app-header,.single-player-game-active .chat-window,.single-player-game-active .main-header,.single-player-game-active .message-dropdown{display:none!important}.game-mode-indicator{background-color:#e74c3ccc;border-radius:20px;box-shadow:0 2px 5px #0003;color:#fff;font-weight:700;padding:8px 16px;position:fixed;right:20px;top:20px;z-index:100}.encounter-content{background-color:#000000b3;border-radius:10px;color:#fff;margin:auto!important;max-width:800px;padding:2rem;position:relative;text-align:center;width:90%;z-index:20!important}.encounter-title{color:#f8f8f8;margin-bottom:1rem}.encounter-description{color:#e0e0e0;font-size:1.2rem;margin-bottom:2rem}.choice-buttons{display:flex;flex-direction:column;gap:10px;position:relative;width:100%;z-index:20!important}.choice-buttons .btn,.choice-buttons .btn-block,.choice-buttons .btn-primary{background-color:#3498dbcc;border:none;border-radius:5px;color:#fff;cursor:pointer;display:block;font-size:1rem;padding:10px 15px;position:relative;text-align:center;transition:background-color .2s;width:100%;z-index:21!important}.choice-buttons .btn-primary:hover,.choice-buttons .btn:hover{background-color:#2980b9}.no-choices{color:#bbb;font-style:italic;margin-top:1rem}.character-images{bottom:0;display:flex;justify-content:space-between;position:absolute;width:100%;z-index:5}.character-image-container{bottom:0;max-height:100vh;position:absolute;transition:all .5s ease;z-index:5}.character-image-container.left{left:0;transform:translateX(-10%)}.character-image-container.right{right:0;transform:translateX(10%)}.character-image-container img{max-height:90vh;object-fit:contain}.scenario-selector{padding:20px 0;position:relative;z-index:30}.story-view .scenario-selector{position:fixed;right:20px;top:20px;z-index:100}.story-view .scenario-selector select{border:1px solid #ccc;border-radius:4px;font-size:1rem;padding:8px 12px}.back-btn{left:10px;position:absolute;top:10px;z-index:30}.story-view .back-btn{left:20px;position:fixed;top:20px;z-index:100}.blank-state-message{color:#fff;font-size:1.2rem;margin-top:20vh;opacity:.8;z-index:20!important}.encounter-container{align-items:center;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;opacity:1;position:absolute;right:0;top:0;will-change:opacity;z-index:10!important}.encounter-container.current{z-index:15!important}.encounter-container.previous{z-index:10!important}.encounter-container.previous.fade-out{animation:storyFadeOut var(--fade-duration) forwards;pointer-events:none}.backdrop-container{overflow:hidden;z-index:1}.backdrop-container,.backdrop-image{height:100%;left:0;position:absolute;top:0;width:100%}.backdrop-image img{height:100%;object-fit:cover;width:100%}.backdrop-overlay{background:linear-gradient(#0000004d,#0009);height:100%;left:0;position:absolute;top:0;width:100%;z-index:2}@media (max-width:768px){.encounter-title{font-size:1.8rem}.encounter-description{font-size:1rem}.encounter-content{padding:1.5rem}.character-image-container.left{transform:translateX(-30%)}.character-image-container.right{transform:translateX(30%)}.character-image-container img{max-height:70vh}}.story-view .backdrop-container,.story-view .backdrop-image{z-index:1!important}.story-view .backdrop-overlay{z-index:2!important}.story-view .encounter-content{margin:auto!important;position:relative!important;z-index:20!important}.story-view .encounter-description,.story-view .encounter-title{position:relative!important;z-index:21!important}.story-view .choice-buttons{position:relative!important;z-index:22!important}.story-view .btn-primary{position:relative!important;z-index:23!important}.panel-content{grid-template-rows:auto auto}.encounter-preview-section,.poll-info-section,.story-tree-section,.user-info-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 2px 5px var(--shadow);display:flex;flex-direction:column;padding:var(--space-3)}.poll-time,.total-users{border-bottom:1px solid var(--border-color);margin-bottom:var(--space-2);padding-bottom:var(--space-2)}.option-bar-container{border-radius:var(--radius-sm)}.user-info-section{grid-column:1}.user-table td,.user-table th{text-align:left}.story-tree-section{grid-column:2;grid-row:2}.visual-breadcrumb-trail{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 2px 5px var(--shadow);margin:0;overflow-x:auto;padding:1rem 0}.breadcrumb-circle,.visual-breadcrumb-trail{align-items:center;display:flex;justify-content:center}.breadcrumb-circle{aspect-ratio:1;background-color:var(--primary);border:2px solid var(--border-color);border-radius:50%;box-sizing:border-box;color:#fff;cursor:pointer;flex:0 0 30px;font-weight:700;height:30px;min-height:30px;min-width:30px;position:relative;transition:all .2s ease;width:30px}.breadcrumb-circle:hover{box-shadow:0 2px 5px #0003;transform:scale(1.1)}.breadcrumb-circle.future{opacity:.7}.breadcrumb-circle.future,.breadcrumb-circle.unreachable{background-color:#95a5a6;box-shadow:none;cursor:not-allowed}.breadcrumb-circle.unreachable{background-image:repeating-linear-gradient(45deg,#0000,#0000 5px,#0000004d 0,#0000004d 10px);opacity:.8;position:relative}.breadcrumb-circle.visited{background-color:#27ae60;box-shadow:none}.breadcrumb-circle.active{background-color:#f1c40f;border-color:#0000;box-shadow:0 0 0 3px #f1c40f80;opacity:1}.breadcrumb-circle:disabled{cursor:not-allowed}.connection-status,.educator-panel .error-toast{border-radius:var(--radius-md)}.game-id-display{border-radius:var(--radius-sm);color:var(--text-secondary)}@media (max-width:768px){.educator-panel .visual-breadcrumb-trail{justify-content:flex-start;padding:.8rem .5rem}.educator-panel .breadcrumb-circle{font-size:.65rem;height:17px;width:17px}.educator-panel .breadcrumb-arrow{margin:0 3px}.educator-panel .breadcrumb-arrow svg{height:10px;width:10px}}.mobile-poll-container{background-color:var(--bg-alt);font-family:var(--font-family-base)}.poll-placeholder,.registration-form{background-color:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-5)}.poll-placeholder{color:var(--text-secondary)}.poll-header{margin-bottom:var(--space-4)}.poll-header h2{color:var(--text-color)}.poll-options{gap:var(--space-4);margin-bottom:var(--space-4)}.results-container{background-color:var(--bg-alt);border-radius:var(--radius-full);margin-top:var(--space-2)}.result-bar{background-color:var(--success)}.vote-percentage{color:var(--text-color);font-weight:var(--font-weight-bold)}.poll-logo{margin:0 auto var(--space-4) auto}.presenter-btn-container{margin-bottom:var(--space-6);margin-top:var(--space-5)}.mobile-poll-timer{color:var(--success);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin:var(--space-4) auto}.placeholder-actions{gap:var(--space-4);margin-top:var(--space-4)}.poll-overlay{display:flex;justify-content:center;left:0;position:absolute;right:0;top:20px;z-index:10}.poll-timer{animation:pulse 2s infinite;background-color:#e74c3ccc;border-radius:30px;padding:10px 30px;text-align:center}.poll-timer h2{color:#fff;font-size:1.8rem;margin:0;text-transform:uppercase}.encounter-options{display:flex;flex-direction:column;gap:15px;margin-top:40px}.encounter-option{background-color:#3498dbb3;border-radius:8px;cursor:pointer;font-size:1.3rem;padding:15px 20px;transition:background-color .3s,transform .2s}.encounter-option:hover{background-color:#3498dbe6;transform:translateY(-2px)}@media (max-width:320px){.poll-header{align-items:flex-start;flex-direction:column;gap:var(--space-2)}}.user-management{border-radius:var(--radius-md);padding:var(--space-4)}.user-management-header{padding-bottom:var(--space-3)}.user-controls,.user-management-header{margin-bottom:var(--space-4)}.search-filter{gap:var(--space-2)}.users-table-container{margin-bottom:var(--space-4)}.users-table{font-size:var(--font-size-sm)}.users-table th{font-weight:var(--font-weight-semibold)}.email-cell{gap:var(--space-2)}.verified-badge{background-color:var(--success);font-weight:var(--font-weight-bold)}.admin-role{color:var(--purple)}.admin-role,.educator-role{font-weight:var(--font-weight-medium)}.educator-role{color:var(--primary)}.student-role{color:var(--text-color)}.pagination{gap:var(--space-2);margin-top:var(--space-4)}.pagination-button{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.pagination-button:hover:not(:disabled){background-color:var(--primary);border-color:var(--primary);color:var(--button-text)}.pagination-button:disabled{color:var(--text-secondary)}.pagination-info{color:var(--text-color);margin:0 var(--space-2)}.user-modal{background-color:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-4)}.user-modal-header{border-bottom:1px solid var(--border-color);margin-bottom:var(--space-4);padding-bottom:var(--space-3)}.modal-actions{gap:var(--space-4);margin-top:var(--space-4)}.loading-spinner{color:var(--text-color);font-size:var(--font-size-base)}.no-results{color:var(--text-color);padding:var(--space-5) 0!important}.profile-search-container{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);margin:0 auto;max-width:1200px;padding:1.5rem;width:100%}.profile-search-container h2{color:var(--text-color);font-size:1.8rem;margin-bottom:1.5rem}.search-container{margin-bottom:2rem}.search-form{align-items:center;display:flex;gap:.5rem}.search-input{background-color:var(--input-bg);border:1px solid var(--border-color);color:var(--text-color);flex:1 1;font-size:1rem;min-width:0;padding:.75rem}.error-message{background-color:var(--bg-alt);border-left:4px solid var(--error);color:var(--error)}.profiles-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.5rem}.profiles-header h3{color:var(--text-color);font-size:1.2rem;margin:0}.loading-profiles,.no-profiles{align-items:center;color:var(--text-secondary);display:flex;font-size:1.1rem;justify-content:center;min-height:200px}.no-profiles{font-style:italic;text-align:center}@media (max-width:768px){.search-form{flex-direction:column;gap:.75rem}.reset-button,.search-button,.search-input{width:100%}.profiles-grid{grid-template-columns:1fr}.profile-content,.stats-grid{flex-direction:column}.badges-grid{grid-template-columns:1fr}}.profile-picture-section{align-items:center;display:flex;flex:0 0 240px;flex-direction:column;gap:1rem;max-width:240px}.profile-picture-preview{border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 5px var(--shadow);height:auto;max-height:240px;object-fit:cover;width:100%}.profile-picture-placeholder{align-items:center;background-color:var(--bg-alt);border:1px dashed var(--border-color);border-radius:8px;color:var(--text-secondary);display:flex;height:240px;justify-content:center;width:100%}.profile-picture-section input[type=file]{width:100%}@media (max-width:768px){.profile-picture-section{flex:1 1 100%;max-width:none}.profile-picture-placeholder,.profile-picture-preview{max-height:300px}}.preferences-page{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);margin:0 auto;max-width:600px;padding:20px}.preferences-page h2{border-bottom:1px solid var(--border-color);color:var(--text-color);margin-bottom:1.5rem;padding-bottom:1rem}.preferences-form{gap:20px}.pref-group,.preferences-form{display:flex;flex-direction:column}.pref-group label{color:var(--text-color);font-weight:500;margin-bottom:.5rem}.pref-group select{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:1rem;padding:.75rem}.checkbox-group{align-items:center;flex-direction:row;gap:10px}.checkbox-group label{margin-bottom:0}.pref-success{border-left:4px solid var(--success);color:var(--success)}.pref-error,.pref-success{background-color:var(--bg-alt);border-radius:4px;margin-top:1rem;padding:.75rem}.pref-error{border-left:4px solid var(--error);color:var(--error)}.preferences-form button[type=submit]{background-color:var(--primary);border:none;border-radius:4px;color:var(--button-text);cursor:pointer;font-size:1rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .2s ease}.preferences-form button[type=submit]:hover{background-color:var(--secondary)}.preferences-form button[type=submit]:disabled{background-color:var(--text-tertiary);color:var(--bg-alt);cursor:not-allowed}.not-authenticated{background-color:var(--bg-alt);font-style:italic;text-align:center}.not-authenticated,.prefs-loading{border-radius:8px;color:var(--text-color);padding:2rem}.prefs-loading{align-items:center;background-color:var(--bg-card);box-shadow:0 2px 10px var(--shadow);display:flex;font-size:1.1rem;justify-content:center;min-height:200px}@media (max-width:640px){.sm\:hidden{display:none}.sm\:flex{display:flex}.sm\:block{display:block}.sm\:flex-col{flex-direction:column}.sm\:flex-row{flex-direction:row}.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}}@media (max-width:768px){.md\:hidden{display:none}.md\:flex{display:flex}.md\:block{display:block}.md\:flex-col{flex-direction:column}.md\:flex-row{flex-direction:row}.md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.user-controls{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.search-filter{max-width:100%;width:100%}.users-table td,.users-table th{font-size:var(--font-size-xs);padding:var(--space-2)}.action-buttons{flex-direction:column;gap:var(--space-1)}.user-modal{padding:var(--space-3);width:95%}.form-column-left,.form-column-right{flex:100% 1}.search-form{flex-direction:column;gap:.75rem}.reset-button,.search-button,.search-input{width:100%}.profiles-grid{grid-template-columns:1fr}.encounter-content{margin-bottom:var(--space-6);padding:var(--space-5) var(--space-3)}.encounter-title{font-size:1.5rem}.encounter-description{font-size:.95rem}.poll-timer h2{font-size:1.25rem}.editor-row{flex-direction:column}.encounter-form-section,.encounter-routes-section{width:100%}.image-selectors,.image-selectors-row{flex-direction:column}}@media (max-width:1024px){.lg\:hidden{display:none}.lg\:flex{display:flex}.lg\:block{display:block}.lg\:flex-col{flex-direction:column}.lg\:flex-row{flex-direction:row}}@media (min-width:768px){.choice-buttons{margin:var(--space-4) auto 0;max-width:500px;width:100%}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.transition-status-indicator{animation:fadeIn .3s ease-in-out;border-radius:5px;bottom:10px;font-family:monospace;left:50%;max-width:90%;padding:10px 20px;position:fixed;text-align:center;transform:translateX(-50%);z-index:1000}.transition-status-indicator.loading{background-color:#2980b9e6;color:#fff}.transition-status-indicator.error{background-color:#e74c3ce6;color:#fff}.transition-error-indicator{display:none}.debug-panel{border:1px solid #0f0;border-radius:4px;max-height:90vh;right:10px;top:10px;width:300px;z-index:1000}.debug-panel h3,.debug-panel h4{color:#0f0;margin:5px 0;text-align:center}.debug-panel p{margin:3px 0}.debug-error{background-color:#300;border:1px solid red;border-radius:3px;color:red;margin-top:10px;padding:5px}.debug-controls{display:flex;flex-direction:column;gap:5px;margin-top:10px}.debug-controls button,.transition-error-indicator button{background-color:#333;border:1px solid #0f0;color:#fff;cursor:pointer;font-family:monospace;padding:5px}.debug-controls button:hover,.transition-error-indicator button:hover{background-color:#444}.debug-controls input{background-color:#222;border:1px solid #0f0;color:#fff;font-family:monospace;padding:5px}.encounter-thumbnail{aspect-ratio:16/9;margin:0 auto;max-height:220px;position:relative;width:100%}.thumbnail-container{background-color:#000;border-radius:6px;height:100%;left:0;overflow:hidden;position:absolute;top:0;width:100%}.thumbnail-backdrop img{display:block;height:100%;object-fit:contain;width:100%}.thumbnail-character{bottom:0;height:60%;object-fit:contain;position:absolute;width:auto}.character-left{left:0}.character-right{right:0}.thumbnail-content{align-items:center;background-color:#0009;border-radius:4px;display:flex;flex-direction:column;justify-content:center;left:50%;max-height:80%;max-width:60%;overflow:hidden;padding:8px 12px;position:absolute;top:50%;transform:translate(-50%,-50%);width:60%}.thumbnail-title{color:#fff;font-size:clamp(4px,1vw,12px);margin:0 0 4px;text-align:center}.thumbnail-description{color:#ddd;font-size:clamp(3px,.8vw,10px);line-height:1.2;overflow:hidden;text-align:center;text-overflow:ellipsis}.thumbnail-character img{max-height:100%;object-fit:contain;width:auto}.route-actions{display:flex;gap:.5rem}.image-selector{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);display:flex;flex-direction:column;gap:.75rem;padding:1rem;width:100%}.image-selector h4{color:var(--text-color);font-size:1rem;margin-bottom:.5rem;margin-top:0}.image-selector-actions{display:flex;flex-direction:column;gap:.75rem}.select-image-btn{background-color:var(--primary);border:none;border-radius:4px;color:var(--button-text);cursor:pointer;font-weight:500;padding:.5rem;transition:background-color .2s}.select-image-btn:hover{background-color:var(--secondary)}.root-encounter-dropdown{cursor:pointer;height:38px;min-width:250px;padding:.5rem 1rem}.info-item{display:flex;justify-content:space-between}.compose-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:300}.compose-modal{background:var(--bg-card);border-radius:8px;box-shadow:0 4px 12px var(--shadow);color:var(--text-color);padding:1rem 1.25rem;position:relative;width:320px}.compose-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.75rem}.suggestion-list{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:0 2px 6px var(--shadow);list-style:none;margin:2px 0 0;max-height:120px;overflow-y:auto;padding:0;position:absolute;width:100%;z-index:5}.suggestion-list li{cursor:pointer;font-size:.85rem;padding:4px 6px}.suggestion-list li:hover{background:var(--bg-alt)}.complete-profile-container{align-items:center;background-color:var(--bg-alt);display:flex;justify-content:center;min-height:100vh;padding:20px}.complete-profile-card{background-color:var(--bg-card);border-radius:8px;box-shadow:0 4px 16px var(--shadow);max-width:400px;padding:32px;width:100%}.profile-picture-container{display:flex;justify-content:center;margin-bottom:24px}.modal-body,.modal-header{padding:1rem}.modal-body{max-height:calc(80vh - 70px)}.error,.loading{color:var(--text-secondary);padding:1rem;text-align:center}.upload-prompt{background-color:var(--bg-alt);border:1px solid var(--info);border-left-width:4px;border-radius:4px;margin-bottom:15px;padding:10px}.upload-prompt p{color:var(--text-secondary);font-size:14px;margin:0}.file-input,.upload-btn,.upload-container{display:none}.progress-bar-container{background-color:var(--bg-alt);border-radius:4px;height:20px;overflow:hidden;position:relative;width:100%}.progress-bar{background-color:var(--primary);height:100%;transition:width .3s ease}.progress-bar-container span{color:var(--text-color);font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.image-manager{margin:0 auto;max-width:1200px;padding:20px}.image-manager h2{color:var(--text-color);margin-bottom:20px}.image-manager-tabs{border-bottom:1px solid var(--border-color);display:flex;margin-bottom:20px}.tab-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:16px;padding:10px 20px;transition:all .3s ease}.tab-button:hover{background-color:var(--hover-bg);color:var(--primary)}.tab-button.active{border-bottom:3px solid var(--primary);color:var(--text-color);font-weight:700}.image-manager-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:300px 1fr}.upload-section{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 4px var(--shadow);padding:20px}.upload-section h3{color:var(--text-color);margin-bottom:15px}.upload-form{display:flex;flex-direction:column;gap:15px}.images-gallery{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 4px var(--shadow);padding:20px}.error,.loading,.no-images{color:var(--text-secondary);padding:20px;text-align:center}.edit-form{gap:16px;width:100%}.edit-form,.file-upload-btn{display:flex;flex-direction:column}.file-upload-btn{align-items:center;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;justify-content:center;padding:30px 20px;text-align:center;transition:all .2s ease}.file-upload-btn:hover{background-color:var(--bg-alt);border-color:var(--primary)}.file-upload-btn i{color:var(--text-secondary);font-size:24px;margin-bottom:10px}.file-upload-btn p{color:var(--text-secondary);margin:0}.upload-input{height:.1px;opacity:0;overflow:hidden;position:absolute;width:.1px;z-index:-1}.image-controls{justify-content:space-between;margin-bottom:16px}.image-controls,.image-filters{align-items:center;display:flex}.image-filters{gap:10px}.image-search{position:relative}.image-search input{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:14px;padding:8px 12px 8px 32px;width:200px}.image-search i{color:var(--text-secondary);left:10px;position:absolute;top:50%;transform:translateY(-50%)}.image-sort{align-items:center;display:flex;gap:8px}.image-sort label{color:var(--text-secondary);font-size:14px}.image-sort select{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:14px;padding:6px 10px}@media (max-width:768px){.image-manager-content{grid-template-columns:1fr}.image-controls{align-items:flex-start;flex-direction:column;gap:10px}.image-search input{width:100%}}.user-badges-section{border-top:1px solid var(--border-color)}.badge-list{border:1px solid var(--border-color);border-radius:var(--radius-sm)}.badge-item{border-bottom:1px solid var(--border-color)}.badge-image{border-radius:var(--radius-sm)}.badge-details h4{color:var(--text-color)!important}.badge-details p{color:var(--text-color)}.badge-date{color:var(--text-secondary)}.badge{align-items:center;border-radius:12px;display:inline-flex;font-size:12px;font-weight:600;justify-content:center;padding:2px 8px;white-space:nowrap}.badge-primary{background-color:var(--primary-light);color:var(--primary)}.badge-success{background-color:var(--success-light);color:var(--success)}.badge-warning{background-color:var(--warning-light);color:var(--warning)}.badge-danger{background-color:var(--error-light);color:var(--error)}.badge-info{background-color:var(--info-light);color:var(--info)}.badge-neutral{background-color:var(--bg-alt);color:var(--text-secondary)}.badge-dark{background-color:var(--bg-dark);color:#fff}.role-badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:2px 8px}.admin-badge{background-color:var(--purple-light);color:var(--purple)}.educator-badge{background-color:var(--primary-light);color:var(--primary)}.student-badge{background-color:var(--bg-alt);color:var(--text-secondary)}.xp-level-display{align-items:center;display:flex;gap:10px;margin-bottom:15px}.level-display,.xp-display{background-color:var(--bg-alt);border-radius:var(--radius-sm);flex:1 1;padding:8px 12px;text-align:center}.level-cell,.xp-cell{font-weight:var(--font-weight-bold)}.xp-cell{color:var(--warning)}.level-cell{color:var(--primary)}.level-label,.xp-label{color:var(--text-secondary);display:block;font-size:12px;margin-bottom:4px}.level-value,.xp-value{font-size:18px;font-weight:700}.images-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));width:100%}.image-item{border:2px solid #0000;border-radius:4px;cursor:pointer;overflow:hidden;transition:transform .2s}.image-item:hover{border-color:var(--primary);box-shadow:0 5px 15px var(--shadow);transform:translateY(-5px)}.image-item.selected{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary)}.image-container{background-color:var(--bg-alt);height:120px;overflow:hidden;position:relative}.image-thumbnail{height:100%;object-fit:contain;width:100%}.image-description-tooltip{background-color:var(--bg-dark);color:var(--text-dark);font-size:12px;left:0;max-height:0;opacity:0;overflow:hidden;padding:8px;position:absolute;right:0;top:0;transition:max-height .3s ease,opacity .3s ease}.image-container:hover .image-description-tooltip{max-height:100px;opacity:1;overflow-y:auto}.image-title{background-color:var(--bg-card);color:var(--text-color);font-size:.85rem;overflow:hidden;padding:.5rem;text-align:center;text-overflow:ellipsis;white-space:nowrap}.image-gallery,.images-gallery-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));width:100%}.images-gallery-grid{margin-top:16px}.profiles-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));width:100%}.image-card{aspect-ratio:1/1;background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 5px var(--shadow);cursor:pointer;overflow:hidden;position:relative;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out;width:100%}.image-card:hover{box-shadow:0 5px 15px #0000001a;transform:translateY(-5px)}.image-card img{display:block;height:100%;object-fit:cover;object-position:center;width:100%}.image-card-overlay{background:#000000b3;bottom:0;color:#fff;font-size:.8rem;left:0;padding:8px 12px;position:absolute;right:0;transition:opacity .3s ease}.image-card-actions{display:flex;gap:5px;opacity:0;position:absolute;right:8px;top:8px;transition:opacity .2s ease}.image-card:hover .image-card-actions{opacity:1}.image-action-btn{align-items:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;transition:background .2s ease;width:28px}.image-action-btn:hover{background:#000c}.gallery-images{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));width:100%}.image-picker-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin-top:16px;width:100%}.image-picker-item{aspect-ratio:1/1;border:2px solid #0000;border-radius:4px;cursor:pointer;overflow:hidden;transition:all .2s ease}.image-picker-item:hover{border-color:var(--primary);transform:translateY(-5px)}.image-picker-item.selected{border-color:var(--primary);box-shadow:0 0 0 2px #3498db80}.image-picker-item img{display:block;height:100%;object-fit:cover;width:100%}.encounter-image-picker .gallery-images{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-top:16px;width:100%}.character-image-picker .gallery-images{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:16px;width:100%}.image-actions{background-color:#0009;bottom:0;display:flex;justify-content:space-between;left:0;opacity:0;padding:5px;position:absolute;right:0;transition:opacity .2s ease}.image-container:hover .image-actions{opacity:1}.image-preview{background-color:var(--bg-alt);border:1px solid var(--border-color);border-radius:4px;height:150px;margin-bottom:10px;overflow:hidden}.image-preview,.preview-container{align-items:center;display:flex;justify-content:center;width:100%}.preview-container{height:100%;position:relative}.image-preview-content{max-height:100%;max-width:100%;object-fit:contain}.encounter-editor .image-description-tooltip,.image-selector-section .image-description-tooltip,.image-selector-section .preview-description-tooltip,.image-selectors-row .preview-description-tooltip,.storyline-editor .image-description-tooltip{display:none!important}.encounter-editor .image-container:hover .image-description-tooltip,.image-selector-section .image-container:hover .image-description-tooltip,.image-selector-section .preview-container:hover .preview-description-tooltip,.image-selectors-row .preview-container:hover .preview-description-tooltip,.storyline-editor .image-container:hover .image-description-tooltip{max-height:0;opacity:0}.image-preview-modal{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.full-size-preview{display:block;margin:0 auto;max-height:400px;max-width:100%}.modal-content{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 5px 15px var(--shadow-dark);display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:auto;position:relative;width:80%}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:15px 20px}.modal-header h3{color:var(--text-color);font-size:1.2rem;margin:0}.close-btn{color:var(--text-tertiary);font-size:24px}.modal-body{background-color:var(--bg-card);color:var(--text-color);max-height:calc(90vh - 70px);overflow-y:auto;padding:20px}.image-details{border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px}.image-details p{color:var(--text-color);margin:5px 0}.image-selector-modal{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}@media (max-width:768px){.images-gallery-grid,.images-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.profiles-grid{grid-template-columns:1fr}.image-picker-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.modal-content{max-height:95vh;width:95%}.image-selectors-row{flex-direction:column}}@media (max-width:480px){.images-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.images-gallery-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}}.question-bank-editor{background-color:var(--bg-alt);color:var(--text-color);display:flex;height:auto;min-height:300px}.qbe-sidebar{background-color:var(--bg-card);border-right:1px solid var(--border-color);box-shadow:2px 0 4px var(--shadow);display:flex;flex-direction:column;overflow-y:auto;padding:15px;width:260px}.qbe-sidebar .create-btn{margin-bottom:10px;width:100%}.question-list{flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0}.question-list li{border:1px solid var(--border-color);border-radius:4px;cursor:pointer;padding:8px 10px;transition:background-color .2s,border-color .2s}.question-list li:hover{background-color:var(--hover-bg);border-color:var(--primary)}.question-list li.active{background-color:var(--primary);border-color:var(--primary);color:var(--button-text)}.qbe-main{flex-grow:1;overflow-y:visible;padding:20px}.question-editor .form-group{display:flex;flex-direction:column;margin-bottom:20px}.question-editor textarea{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);min-height:80px;padding:10px;resize:vertical}.options-section{margin-top:15px}.options-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.option-row{border:1px solid var(--border-color);border-radius:6px;display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding:10px}.option-main,.option-row.option-header{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:60px 1fr 120px}.option-main input[type=radio]{margin:0 auto}.option-main .delete-btn{width:100%}.option-row.option-header span.header-label{font-weight:600;text-align:center}.option-row.option-header{border:none;margin-bottom:8px;padding:0 10px 8px}.option-rationale-label{display:flex;flex-direction:column;font-size:.85rem;font-weight:600;gap:4px;margin-left:30px}.option-rationale-input{resize:vertical;width:100%}.option-input,.option-rationale-input{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);padding:6px 10px}.option-input{flex-grow:1}.delete-btn{background-color:var(--error);border:none;border-radius:4px;color:var(--button-text);cursor:pointer;padding:6px 10px}.delete-btn:hover{filter:brightness(90%)}.tag-item{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:9999px;color:var(--text-color);cursor:pointer;display:inline-flex!important;flex:0 0 auto!important;padding:6px 12px;position:relative;transition:background-color .2s,border-color .2s,color .2s;-webkit-user-select:none;user-select:none;width:max-content!important}.tag-item input{height:0;opacity:0;pointer-events:none;position:absolute;width:0}.tag-item:before{content:"✓";font-size:.8em;line-height:1;margin-right:4px;opacity:0;transition:opacity .2s}.tag-item.selected{background-color:var(--primary);border-color:var(--primary);color:var(--button-text);padding-right:16px}.tag-item.selected:before{opacity:1}.btn{align-items:center;background-color:var(--button-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--button-text);display:inline-flex;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);justify-content:center;padding:var(--space-2) var(--space-4);text-align:center;transition:background-color var(--transition-fast) var(--transition-timing-default),color var(--transition-fast) var(--transition-timing-default),border-color var(--transition-fast) var(--transition-timing-default),transform var(--transition-fast) var(--transition-timing-default),box-shadow var(--transition-fast) var(--transition-timing-default),opacity var(--transition-fast) var(--transition-timing-default)}.btn:hover:not(:disabled){background-color:var(--button-hover)}.btn:focus{outline:2px solid var(--primary);outline-offset:1px}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{cursor:not-allowed;opacity:.55}.btn .icon{align-items:center;display:inline-flex;justify-content:center}.btn .icon-left{margin-right:var(--space-2)}.btn .icon-right{margin-left:var(--space-2)}.btn-primary{background-color:var(--primary);border-color:var(--primary);color:var(--button-text)}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark);border-color:var(--primary-dark)}.btn-secondary{background-color:var(--secondary);border-color:var(--secondary);color:var(--button-text)}.btn-secondary:hover:not(:disabled){background-color:var(--secondary-dark);border-color:var(--secondary-dark)}.btn-accent{background-color:var(--accent);border-color:var(--accent);color:var(--button-text)}.btn-accent:hover:not(:disabled){background-color:var(--accent-dark);border-color:var(--accent-dark)}.btn-success{background-color:var(--success);border-color:var(--success);color:var(--button-text)}.btn-success:hover:not(:disabled){background-color:var(--success-dark);border-color:var(--success-dark)}.btn-danger{background-color:var(--error);border-color:var(--error);color:var(--button-text)}.btn-danger:hover:not(:disabled){background-color:var(--error-dark);border-color:var(--error-dark)}.btn-warning{background-color:var(--warning);border-color:var(--warning);color:var(--text-color)}.btn-warning:hover:not(:disabled){background-color:var(--warning-dark);border-color:var(--warning-dark)}.btn-info{background-color:var(--info);border-color:var(--info);color:var(--button-text)}.btn-info:hover:not(:disabled){background-color:var(--info-dark);border-color:var(--info-dark)}.btn-outline{background:#0000;color:var(--text-color)}.btn-outline.btn-primary{border-color:var(--primary);color:var(--primary)}.btn-outline.btn-primary:hover:not(:disabled){background-color:var(--primary);color:var(--button-text)}.btn-outline.btn-secondary{border-color:var(--secondary);color:var(--secondary)}.btn-outline.btn-secondary:hover:not(:disabled){background-color:var(--secondary);color:var(--button-text)}.btn-outline.btn-accent{border-color:var(--accent);color:var(--accent)}.btn-outline.btn-accent:hover:not(:disabled){background-color:var(--accent);color:var(--button-text)}.btn-outline.btn-success{border-color:var(--success);color:var(--success)}.btn-outline.btn-success:hover:not(:disabled){background-color:var(--success);color:var(--button-text)}.btn-outline.btn-danger{border-color:var(--error);color:var(--error)}.btn-outline.btn-danger:hover:not(:disabled){background-color:var(--error);color:var(--button-text)}.btn-flat{background:#0000;border:none;color:var(--text-color);padding:var(--space-1) var(--space-2)}.btn-flat:hover:not(:disabled){background:var(--hover-bg)}.btn-flat.btn-primary{color:var(--primary)}.btn-flat.btn-primary:hover:not(:disabled){color:var(--primary-dark)}.btn-flat.btn-secondary{color:var(--secondary)}.btn-flat.btn-danger{color:var(--error)}.btn-xs{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2)}.btn-sm{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-3)}.btn-md{font-size:var(--font-size-base);padding:var(--space-2) var(--space-4)}.btn-lg{font-size:var(--font-size-lg);padding:var(--space-3) var(--space-5)}.btn-xl{font-size:var(--font-size-xl);padding:var(--space-4) var(--space-6)}.btn-group{display:inline-flex}.btn-group .btn:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.btn-group .btn:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0;margin-left:-1px}.btn-block{display:flex;width:100%}.btn-icon{align-items:center;border-radius:var(--radius-md);display:inline-flex;justify-content:center;min-height:2.5rem;min-width:2.5rem;padding:var(--space-2)}.btn-icon.btn-sm{min-height:2rem;min-width:2rem;padding:var(--space-1)}.btn-icon.btn-circle{border-radius:var(--radius-full)}.btn-icon.btn-profile{font-size:.9em;min-height:1.875rem;min-width:1.875rem;overflow:hidden}.profile-image,.profile-initials{border-radius:inherit;height:100%;width:100%}.profile-initials{align-items:center;background-color:var(--primary);color:#fff;display:flex;font-size:inherit;font-weight:var(--font-weight-bold);justify-content:center}.btn-loading{color:#0000!important;pointer-events:none;position:relative}.btn-loading:after{animation:button-loading-spinner .75s linear infinite;border:2px solid;border-color:#0000 var(--button-text) var(--button-text) #0000;border-radius:50%;content:"";height:1rem;left:calc(50% - .5rem);position:absolute;top:calc(50% - .5rem);width:1rem}@keyframes button-loading-spinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.admin-button,.return-button{background-color:#000000b3;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-weight:var(--font-weight-bold);padding:var(--space-2) var(--space-4);text-align:center;transition:all var(--transition-base) var(--transition-timing-default)}.admin-button{background-color:#e74c3ccc;text-decoration:none}.admin-button:hover,.return-button:hover{background-color:#282828e6;box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-button:hover{background-color:#c0392be6}.admin-button:active,.return-button:active{transform:translateY(0)}.main-tab{align-items:center;background-color:var(--bg-alt);border:1px solid var(--border-color);box-shadow:0 1px 3px var(--shadow);color:var(--text-color);display:inline-flex;font-weight:500;margin:0 3px;padding:.5rem .75rem;transition:all .2s ease}.main-tab:hover{transform:translateY(-2px)}.main-tab.active,.main-tab:hover{background-color:var(--hover-bg);color:var(--primary)}.main-tab.active{border-bottom:2px solid var(--primary)}.main-tab .caret{font-size:.7rem;margin-left:6px}.option-label-button,.poll-toggle-btn{border-radius:var(--radius-sm);transition:background-color var(--transition-fast) var(--transition-timing-default)}.poll-toggle-btn.send-poll{background-color:var(--success)}.poll-toggle-btn.end-poll{background-color:var(--error)}.poll-toggle-btn:disabled{background-color:var(--border-color);color:var(--text-secondary)}.poll-option{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--text-color);font-size:var(--font-size-lg);padding:var(--space-4) var(--space-5);transition:background-color var(--transition-fast) var(--transition-timing-default)}.poll-option:hover:not(.disabled){background-color:var(--hover-bg)}.poll-option.selected{background-color:var(--success-light);border:2px solid var(--success)}.option-content{gap:var(--space-2)}.option-text{color:var(--text-color);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium)}.close-button{color:var(--text-secondary);transition:color var(--transition-fast) var(--transition-timing-default)}.btn-subtle,.close-button:hover{color:var(--text-color)}.btn-subtle{background-color:var(--bg-alt);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:11px;margin-top:8px;padding:4px 8px}.btn-subtle:hover{background-color:var(--border-color)}.form{display:flex;flex-direction:column;gap:var(--space-4);width:100%}.form-group,.form-group-horizontal{margin-bottom:var(--space-4)}.form-group-horizontal{align-items:center;display:flex;flex-direction:row;gap:var(--space-4)}.form-group-horizontal label{flex:0 0 30%;max-width:30%}.form-group-horizontal .form-control{flex:1 1}.form-label{color:var(--text-color);display:inline-block;font-weight:var(--font-weight-medium);margin-bottom:var(--space-1)}.form-label-required:after{color:var(--error);content:"*";margin-left:var(--space-1)}.form-helper-text{color:var(--text-secondary)}.form-error-text,.form-helper-text{font-size:var(--font-size-sm);margin-top:var(--space-1)}.compose-error,.form-error-text{color:var(--error)}.compose-error{font-size:.8rem}.form-control{border-radius:var(--radius-md);display:block;font-size:var(--font-size-base);line-height:var(--line-height-base);padding:var(--space-2) var(--space-3);transition:border-color var(--transition-fast) var(--transition-timing-default),box-shadow var(--transition-fast) var(--transition-timing-default);width:100%}.form-control:focus{box-shadow:0 0 0 2px rgba(var(--primary-rgb),.2)}.form-control:disabled,.form-control[readonly]{background-color:var(--bg-alt);cursor:not-allowed;opacity:.7}.form-control-error{border-color:var(--error)}.form-control-error:focus{box-shadow:0 0 0 2px rgba(var(--error-rgb),.2)}.form-control-success{border-color:var(--success)}.form-control-success:focus{box-shadow:0 0 0 2px rgba(var(--success-rgb),.2)}input[type=date],input[type=datetime-local],input[type=email],input[type=month],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=time],input[type=url],input[type=week]{-webkit-appearance:none;appearance:none}textarea.form-control{min-height:100px;resize:vertical}select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right var(--space-2) center;background-repeat:no-repeat;background-size:16px;padding-right:var(--space-6)}.form-check{cursor:pointer;margin-bottom:var(--space-2)}.form-check-input{flex-shrink:0;height:1rem;margin-right:var(--space-2);width:1rem}input[type=checkbox],input[type=radio]{cursor:pointer}.form-check-label{cursor:pointer;font-weight:var(--font-weight-normal);margin-bottom:0}.custom-checkbox{align-items:center;cursor:pointer;display:inline-flex;position:relative}.custom-checkbox-input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.custom-checkbox-mark{align-items:center;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:inline-flex;height:1.25rem;justify-content:center;margin-right:var(--space-2);transition:background-color var(--transition-fast) var(--transition-timing-default),border-color var(--transition-fast) var(--transition-timing-default);width:1.25rem}.custom-checkbox-input:checked~.custom-checkbox-mark{background-color:var(--primary);border-color:var(--primary)}.custom-checkbox-mark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";display:none;height:10px;transform:rotate(45deg);width:5px}.custom-checkbox-input:checked~.custom-checkbox-mark:after{display:block}.form-file{display:inline-block;position:relative}.form-file-input{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}.form-file-label{align-items:center;background-color:var(--bg-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);justify-content:center;padding:var(--space-2) var(--space-4);transition:background-color var(--transition-fast) var(--transition-timing-default),border-color var(--transition-fast) var(--transition-timing-default)}.form-file-input:focus~.form-file-label{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.2)}.form-file-label:hover{background-color:var(--hover-bg)}.form-control-sm{font-size:var(--font-size-sm);padding:var(--space-1) var(--space-2)}.form-control-lg{font-size:var(--font-size-lg);padding:var(--space-3) var(--space-4)}.form-actions{gap:var(--space-3);margin-top:var(--space-5)}.form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(12,1fr)}.form-col-6{grid-column:span 6}.form-col-4{grid-column:span 4}.form-col-3{grid-column:span 3}.form-col-12{grid-column:span 12}.input-group{align-items:stretch;display:flex;position:relative;width:100%}.input-group .form-control:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.input-group .form-control:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.input-group-append,.input-group-prepend{align-items:center;background-color:var(--bg-alt);border:1px solid var(--border-color);color:var(--text-color);display:flex;line-height:var(--line-height-base);padding:var(--space-2) var(--space-3);white-space:nowrap}.input-group-prepend{border-radius:var(--radius-md) 0 0 var(--radius-md);border-right:none}.input-group-append{border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0}.search-field{position:relative}.search-field input{padding-left:2.5rem}.search-field-icon{color:var(--text-tertiary);left:var(--space-3);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.form-success-message{background-color:var(--bg-alt);border-left:4px solid var(--success);border-radius:4px;color:var(--success);margin-top:1rem;padding:.75rem}.test-results{margin-top:20px}@media (max-width:768px){.form-group-horizontal{align-items:flex-start;flex-direction:column}.form-group-horizontal label{flex:0 0 100%;margin-bottom:var(--space-1);max-width:100%}.form-grid{grid-template-columns:1fr}.form-col-12,.form-col-3,.form-col-4,.form-col-6{grid-column:1/-1}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:var(--text-color);overflow:hidden;position:relative;transition:background-color var(--transition-base) var(--transition-timing-default),border-color var(--transition-base) var(--transition-timing-default),box-shadow var(--transition-base) var(--transition-timing-default),transform var(--transition-base) var(--transition-timing-default)}.card-hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-clickable{cursor:pointer}.card-clickable:active{box-shadow:var(--shadow-sm);transform:translateY(1px)}.card-padding-none{padding:0}.card-padding-sm{padding:var(--space-2)}.card-padding-md{padding:var(--space-4)}.card-padding-lg{padding:var(--space-6)}.card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:var(--space-4)}.card-header h1,.card-header h2,.card-header h3,.card-header h4,.card-header h5,.card-header h6{margin:0}.card-body,.card-footer{padding:var(--space-4)}.card-footer{align-items:center;border-top:1px solid var(--border-color);display:flex;gap:var(--space-2);justify-content:flex-end}.card-borderless{border:none}.card-highlight{border-left:4px solid var(--primary)}.card-highlight-success{border-left:4px solid var(--success)}.card-highlight-warning{border-left:4px solid var(--warning)}.card-highlight-danger{border-left:4px solid var(--error)}.card-highlight-info{border-left:4px solid var(--info)}.card-primary{background-color:rgba(var(--primary-rgb),.1)}.card-success{background-color:rgba(var(--success-rgb),.1)}.card-warning{background-color:rgba(var(--warning-rgb),.1)}.card-danger{background-color:rgba(var(--error-rgb),.1)}.card-info{background-color:rgba(var(--info-rgb),.1)}.card-horizontal{display:flex}.card-horizontal .card-media{flex:0 0 33.333%;max-width:33.333%}.card-horizontal .card-content{flex:1 1}.card-media{overflow:hidden;position:relative}.card-media img{display:block;height:auto;width:100%}.card-media-overlay{background:linear-gradient(0deg,#000c,#0000);bottom:0;color:#fff;left:0;padding:var(--space-4);position:absolute;right:0}.card-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.content-card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100%;padding:var(--space-4);transition:transform var(--transition-base) var(--transition-timing-default),box-shadow var(--transition-base) var(--transition-timing-default)}.content-card h3{color:var(--text-color);font-size:var(--font-size-xl);margin-bottom:var(--space-3);margin-top:0}.content-card-body{flex:1 1}.content-card-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:auto}.welcome-section{background-color:var(--bg-card);border-left:5px solid var(--primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--space-6);padding:var(--space-5)}@media (max-width:768px){.card-horizontal{flex-direction:column}.card-horizontal .card-media{flex:0 0 100%;max-width:100%}.card-grid{grid-template-columns:1fr}}.profile-card{background-color:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:all .2s ease}.profile-card:hover{border-color:var(--primary);box-shadow:0 5px 15px var(--shadow);transform:translateY(-2px)}.profile-card-header{align-items:center;background-color:var(--bg-alt);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem}.profile-name{color:var(--text-color);font-size:1.1rem;font-weight:600;margin:0}.profile-level{background-color:var(--primary);border-radius:4px;color:var(--button-text);font-size:.9rem;font-weight:700;padding:.3rem .6rem}.profile-card-body{color:var(--text-color);flex-grow:1;padding:1rem}.profile-location{color:var(--text-color);font-size:.95rem;margin-bottom:.75rem}.profile-location .label{color:var(--text-secondary);font-weight:600}.profile-bio{color:var(--text-color);font-size:.9rem;line-height:1.4}.profile-bio.empty{color:var(--text-tertiary);font-style:italic}.profile-card-footer{background-color:var(--bg-alt);border-top:1px solid var(--border-color);padding:1rem}.profile-stats{display:flex;gap:1rem;margin-bottom:.75rem}.stat{align-items:center;display:flex;flex-direction:column}.stat .value{color:var(--primary);font-size:1.1rem;font-weight:700}.stat .label{color:var(--text-tertiary);font-size:.8rem}.profile-last-seen{color:var(--text-tertiary);font-size:.85rem;text-align:right}.profile-card .btn{border-radius:0 0 8px 8px;margin-top:auto;width:100%}.result-card{border-radius:4px;box-shadow:0 1px 3px var(--shadow);margin-bottom:15px;padding:12px}.result-card.success{background-color:#2ecc711a;border-left:4px solid var(--success)}.result-card.failure{background-color:#e74c3c1a;border-left:4px solid var(--error)}.result-title{font-size:14px;font-weight:700;margin-bottom:8px}.result-message{background:var(--bg-alt);border-radius:3px;font-family:monospace;font-size:13px;line-height:1.4;padding:8px;white-space:pre-wrap;word-break:break-all}.no-results{background:var(--bg-alt);border-radius:4px;color:var(--text-secondary);padding:20px}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(var(--primary-rgb),.7)}70%{box-shadow:0 0 0 10px rgba(var(--primary-rgb),0)}to{box-shadow:0 0 0 0 rgba(var(--primary-rgb),0)}}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}@keyframes loadingDots{0%,80%,to{opacity:0}40%{opacity:1}}@keyframes loadingBar{0%{width:0}to{width:100%}}@keyframes progressLinear{0%{width:0}to{width:100%}}@keyframes progressCircular{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.animate-fade-in{animation:fadeIn var(--transition-base) var(--transition-timing-default) forwards}.animate-fade-out{animation:fadeOut var(--transition-base) var(--transition-timing-default) forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-base) var(--transition-timing-default) forwards}.animate-fade-in-down{animation:fadeInDown var(--transition-base) var(--transition-timing-default) forwards}.animate-scale-in{animation:scaleIn var(--transition-base) var(--transition-timing-default) forwards}.animate-scale-out{animation:scaleOut var(--transition-base) var(--transition-timing-default) forwards}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s infinite}.animate-shake{animation:shake .5s var(--transition-timing-bounce)}.animate-bounce{animation:bounce 1s var(--transition-timing-bounce)}.duration-75{animation-duration:75ms}.duration-100{animation-duration:.1s}.duration-150{animation-duration:.15s}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.duration-500{animation-duration:.5s}.duration-700{animation-duration:.7s}.duration-1000{animation-duration:1s}.delay-0{animation-delay:0ms}.delay-75{animation-delay:75ms}.delay-100{animation-delay:.1s}.delay-150{animation-delay:.15s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-500{animation-delay:.5s}.delay-700{animation-delay:.7s}.delay-1000{animation-delay:1s}.ease-linear{animation-timing-function:linear}.ease-in{animation-timing-function:cubic-bezier(.4,0,1,1)}.ease-out{animation-timing-function:cubic-bezier(0,0,.2,1)}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.ease-bounce{animation-timing-function:var(--transition-timing-bounce)}.fill-none{animation-fill-mode:none}.fill-forwards{animation-fill-mode:forwards}.fill-backwards{animation-fill-mode:backwards}.fill-both{animation-fill-mode:both}.iterate-infinite{animation-iteration-count:infinite}.iterate-once{animation-iteration-count:1}.iterate-twice{animation-iteration-count:2}.paused{animation-play-state:paused}.running{animation-play-state:running}.direction-normal{animation-direction:normal}.direction-reverse{animation-direction:reverse}.direction-alternate{animation-direction:alternate}.direction-alternate-reverse{animation-direction:alternate-reverse}.transition-all{transition-property:all;transition-timing-function:var(--transition-timing-default)}.transition-all,.transition-transform{transition-duration:var(--transition-base)}.transition-transform{transition-property:transform;transition-timing-function:var(--transition-timing-default)}.transition-opacity{transition-property:opacity;transition-timing-function:var(--transition-timing-default)}.transition-colors,.transition-opacity{transition-duration:var(--transition-base)}.transition-colors{transition-property:background-color,border-color,color,fill,stroke;transition-timing-function:var(--transition-timing-default)}.loading-spinner{animation:spin .75s linear infinite;border:2px solid var(--bg-alt);border-radius:50%;border-top-color:var(--primary);display:inline-block;height:2rem;width:2rem}.loading-spinner-sm{border-width:1px;height:1rem;width:1rem}.loading-spinner-lg{border-width:3px;height:3rem;width:3rem}.loading-dots{align-items:center;display:inline-flex}.loading-dots:after{animation:loadingDots 1.4s infinite both;margin-left:.25rem}.loading-dots:after,.loading-dots:before{background-color:currentColor;border-radius:50%;content:"";height:.25rem;width:.25rem}.loading-dots:before{animation:loadingDots 1.4s .2s infinite both;margin-right:.25rem}.progress-bar{background-color:var(--bg-alt);border-radius:var(--radius-full);height:.25rem;overflow:hidden}.progress-bar-fill{background-color:var(--primary);border-radius:var(--radius-full);height:100%;transition:width .3s ease}.progress-bar-indeterminate .progress-bar-fill{animation:progressLinear 1.5s ease-in-out infinite;animation-direction:alternate;width:50%}@media (prefers-reduced-motion){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.modal-enter{animation:scaleIn var(--transition-base) var(--transition-timing-default) forwards}.modal-exit{animation:scaleOut var(--transition-base) var(--transition-timing-default) forwards}.tooltip-enter{animation:fadeInUp var(--transition-fast) var(--transition-timing-default) forwards}.tooltip-exit{animation:fadeOut var(--transition-fast) var(--transition-timing-default) forwards}.dropdown-enter{animation:fadeInDown var(--transition-fast) var(--transition-timing-default) forwards}.dropdown-exit{animation:fadeOut var(--transition-fast) var(--transition-timing-default) forwards}.toast-enter{animation:fadeInRight var(--transition-base) var(--transition-timing-default) forwards}.toast-exit{animation:fadeOutRight var(--transition-base) var(--transition-timing-default) forwards}@keyframes fadeOutRight{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}.inline-loading{align-items:center;color:#555;color:var(--text-secondary,#555);display:flex;font-size:.875rem;justify-content:center;padding:1rem}@keyframes storyFadeOut{0%{opacity:1}to{opacity:0}}.report-page.main-content{box-sizing:border-box;margin:0!important;max-width:100%!important;padding:20px;width:100%!important}.question-practice-container{margin:0 auto;max-width:100%!important}.qp-report-table{margin:1rem auto!important;max-width:1200px!important;width:100%!important}.custom-date-range,.date-filter-bar,.student-selector{margin-left:auto;margin-right:auto;max-width:100%}@media (max-width:768px){.report-page.main-content{padding:10px}.qp-report-table td,.qp-report-table th{font-size:.85rem;padding:6px 8px}}.export-pdf-btn{background-color:#2563eb;background-color:var(--primary,#2563eb);border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:background-color .2s}.export-pdf-btn:hover{background-color:#1e40af;background-color:var(--primary-dark,#1e40af)}.presentation-landing-container{align-items:center;animation:gradientShift 12s ease infinite;background:linear-gradient(135deg,#ff7e5f,#feb47b,#86a8e7,#91eae4);background-size:400% 400%;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px;text-align:center}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.presentation-welcome{color:#fff;font-size:2.2rem;font-weight:800;margin:0 0 30px;max-width:90%;text-shadow:2px 2px 5px #00000040}.presentation-qr{border:6px solid #fff;border-radius:18px;box-shadow:0 6px 15px #0000004d;height:auto;max-width:80vw;transition:transform .3s ease;width:380px}.presentation-qr:hover{transform:scale(1.05)}.presentation-landing-container,.presentation-landing-container *{-webkit-user-select:none;user-select:none}:fullscreen .presentation-welcome{font-size:4vw!important}:fullscreen .presentation-qr{margin-bottom:5vh!important;max-width:65vh!important;width:40vw!important}:-webkit-full-screen .presentation-welcome{font-size:4vw!important}:-webkit-full-screen .presentation-qr{margin-bottom:5vh!important;max-width:65vh!important;width:40vw!important}:-webkit-full-screen .presentation-landing-container,:fullscreen .presentation-landing-container{padding:5vh 5vw!important}.encounter-display{--fade-duration:1.5s;background-color:#000;color:#fff;cursor:pointer;font-family:Arial,sans-serif;height:100vh;overflow:hidden;position:relative;width:100vw}.encounter-display,.encounter-display *{-webkit-user-select:none;user-select:none}.encounter-backdrop{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:1}.encounter-backdrop img{height:100%;object-fit:cover;width:100%}.encounter-character{align-items:flex-end;bottom:0;display:flex;height:60vh;position:absolute;z-index:2}.encounter-character img{display:block;max-height:100%;object-fit:contain;width:auto}.character-1{bottom:0;left:0}.character-2{bottom:0;right:0}.encounter-content{background-color:#0009;border-radius:8px;box-shadow:0 4px 8px #0000004d;display:flex;flex-direction:column;justify-content:center;left:50%;max-height:80%;max-width:60%;overflow:hidden;padding:40px;position:absolute;top:50%;transform:translate(-50%,-50%);width:60%;z-index:3}.encounter-title{color:#fff;font-size:2.5rem;margin-bottom:20px;text-align:center;text-shadow:0 0 10px #00000080}.encounter-description{font-size:1.5rem;line-height:1.6;text-shadow:0 0 5px #00000080;white-space:pre-wrap}:root{--transition-duration:1.5s}.presentation-display-container{background-color:#000;height:100vh;overflow:hidden;position:relative;width:100%}.slide-container{height:100%;left:0;position:absolute;top:0;width:100%;will-change:opacity}.slide-active,.slide-entering{opacity:1;z-index:1}.slide-exiting{animation:fadeOutAnimation 1.5s ease-in-out forwards;animation:fadeOutAnimation var(--transition-duration) forwards ease-in-out;opacity:1;pointer-events:none;z-index:2}@keyframes fadeOutAnimation{0%{opacity:1}to{opacity:0}}.slide-exiting .encounter-description,.slide-exiting .encounter-title{-webkit-font-smoothing:subpixel-antialiased;transform:translateZ(0)}.slide-container>*{height:100%;opacity:1;width:100%}body.single-player-game-active .message-dropdown{display:none!important}.singleplayer-controls{align-items:center;display:flex;gap:8px;position:fixed;right:10px;top:10px;z-index:9999}.singleplayer-controls .scenario-selector select{max-width:220px;padding:6px 8px}.singleplayer-controls .back-btn{font-size:.9rem;height:36px;padding:6px 12px}.singleplayer-back-btn{left:10px;position:fixed;top:10px;z-index:9999}.single-player-intro{align-items:center;background:#000;color:#fff;display:flex;font-size:2rem;height:100vh;justify-content:center;text-align:center;width:100vw}.encounter-form{box-sizing:border-box!important;display:flex;flex-direction:column;gap:1rem;width:100%!important}.encounter-form,.encounter-form h3{max-width:100%!important;overflow:hidden!important}.encounter-form h3{color:var(--text-color);font-size:1.2rem;margin-bottom:.5rem;margin-top:0;text-overflow:ellipsis!important;white-space:nowrap!important}.form-group{box-sizing:border-box!important;display:flex;flex-direction:column;max-width:100%!important;overflow:hidden!important;width:100%!important}.form-group label{color:var(--text-color)!important;font-size:.9rem;margin-bottom:.4rem}.form-control{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box!important;color:var(--text-color);font-family:inherit;font-size:.95rem;max-width:100%!important;padding:.6rem;transition:border-color .2s;width:100%!important}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 2px #3498db1a;box-shadow:0 0 0 2px var(--primary-shadow,#3498db1a);outline:none}textarea.form-control{min-height:120px!important}input.form-control,textarea.form-control{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.encounter-info{background-color:var(--bg-alt);border-radius:4px;margin-top:.5rem;padding:.8rem}.encounter-info,.info-item{box-sizing:border-box!important;max-width:100%!important;overflow:hidden!important;width:100%!important}.info-item{display:flex!important;flex-wrap:wrap!important;font-size:.85rem;margin-bottom:.5rem}.info-item:last-child{margin-bottom:0}.info-label{color:var(--text-secondary);font-weight:600;margin-right:.5rem!important}.info-value{color:var(--text-color);flex:1 1!important;overflow:hidden!important;text-overflow:ellipsis!important}@media (max-width:768px){.encounter-form{box-sizing:border-box!important;margin:0!important;padding:10px!important}.encounter-form,.form-group{max-width:100%!important;overflow:hidden!important;width:100%!important}.form-group{margin:0 0 10px!important;padding:0!important}.form-group:last-of-type{margin-bottom:0!important}.form-control,input.form-control,textarea.form-control{box-sizing:border-box!important;font-size:14px!important;max-width:100%!important;padding:8px!important;width:100%!important}label{display:block!important;margin-bottom:5px!important;width:100%!important}textarea.form-control{min-height:100px!important}}.encounter-routes{box-sizing:border-box!important;display:flex;flex-direction:column;gap:1rem;max-width:100%!important;overflow:hidden!important;width:100%!important}.encounter-routes h3{color:var(--text-color);font-size:1.2rem;margin-bottom:.5rem;margin-top:0}.no-routes{background-color:var(--bg-alt);border-radius:4px;color:var(--text-secondary);padding:1.5rem;text-align:center}.encounter-route{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box!important;margin-bottom:1rem;max-width:100%!important;overflow:hidden!important;padding:1rem;position:relative;transition:box-shadow .2s ease;width:100%!important}.encounter-route:hover{border-color:var(--primary);box-shadow:0 2px 8px var(--shadow)}.route-content{align-items:center;display:flex;gap:1rem;justify-content:space-between;overflow:hidden!important}.route-content,.route-title-input{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.route-title-input{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);flex:1 1;font-family:inherit;font-size:.95rem;padding:.6rem}.route-title-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #3498db1a;box-shadow:0 0 0 2px var(--primary-shadow,#3498db1a);outline:none}.route-actions{box-sizing:border-box!important;display:flex!important;flex-wrap:wrap!important;gap:.5rem!important;max-width:100%!important;width:100%!important}.route-actions button{flex:0 1 auto!important;font-size:.85rem;margin-left:0;margin-right:0;white-space:nowrap!important}.cancel-btn,.delete-btn,.follow-btn,.link-btn,.new-btn,.unlink-btn,.unlinked-option{all:unset}.unlinked-encounters-list{background-color:var(--bg-alt);border:1px solid var(--border-color);border-radius:4px;margin-top:1rem;padding:1rem}.unlinked-encounters-list h4{color:var(--text-color);font-size:.9rem;margin-bottom:.75rem;margin-top:0}.unlinked-options{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.route-navigation{margin-bottom:15px}.up-level-btn{background-color:var(--bg-alt);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-weight:700;padding:8px 15px;transition:background-color .3s}.up-level-btn:hover{background-color:var(--hover-bg);color:var(--text-color)}.encounter-route,.encounter-routes,.route-actions,.route-content,.route-title-input{box-sizing:border-box!important;max-width:100vw!important;overflow:hidden!important;width:100%!important}@media (max-width:768px){.route-content{align-items:stretch!important;max-width:100%!important}.route-actions,.route-content{display:flex!important;flex-direction:column!important;margin:0!important;padding:0!important;width:100%!important}.route-actions button{margin:0 0 .5rem!important;overflow:hidden!important;padding:.5rem!important;text-overflow:ellipsis!important;white-space:nowrap!important;width:100%!important}.route-actions button:last-child{margin-bottom:0!important}}.storyline-editor{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);overflow-x:hidden!important;padding:1.5rem;width:100%}.storyline-controls,.storyline-editor{box-sizing:border-box!important;max-width:100%!important}.storyline-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;overflow:visible!important;width:100%!important}.control-item{display:flex;flex-grow:1;min-width:200px}.control-item>button,.control-item>select{box-sizing:border-box;width:100%}.add-choice-button,.primary-button,.secondary-button{background:var(--button-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--button-text);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background-color .2s ease,color .2s ease}.primary-button{background:var(--primary);color:var(--button-text)}.primary-button:hover{background:var(--secondary)}.secondary-button{background:var(--bg-alt);color:var(--text-secondary)}.secondary-button:hover{background:var(--hover-bg);color:var(--text-color)}.add-choice-button{background:var(--success);color:var(--button-text);margin-bottom:1rem}.add-choice-button:hover{filter:brightness(90%)}.root-encounter-dropdown{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);font-size:1rem;height:auto;padding:.75rem}.root-encounter-dropdown:hover{border-color:var(--primary)}.root-encounter-dropdown:focus{border-color:var(--primary);box-shadow:0 0 0 2px #3498db33;box-shadow:0 0 0 2px var(--primary-shadow,#3498db33);outline:none}.loading{color:var(--text-tertiary);padding:2rem;text-align:center}.error{background-color:var(--bg-alt);border:1px solid var(--error);border-radius:4px;color:var(--error);margin-bottom:1rem;padding:.75rem}.storyline-editor{margin:0 auto;max-width:1200px;padding:20px}.encounter-editor{background:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);box-sizing:border-box!important;margin-top:20px;max-width:100%!important;overflow:hidden!important;padding:20px;width:100%!important}.editor-row{display:flex;gap:20px}.encounter-form-section{box-sizing:border-box!important;flex:1 1;max-width:100%!important;min-width:300px;overflow:hidden!important;width:100%!important}.encounter-routes-section{flex:2 1;min-width:400px}.image-selector-section{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.image-selector-section h3{color:var(--text-color);margin-bottom:1rem;margin-top:0}.image-selectors{display:flex;flex-wrap:wrap;gap:1.5rem}.image-selectors-row{display:flex;flex-direction:row;gap:20px;justify-content:space-between;margin-top:20px}.image-selectors-row>*{flex:1 1}.storyline-editor .visual-breadcrumb-trail{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;display:flex;justify-content:center;margin-bottom:1rem;overflow-x:auto;padding:1rem .5rem}.dark-theme .storyline-editor .visual-breadcrumb-trail{background-color:#1e2124!important;border-color:#444!important}.storyline-editor .breadcrumb-circle{align-items:center;background-color:var(--primary);border:2px solid var(--border-color);border-radius:50%;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;line-height:1;min-height:40px;min-width:40px;padding:0;position:relative;text-align:center;transition:all .2s ease;width:40px}.storyline-editor .breadcrumb-circle:hover{box-shadow:0 2px 5px #0003;transform:scale(1.1)}.storyline-editor .breadcrumb-circle.active{box-shadow:0 0 0 3px #3498db80;box-shadow:0 0 0 3px var(--primary-shadow,#3498db80)}.storyline-editor .breadcrumb-circle.status-red{background-color:var(--error)}.storyline-editor .breadcrumb-circle.status-yellow{background-color:var(--warning)}.storyline-editor .breadcrumb-circle.status-green{background-color:var(--success)}.storyline-editor .breadcrumb-circle.status-default{background-color:var(--primary)}.storyline-editor .breadcrumb-arrow{align-items:center;color:var(--text-color);display:flex;margin:0 8px}.breadcrumb-item,.breadcrumb-separator,.breadcrumb-trail{display:none}@media (max-width:768px){.storyline-controls{flex-direction:column;gap:.75rem}.storyline-controls .control-item{flex-grow:0;margin-bottom:.5rem;min-width:0;width:100%}.storyline-controls .control-item:last-child{margin-bottom:0}.storyline-controls .control-item>button,.storyline-controls .control-item>select{box-sizing:border-box!important;width:100%!important}.root-encounter-dropdown{min-width:100%;width:100%}.storyline-controls button{width:100%}.editor-row{flex-direction:column}.encounter-editor{padding:15px!important}.encounter-editor,.encounter-form-section,.encounter-routes-section{max-width:100%!important;overflow:hidden!important;width:100%!important}.encounter-form-section,.encounter-routes-section{box-sizing:border-box!important;flex:none!important;min-width:0!important}.image-selectors,.image-selectors-row{flex-direction:column}}.image-note{background-color:var(--bg-alt);border-left:3px solid var(--primary);border-radius:0 4px 4px 0;color:var(--text-secondary);font-size:14px;margin-bottom:15px;padding:8px 12px}button,input,select,textarea{box-sizing:border-box!important;max-width:100%!important}.storyline-editor .encounter-route{overflow:hidden!important}.storyline-editor .encounter-route,.storyline-editor .route-content,.storyline-editor .route-title-input{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.storyline-editor .route-actions{flex-wrap:wrap!important;max-width:100%!important;width:100%!important}.main-content,.storyline-editor .form-control,.storyline-editor .form-group{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.main-content{overflow-x:hidden!important}.storyline-editor,.storyline-editor *{word-wrap:break-word!important;box-sizing:border-box!important;max-width:100%!important;overflow-wrap:break-word!important;word-break:break-word!important}.route-title-input,button,input[type=text],select{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.form-control[type=textarea],textarea{overflow:auto!important;white-space:pre-wrap!important}.encounter-route .route-content{box-sizing:border-box!important;display:flex!important;flex-direction:column!important;margin:0!important;max-width:100%!important;overflow:hidden!important;padding:0!important;width:100%!important}@media (max-width:768px){.route-actions{flex-direction:column!important;width:100%!important}.route-actions button{margin:0 0 .5rem!important;width:100%!important}.route-actions button:last-child{margin-bottom:0!important}.form-control,input,select,textarea{max-width:100%!important;min-width:0!important;width:100%!important}}.encounter-editor input,.encounter-editor select,.encounter-editor textarea{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.debug-panel{background:#0000000d;border:1px solid #ccc;font-size:12px;margin-bottom:10px;max-height:200px;overflow:auto;padding:8px}.confirm-overlay{align-items:center;background:#0000008c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.confirm-modal{animation:fadeInScale .25s ease-out forwards;background:#fff;border-radius:6px;box-shadow:0 4px 12px #00000040;max-width:400px;padding:20px 24px;position:relative;width:90%}.close-btn{background:#0000;right:10px}.confirm-body{margin-bottom:18px;text-align:center}.confirm-actions{display:flex;gap:16px;justify-content:center}.btn{border:none;border-radius:4px;cursor:pointer;padding:8px 18px}.btn-primary{background:#007bff}.btn-secondary{background:#6c757d}@keyframes fadeInScale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.user-management{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);box-sizing:border-box;max-width:100%;overflow-x:hidden;padding:1.5rem;width:100%}.user-management-header{align-items:center;border-bottom:1px solid var(--border-color);box-sizing:border-box;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;width:100%}.user-management-header h2{color:var(--text-color);font-size:1.5rem;margin:0}.add-user-btn{background-color:var(--primary);border:none;border-radius:4px;color:var(--button-text);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background-color .2s ease}.add-user-btn:hover{background-color:#2980b9}.user-controls{align-items:center;box-sizing:border-box;display:flex;justify-content:space-between;margin-bottom:1rem;width:100%}.search-filter{display:flex;flex-grow:1;gap:.5rem;max-width:600px}.search-input{flex-grow:1;font-size:.9rem;width:100%}.role-filter,.search-input{border:1px solid #e7ecf0;border-radius:4px;box-sizing:border-box;padding:.5rem}.role-filter{background-color:#fff;min-width:140px}.results-info{color:#000;font-size:.9rem}.error-message{background-color:#ffecec;border-left:4px solid #e74c3c;border-radius:4px;box-sizing:border-box;color:#e74c3c;margin-bottom:1rem;padding:.75rem;width:100%}.users-table-container{box-sizing:border-box;margin-bottom:1.5rem;overflow-x:auto;width:100%}.users-table{border-collapse:collapse;box-sizing:border-box;font-size:.95rem;width:100%}.users-table th{background-color:var(--bg-alt);border-bottom:2px solid var(--border-color);box-sizing:border-box;color:var(--text-color);cursor:pointer;font-weight:600;padding:.75rem;text-align:left;-webkit-user-select:none;user-select:none}.users-table th:hover{background-color:var(--hover-bg)}.users-table td{border-bottom:1px solid var(--border-color);box-sizing:border-box;color:var(--text-color);padding:.75rem}.users-table tr:hover{background-color:var(--hover-bg)}.email-cell{align-items:center;display:flex;gap:.5rem}.verified-badge{align-items:center;background-color:#2ecc71;border-radius:50%;color:#fff;display:inline-flex;font-size:.7rem;font-weight:700;height:16px;justify-content:center;width:16px}.admin-role{color:#9b59b6;font-weight:500}.educator-role{color:#3498db;font-weight:500}.student-role{color:#000}.user-nickname{color:#000;font-size:.85rem;margin-left:.5rem}.action-buttons{display:flex;gap:.5rem}.no-results{color:#000;font-style:italic;padding:2rem 0!important;text-align:center}.no-results,.pagination{box-sizing:border-box;width:100%}.pagination{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-top:1.5rem}.pagination-button{background-color:#fff;border:1px solid #e7ecf0;border-radius:4px;box-sizing:border-box;cursor:pointer;padding:.4rem .75rem;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:#3498db;border-color:#3498db;color:#000}.pagination-button:disabled{color:#999;cursor:not-allowed}.pagination-info{color:#000;margin:0 .5rem}.user-modal-overlay{align-items:center;background-color:#00000080;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.user-modal{background-color:#fff;border-radius:8px;box-shadow:0 5px 20px #0003;box-sizing:border-box;max-height:90vh;max-width:800px;overflow-y:auto;padding:1.5rem;width:95%}.user-modal-header{align-items:center;border-bottom:1px solid #e7ecf0;box-sizing:border-box;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;width:100%}.user-modal-header h2{color:#000;margin:0}.close-button{background:none;border:none;color:#555;cursor:pointer;font-size:1.5rem}.close-button:hover{color:#000}.form-group{margin-bottom:1rem}.form-group,.form-group label{box-sizing:border-box;width:100%}.form-group label{color:#000}.form-group input,.form-group select,.form-group textarea{border:1px solid #e7ecf0;color:#000;font-size:.95rem;padding:.65rem}.form-row{display:flex;gap:15px;margin-bottom:15px}.form-column,.form-row{box-sizing:border-box;width:100%}.form-column{flex:1 1}.form-column label{display:block;margin-bottom:5px}.form-column input,.form-column label{box-sizing:border-box;width:100%}.form-check{align-items:center;display:flex;gap:.5rem}.form-check input{height:16px;margin:0;width:16px}.form-check label{color:#000;font-weight:500}.form-check input:disabled+label{cursor:not-allowed;opacity:.7}.modal-actions{box-sizing:border-box;gap:1rem;margin-top:1.5rem;width:100%}.cancel-button,.save-button{border:none;border-radius:4px;box-sizing:border-box;cursor:pointer;font-weight:500;padding:.65rem 1.5rem;transition:background-color .2s ease}.cancel-button{background-color:#ecf0f1;color:#000}.cancel-button:hover{background-color:#dfe4e6}.save-button{background-color:#3498db;color:#000}.save-button:hover{background-color:#2980b9}.loading-spinner{align-items:center;box-sizing:border-box;color:#000;display:flex;font-size:1.1rem;justify-content:center;min-height:200px;width:100%}.user-badges-section{border-top:1px solid #eee;box-sizing:border-box;margin-top:30px;padding-top:20px;width:100%}.user-modal .user-badges-section .badge-list .badge-item .badge-info .badge-details h4{color:#000!important;font-weight:700!important}.badge-list{border:1px solid #eee;border-radius:4px;margin-bottom:15px;max-height:250px;overflow-y:auto}.badge-item,.badge-list{box-sizing:border-box;padding:10px;width:100%}.badge-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between}.badge-item:last-child{border-bottom:none}.badge-info{align-items:center;box-sizing:border-box;display:flex;gap:15px;width:100%}.badge-image{height:50px;width:50px}.badge-details{flex:1 1}.badge-details h4{color:#000!important;font-size:16px;margin:0 0 5px}.badge-details p{color:#000;font-size:14px;margin:0 0 5px}.badge-date,.remove-badge-btn{color:#000;font-size:12px}.remove-badge-btn{background-color:#ff5757;border:none;border-radius:4px;cursor:pointer;padding:5px 10px}.remove-badge-btn:hover{background-color:#ff3030}.add-badge-section{box-sizing:border-box;margin-top:15px;width:100%}.add-badge-form{display:flex;gap:10px}.add-badge-form,.badge-select{box-sizing:border-box;width:100%}.badge-select{border:1px solid #ddd;border-radius:4px;flex:1 1;padding:8px}.add-badge-btn{background-color:#4caf50;border:none;border-radius:4px;color:#000;cursor:pointer;padding:8px 15px}.add-badge-btn:hover{background-color:#45a049}.add-badge-btn:disabled{background-color:#ccc;cursor:not-allowed}.level-cell,.xp-cell{font-weight:700;text-align:center}.xp-cell{color:#e67e22}.level-cell{color:#3498db}.form-container{box-sizing:border-box;display:flex;flex-wrap:wrap;gap:30px;margin-bottom:20px;width:100%}.form-column-left,.form-column-right{box-sizing:border-box;flex:1 1;min-width:300px;width:100%}.form-column-left .form-group,.form-column-right .form-group{box-sizing:border-box;margin-bottom:20px;width:100%}@media (max-width:768px){.user-management{box-sizing:border-box!important;max-width:100%!important;overflow-x:hidden!important;padding:1rem!important;width:100%!important}.user-management-header{align-items:flex-start!important;flex-direction:column!important;gap:1rem!important;width:100%!important}.add-user-btn{box-sizing:border-box!important;width:100%!important}.user-controls{align-items:flex-start!important;gap:1rem!important}.search-filter,.user-controls{flex-direction:column!important;width:100%!important}.search-filter{gap:.5rem!important;max-width:100%!important}.role-filter,.search-input{box-sizing:border-box!important;width:100%!important}.users-table-container{overflow-x:visible!important;width:100%!important}.users-table{box-sizing:border-box!important;display:block!important;width:100%!important}.users-table thead{display:none!important}.users-table tbody,.users-table tr{display:block!important;width:100%!important}.users-table tr{border:1px solid var(--border-color)!important;border-radius:4px!important;box-sizing:border-box!important;margin-bottom:1rem!important}.users-table td{border:none!important;border-bottom:1px solid #eee!important;border-bottom:1px solid var(--border-color-light,#eee)!important;box-sizing:border-box!important;display:flex!important;padding:.5rem!important;text-align:left!important;width:100%!important}.users-table td:last-child{border-bottom:none!important}.users-table td:first-of-type{display:none!important}.users-table td:nth-of-type(2):before{content:"Name: ";font-weight:700;margin-right:.5rem}.users-table td:nth-of-type(3):before{content:"Email: ";font-weight:700;margin-right:.5rem}.users-table td:nth-of-type(4):before{content:"Level: ";font-weight:700;margin-right:.5rem}.users-table td:nth-of-type(5):before{content:"Last Seen: ";font-weight:700;margin-right:.5rem}.users-table td:nth-of-type(6):before{content:"Role: ";font-weight:700;margin-right:.5rem}.users-table td:nth-of-type(7):before{content:"Actions: ";font-weight:700;margin-right:.5rem}.action-buttons{flex-direction:column!important;gap:.5rem!important;width:100%!important}.action-buttons button{box-sizing:border-box!important;margin:0!important;width:100%!important}.pagination{flex-wrap:wrap!important;gap:.5rem!important;justify-content:center!important}.pagination-button{flex:1 1!important;min-width:calc(25% - .5rem)!important;text-align:center!important}.user-modal{height:90vh!important;max-height:90vh!important;max-width:95%!important;overflow-y:auto!important;padding:1rem!important;width:95%!important}.form-container{flex-direction:column!important;gap:1rem!important}.form-column-left,.form-column-right{flex:1 0 100%!important;min-width:100%!important;width:100%!important}.form-row{gap:.75rem!important}.form-row,.modal-actions{flex-direction:column!important}.modal-actions{gap:.5rem!important;width:100%!important}.modal-actions button{box-sizing:border-box!important;margin:0!important;width:100%!important}.add-badge-form{gap:.5rem!important}.add-badge-form,.badge-info{flex-direction:column!important}.badge-info{align-items:center!important;text-align:center!important}.badge-item{flex-direction:column!important;gap:.75rem!important}.remove-badge-btn{width:100%!important}}.action-buttons .btn{box-sizing:border-box;min-width:80px}.badge-showcase{margin-top:2rem}.badge-showcase__title{color:#333;color:var(--text-color,#333);font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.badge-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.badge-card{background:#fff;background:var(--bg-alt,#fff);border-radius:12px;box-shadow:0 2px 6px #00000014;flex-direction:column;height:100%;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}.badge-card:hover{box-shadow:0 8px 18px #00000026;transform:translateY(-6px)}.badge-card__image-wrapper{aspect-ratio:1/1;background:#f1f1f1;background:var(--bg-muted,#f1f1f1);position:relative;width:100%}.badge-card__image{height:100%;object-fit:cover;width:100%}.badge-card__content{display:flex;flex:1 1;flex-direction:column;padding:.75rem 1rem 1rem}.badge-card__title{color:#333;color:var(--text-color,#333);font-size:1rem;font-weight:600;margin:0 0 .25rem;text-align:center}.badge-card__description{color:#666;color:var(--text-secondary,#666);flex-grow:1;font-size:.8rem;margin:0 0 .5rem;text-align:center}.badge-card__earned{color:#888;color:var(--text-secondary,#888);font-size:.7rem;text-align:center}.badge-card__overlay{background:#0009;bottom:0;color:#fff;font-size:.8rem;left:0;opacity:0;padding:.4rem .6rem;position:absolute;text-align:center;transform:translateY(100%);transition:opacity .25s ease,transform .25s ease;width:100%}.badge-card:hover .badge-card__overlay{opacity:1;transform:translateY(0)}.badge-modal{align-items:center;background:#000000a6;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.badge-modal__content{background:#fff;background:var(--bg,#fff);border-radius:12px;box-shadow:0 6px 20px #00000040;padding:2rem 1.5rem 1.5rem;position:relative;text-align:center;width:min(90%,480px)}.badge-modal__close{background:#0000;border:none;color:#666;color:var(--text-color,#666);cursor:pointer;font-size:1.6rem;line-height:1;position:absolute;right:.8rem;top:.6rem}.badge-modal__image{border-radius:8px;display:block;height:280px;margin:0 auto 1.5rem;object-fit:cover;width:280px}.badge-modal__description,.badge-modal__earned,.badge-modal__title{text-align:center}.badge-modal__title{color:#333;color:var(--text-color,#333);font-size:1.4rem;margin:0 0 .5rem}.badge-modal__description{color:#555;color:var(--text-secondary,#555);font-size:.9rem;margin-bottom:.75rem}.badge-modal__earned{color:#777;color:var(--text-secondary,#777);font-size:.8rem}.no-badges{margin-top:1rem;text-align:center}.badge-detail-modal{max-width:500px;width:90%}.user-profile-container{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);margin:0 auto;max-width:1200px;padding:2rem;width:100%}.user-profile-container h2{border-bottom:1px solid var(--border-color);color:var(--text-color);font-size:1.8rem;margin-bottom:1.5rem;padding-bottom:1rem}.profile-error{border-left:4px solid var(--error);color:var(--error)}.profile-error,.profile-success{background-color:var(--bg-alt);border-radius:4px;margin-bottom:1rem;padding:.75rem}.profile-success{border-left:4px solid var(--success);color:var(--success)}.profile-notice{border-left:4px solid var(--info);border-radius:4px;color:var(--info);margin-bottom:1rem;padding:.75rem}.profile-notice,h2 span{background-color:var(--bg-alt)}h2 span{border-radius:3px;color:var(--text-secondary);font-size:.8rem;font-weight:400;margin-left:.75rem;padding:.3rem .6rem;vertical-align:middle}.profile-loading{align-items:center;background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 10px var(--shadow);color:var(--text-color);display:flex;font-size:1.1rem;justify-content:center;min-height:200px;padding:2rem}.profile-content{display:flex;flex-wrap:wrap;gap:2rem}.profile-form-section,.profile-stats-section{flex:1 1;min-width:350px}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-color);display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;color:var(--text-color);font-size:1rem;padding:.75rem;width:100%}.form-group textarea{min-height:100px;resize:vertical}.form-group input:disabled{background-color:var(--bg-alt);cursor:not-allowed;opacity:.7}.field-hint{color:var(--text-secondary);display:block;font-size:.8rem;margin-top:.25rem}.profile-form .btn{align-self:center;margin-top:1.5rem}.profile-badges,.profile-stats{background-color:var(--bg-alt);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.profile-badges h3,.profile-stats h3{color:var(--text-color);font-size:1.2rem;margin-bottom:1rem;margin-top:0}.stats-grid{display:flex;gap:1rem;justify-content:space-between}.stat-item{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 5px var(--shadow);flex:1 1;padding:1rem;text-align:center}.stat-value{color:var(--primary);font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:var(--text-secondary);font-size:.9rem}.badges-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));max-height:400px;overflow-y:auto;padding-right:.5rem}.badge-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 5px var(--shadow);display:flex;gap:1rem;padding:1rem}.badge-image{border-radius:4px;height:60px;object-fit:cover;width:60px}.badge-info{flex:1 1}.badge-info h4{color:var(--text-color);font-size:1rem;margin:0 0 .5rem}.badge-info p{color:var(--text-secondary);font-size:.9rem;margin:0 0 .5rem}.badge-date{display:block;font-size:.8rem}.badge-date,.no-badges{color:var(--text-tertiary)}.no-badges{font-style:italic}@media (max-width:768px){.user-profile-container{overflow-x:hidden!important;padding:1rem!important}.profile-content{flex-direction:column!important;gap:1.25rem 0!important}.left-column,.profile-form-section,.profile-info-section,.profile-stats-section{min-width:0!important}.form-group,.left-column,.profile-form-section,.profile-info-section,.profile-stats-section{box-sizing:border-box!important;margin-left:0!important;margin-right:0!important;padding-left:0!important;padding-right:0!important;width:100%!important}.form-group input,.form-group select,.form-group textarea{box-sizing:border-box!important;margin-left:0!important;margin-right:0!important;max-width:100%!important;width:100%!important}.stats-grid{flex-direction:column}.badges-grid{grid-template-columns:1fr}}.public-profile .profile-content{display:flex;flex-wrap:wrap;gap:2rem}.profile-info-section{flex:1 1;min-width:350px}.profile-card{background-color:var(--bg-alt);border-radius:8px;box-shadow:0 2px 5px var(--shadow);margin-bottom:2rem;padding:1.5rem}.profile-card h3{border-bottom:1px solid var(--border-color);font-size:1.2rem;margin-top:0;padding-bottom:.7rem}.profile-card h3,.profile-field{color:var(--text-color);margin-bottom:1rem}.profile-field{line-height:1.5}.profile-field strong{color:var(--text-secondary);font-weight:600;margin-right:.5rem}.profile-field.empty{color:var(--text-tertiary);font-style:italic}.profile-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.back-button{align-items:center;background-color:var(--hover-bg);border:none;border-radius:4px;color:var(--primary);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.back-button:hover{background-color:var(--bg-alt);color:var(--secondary)}.back-link{margin-top:1.5rem}.back-link a{align-items:center;color:var(--primary);display:inline-flex;font-weight:500;text-decoration:none}.back-link a:hover{color:var(--secondary);text-decoration:underline}.btn-save-profile{background-color:#28a745!important;border-color:#1e7e34!important;color:#fff!important}.btn-save-profile:hover{background-color:#218838!important;border-color:#196c2c!important}.educator-panel{background-color:var(--bg-alt);color:var(--text-color);display:flex;flex-direction:column;font-family:Arial,sans-serif;min-height:calc(100vh - 150px);width:100%}.scenario-selector{align-items:center;display:flex;flex-grow:1;margin:0 15px}.scenario-selector .control-item{display:flex;width:100%}.scenario-selector .control-item>select{width:100%}.scenario-selector label{font-weight:700;margin-right:10px;white-space:nowrap}.scenario-selector select{border-radius:4px;cursor:pointer;font-size:1rem;max-width:260px;padding:8px 12px;width:100%}.open-display-btn{border:none;border-radius:4px;cursor:pointer;flex-shrink:0;font-weight:700;padding:8px 15px;transition:background-color .3s}.panel-content{grid-gap:15px;display:grid;flex-grow:1;gap:15px;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;overflow-y:auto;padding:15px}.poll-info-section{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 5px var(--shadow);display:flex;flex-direction:column;grid-column:1;grid-row:1;padding:10px}.poll-time{border-bottom:1px solid var(--border-color);margin-bottom:8px;padding-bottom:8px}.time-display{font-size:2rem;font-weight:700;margin:10px 0;text-align:center}.poll-options{flex-grow:1;margin-bottom:8px}.poll-option{border-radius:4px;gap:3px;margin-bottom:4px;padding:0}.poll-option:last-child{margin-bottom:0}.option-label{font-weight:700;margin-bottom:5px}.option-label-button{border:none;border-radius:4px;cursor:pointer;flex-shrink:0;font-weight:700;margin-bottom:0;min-width:200px;padding:5px 10px;text-align:center;transition:background-color .3s;width:200px}.option-label-button:disabled{cursor:not-allowed}.option-bar-container{align-items:center;border-radius:4px;display:flex;flex-basis:100px;flex-grow:1;height:25px;min-width:120px;overflow:hidden;position:relative}.option-bar{background-color:var(--primary);height:100%;transition:width .5s ease}.vote-counts{color:var(--text-color);font-weight:700;left:50%;position:absolute;text-shadow:0 0 2px #fff;transform:translateX(-50%);z-index:2}.poll-controls{border-top:1px solid var(--border-color);display:flex;justify-content:space-between;padding-top:8px}.poll-controls button{border:none;border-radius:4px;cursor:pointer;font-weight:700;padding:10px 15px;transition:background-color .3s,opacity .3s}.poll-controls button:disabled{cursor:not-allowed;opacity:.5}.end-poll-btn,.send-poll-btn,.show-messages-btn{color:#fff}.poll-controls button:hover:not(:disabled){opacity:.9}.user-info-section{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 5px var(--shadow);grid-column:1/-1!important;grid-row:2;padding:10px}.total-users,.user-info-section{display:flex;flex-direction:column}.total-users{border-bottom:1px solid var(--border-color);margin-bottom:8px;padding-bottom:8px}.view-categories-btn{align-self:flex-start;background-color:#7f8c8d;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:5px;padding:5px 10px}.user-categories{background-color:#f9f9f9;border-radius:4px;margin-top:10px;padding:10px}.user-categories ul{list-style-type:none;margin:0;padding:0}.user-categories li{border-bottom:1px solid var(--border-color);padding:5px 0}.user-list{flex-grow:1;overflow-y:auto}.user-table{border-collapse:collapse;width:100%}.user-table td,.user-table th{border-bottom:1px solid var(--border-color);height:60px;padding:8px;text-align:center!important;vertical-align:middle}.user-table th{background-color:var(--bg-alt);font-weight:700}.user-table td:first-child{align-items:center;display:flex;gap:6px;justify-content:flex-start}.user-table td:first-child .username{text-align:left}.user-table td:nth-child(5)>button{margin:0 3px}.btn-small{font-size:.8rem;min-width:50px;padding:4px 8px}.message-indicator{color:#e74c3c;font-size:1.2rem}.selection-staphylococcus{background-color:#3498db33}.selection-streptococcus{background-color:#e74c3c33}.selection-enterococcus{background-color:#2ecc7133}.selection-actinomyces{background-color:#f1c40f33}.encounter-preview-section{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 5px var(--shadow);flex-direction:column;grid-column:2;grid-row:1;padding:6px}.encounter-preview{background-color:#f9f9f9;border-radius:4px;flex-grow:1;padding:10px}.encounter-preview h4{border-bottom:1px solid var(--border-color);color:#2c3e50;margin-top:0;padding-bottom:10px}.preview-images{display:flex;flex-wrap:wrap;height:200px;justify-content:center;margin-top:10px;overflow:hidden;position:relative}.preview-backdrop{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.preview-character{height:100%;margin:0 10px;position:relative;z-index:2}.preview-backdrop img,.preview-character img{height:100%;object-fit:contain;width:auto}.story-tree-section{background-color:var(--bg-card);border-radius:8px;box-shadow:0 2px 5px var(--shadow);display:flex;flex-direction:column;grid-column:1/3;grid-row:3;padding:10px}.story-tree{flex-grow:1;overflow-y:auto}.tree-list{list-style-type:none;padding:0}.tree-list li{background-color:#f9f9f9;border-radius:4px;cursor:pointer;margin-bottom:5px;padding:8px 10px;transition:background-color .3s}.tree-list li:hover{background-color:#eee}.tree-list .active-node{background-color:var(--primary);color:#fff}.poll-toggle-btn{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;padding:10px 20px;transition:background-color .3s ease}.poll-toggle-btn.send-poll{background-color:#4caf50;color:#fff}.poll-toggle-btn.end-poll{background-color:#f44336;color:#fff}.poll-toggle-btn:disabled{background-color:#ccc;color:#666;cursor:not-allowed}.total-votes{color:var(--text-color);margin-bottom:10px}@media (max-width:1024px){.panel-content{grid-template-columns:1fr;grid-template-rows:auto auto auto}.poll-info-section{grid-column:1;grid-row:1}.encounter-preview-section{grid-column:1;grid-row:2}.user-info-section{grid-column:1;grid-row:3}.scenario-selector{align-items:flex-start;flex-direction:column;margin:10px 0}.scenario-selector label{margin-bottom:5px}.panel-header{align-items:stretch;flex-direction:column}.panel-header h1{margin-bottom:10px}.open-display-btn{align-self:center;margin-top:10px}}.educator-panel .debug-panel{background-color:#000000e6;border:1px solid #0f0;border-radius:4px;color:#0f0;font-family:monospace;font-size:12px;left:10px;max-height:90vh;overflow-y:auto;padding:10px;position:fixed;top:10px;width:300px;z-index:1000}.educator-panel .debug-panel h3,.educator-panel .debug-panel h4{color:#0f0;margin:5px 0;text-align:center}.educator-panel .debug-panel p{margin:3px 0}.educator-panel .debug-controls{display:flex;flex-direction:column;gap:5px;margin-top:10px}.educator-panel .debug-controls button{background-color:#333;border:1px solid #0f0;color:#fff;cursor:pointer;font-family:monospace;padding:5px}.educator-panel .debug-controls button:hover{background-color:#444}.educator-panel .error-toast{align-items:center;background-color:#f00c;border-radius:5px;box-shadow:0 2px 10px #00000080;color:#fff;display:flex;flex-direction:column;font-family:monospace;left:50%;max-width:80%;padding:10px 20px;position:fixed;text-align:center;top:20px;transform:translateX(-50%);z-index:1000}.educator-panel .error-toast p{margin:0 0 10px}.educator-panel .error-toast button{background-color:#333;border:1px solid #fff;border-radius:3px;color:#fff;cursor:pointer;font-family:monospace;padding:5px 15px}.connection-status{animation:fadeIn .3s ease-in-out;border-radius:4px;box-shadow:0 2px 6px #0003;font-size:14px;left:50%;padding:8px 15px;position:fixed;text-align:center;top:10px;transform:translateX(-50%);z-index:1000}.connection-status.loading{background-color:#3498dbcc;color:#fff}.connection-status.error{background-color:#e74c3ccc;color:#fff}.connection-status.disconnected{background-color:#f1c40fcc;color:#333}@keyframes fadeIn{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.game-id-display{background-color:#0000001a;border-radius:3px;color:#666;font-size:12px;margin-bottom:10px;padding:3px 8px}.educator-panel .visual-breadcrumb-trail{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 5px var(--shadow);display:flex;justify-content:center;margin:0;overflow-x:auto;padding:1rem 0}.educator-panel .breadcrumb-circle{align-items:center;background-color:#95a5a6;border:2px solid #0000;border-radius:50%;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex:0 0 20px;flex-shrink:0;font-size:.7rem;font-weight:700;height:20px;justify-content:center;position:relative;transition:background-color .3s ease,box-shadow .3s ease,transform .2s ease,opacity .3s ease,background-image .3s ease;width:20px;will-change:background-color,box-shadow,transform,opacity}.educator-panel .breadcrumb-circle:hover:not(:disabled){box-shadow:0 2px 5px #0003;transform:scale(1.1)}.educator-panel .breadcrumb-circle.future{background-color:#95a5a6;box-shadow:none;cursor:not-allowed;opacity:.7}.educator-panel .breadcrumb-circle.unreachable{background-color:#95a5a6;background-image:repeating-linear-gradient(45deg,#0000,#0000 5px,#0000004d 0,#0000004d 10px);box-shadow:none;cursor:not-allowed;opacity:.8;position:relative}.educator-panel .breadcrumb-circle.visited{background-color:#27ae60;box-shadow:none}.educator-panel .breadcrumb-circle.active{background-color:#f1c40f;border-color:#0000;box-shadow:0 0 0 3px #f1c40f80;opacity:1}.educator-panel .breadcrumb-circle:disabled{cursor:not-allowed}.breadcrumb-arrow{align-items:center;color:#7f8c8d;display:flex;flex-shrink:0;margin:0 4px}.breadcrumb-arrow svg{height:12px;width:12px}@media (max-width:768px){.educator-panel,.educator-panel .visual-breadcrumb-trail{box-sizing:border-box!important;max-width:100%!important;overflow-x:hidden!important;width:100%!important}.educator-panel .visual-breadcrumb-trail{flex-wrap:wrap!important;height:auto!important;justify-content:center!important;padding:5px!important}.educator-panel .breadcrumb-circle{box-sizing:border-box!important;font-size:.8rem!important;height:30px!important;min-height:30px!important;min-width:30px!important;width:30px!important}.educator-panel .breadcrumb-arrow{margin:0 3px!important}.educator-panel .breadcrumb-arrow svg{height:16px!important;width:16px!important}.encounter-preview-section,.panel-content,.poll-info-section,.story-tree-section,.user-info-section{box-sizing:border-box!important;max-width:100%!important;overflow-x:hidden!important;padding:10px!important;width:100%!important}.user-table{box-sizing:border-box!important;display:block!important;max-width:100%!important;overflow-x:auto!important;width:100%!important}.scenario-controls{gap:.75rem!important}.scenario-controls,.scenario-selector{flex-direction:column!important;width:100%!important}.scenario-selector{box-sizing:border-box!important;margin:0 0 10px!important;max-width:100%!important}.scenario-selector label{display:block!important;margin-bottom:5px!important;width:100%!important}.scenario-selector select{box-sizing:border-box!important;max-width:100%!important;min-width:0!important;width:100%!important}.open-display-btn,.poll-controls button,.scenario-controls button{box-sizing:border-box!important;margin:5px 0!important;width:100%!important}.poll-option{box-sizing:border-box!important;flex-direction:column!important;margin-bottom:10px!important;padding:10px!important;width:100%!important}.option-label-button{margin-bottom:5px!important}.option-bar-container,.option-label-button{box-sizing:border-box!important;min-width:0!important;width:100%!important}.message-bubble-wrapper{align-items:center!important;display:flex!important;justify-content:center!important}.badge-modal{box-sizing:border-box!important;max-width:90vw!important;padding:15px!important;width:90%!important}.badge-grid{gap:8px!important;grid-template-columns:repeat(auto-fill,minmax(80px,1fr))!important}.poll-option-row{align-items:stretch!important;flex-direction:column!important;width:100%!important}.poll-option-row .poll-route-button{margin-bottom:6px!important;max-width:100%!important;width:100%!important}.poll-option-row .option-bar-container{flex-basis:20px!important;flex-grow:0!important;flex-shrink:0!important;justify-content:flex-start!important;width:100%!important}.poll-option-row .option-bar-container .option-bar{flex-basis:auto!important}.poll-option-row .option-bar-container .vote-counts{line-height:1!important}}.educator-panel .encounter-preview-section,.educator-panel .poll-info-section,.educator-panel .story-tree-section,.educator-panel .user-info-section,.educator-panel select{background-color:var(--bg-card);border:1px solid var(--border-color);box-shadow:0 2px 5px var(--shadow);color:var(--text-color)}.scenario-selector select{background-color:var(--bg-card);border:1px solid var(--border-color);box-shadow:0 1px 3px var(--shadow);color:var(--text-color)}.scenario-selector select:focus{outline:2px solid var(--primary)}.poll-option{background-color:var(--bg-card);border:1px solid var(--border-color)}.option-bar-container{background-color:var(--bg-alt)}.open-display-btn{background-color:var(--accent);color:var(--button-text)}.open-display-btn:hover{filter:brightness(90%)}.option-label-button{background-color:var(--primary);color:var(--button-text)}.option-label-button:hover:not(:disabled){filter:brightness(90%)}.option-label-button:disabled{background-color:var(--border-color);color:var(--text-secondary)}.send-poll-btn{background-color:var(--success)}.end-poll-btn{background-color:var(--error)}.show-messages-btn{background-color:var(--primary)}.time-display{color:var(--error)}.total-votes,.vote-counts{color:var(--text-color)}.option-bar-container,.poll-time,.total-users,.tree-list .active-node,.tree-list li,.tree-list li:hover,.user-categories li,.user-table td,.user-table th{border-color:var(--border-color)}.poll-route-button{max-width:100%;padding:5px 8px;text-align:center;white-space:normal;width:180px}.guest-user{color:var(--text-secondary);font-style:italic}.guest-label{background-color:var(--border-color);border-radius:4px;color:var(--text-color);font-size:.75rem;padding:1px 4px;vertical-align:middle}.message-bubble-icon{cursor:pointer;height:50px;transition:transform .15s ease-in-out;width:50px}.message-bubble-icon:hover{transform:scale(1.1)}.message-bubble-wrapper{cursor:pointer;display:inline-block;position:relative}.message-bubble-wrapper .unread-badge{align-items:center;background-color:red;border-radius:50%;color:#fff;display:flex;font-size:11px;font-weight:700;height:18px;justify-content:center;line-height:18px;pointer-events:none;position:absolute;right:-2px;top:-2px;width:18px}.modal-overlay{background:#0009;height:100%;width:100%;z-index:2000}.badge-modal{background:#fff;background:var(--bg-card,#fff);border-radius:8px;box-shadow:0 4px 12px #0000004d;color:var(--text-color);max-height:80vh;max-width:600px;overflow-y:auto;padding:20px}.badge-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:15px}.badge-modal .badge-item{align-items:center;cursor:pointer;display:flex;flex-direction:column;transition:transform .2s ease}.badge-modal .badge-item:hover{transform:scale(1.05)}.badge-modal img{border-radius:4px;height:80px;margin-bottom:6px;object-fit:cover;width:80px}.badge-modal span{font-size:.85rem;text-align:center}.message-cell-wrapper{align-items:center;display:inline-flex;padding-right:12px!important;position:relative}.message-cell-wrapper .fa-comment{color:#3498db;color:var(--primary,#3498db);font-size:1.8rem}.unread-message-count{align-items:center;background-color:#e74c3c;border:1px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:700;height:20px;justify-content:center;line-height:20px;position:absolute;right:15px;top:0;width:20px}.chat-icon-small{height:38px;width:38px}.message-bubble-btn{align-items:center;background:none;border:none;cursor:pointer;display:inline-flex;justify-content:center;padding:0}.message-bubble-btn:hover{transform:scale(1.1)}.mobile-profile-dropdown{width:100%}.mobile-profile-dropdown .main-tab{align-items:center;background:none;border:none;border-bottom:1px solid #ffffff1a;border-radius:0;color:#fff;cursor:pointer;display:flex;font-size:1rem;justify-content:space-between;padding:1rem;text-align:left;width:100%}.mobile-profile-dropdown .dropdown-content{background-color:#0003;border:none;border-radius:0;box-shadow:none;position:relative;width:100%}.mobile-profile-dropdown .dropdown-item{border-bottom:1px solid #ffffff1a;color:#fff;display:block;font-size:.9rem;padding:1rem 2rem;text-decoration:none;width:100%}.mobile-profile-dropdown .dropdown-header{align-items:center;background-color:#0000004d;border-bottom:1px solid #ffffff1a;color:#ffffffb3;display:flex;font-size:.9rem;padding:.75rem 1rem}.hamburger-btn{background:none;border:none;cursor:pointer;display:none;flex-direction:column;height:22px;justify-content:space-between;padding:0;width:28px;z-index:101}.hamburger-btn .bar{background-color:#fff;display:block;height:3px;transition:all .3s ease;width:100%}.hamburger-btn.open .bar:first-child{transform:translateY(9px) rotate(45deg)}.hamburger-btn.open .bar:nth-child(2){opacity:0}.hamburger-btn.open .bar:nth-child(3){transform:translateY(-9px) rotate(-45deg)}@media (max-width:768px){.hamburger-btn{display:flex}.mobile-nav-container{display:none;width:100%}.mobile-nav-container.open{background-color:initial;display:flex}.main-nav{align-items:flex-start;background-color:initial;padding:1rem 0}.main-nav,.main-tabs.mobile{flex-direction:column;gap:0;width:100%}.dropdown .main-tab,.main-tabs.mobile .dropdown .main-tab{align-items:center;background-color:initial;border-bottom:1px solid #ffffff1a;border-radius:0;color:#fff;display:flex;justify-content:space-between;padding:1rem;text-align:left;width:100%}.dropdown .dropdown-content.mobile,.main-tabs.mobile .dropdown-content.mobile{background-color:#fff;background-color:var(--bg-card,#fff);border:none;border-radius:0;box-shadow:none;max-width:none!important;position:relative;width:100%!important}.dropdown-content.mobile .dropdown-item,.dropdown-content.mobile a.dropdown-item,.dropdown-content.mobile button.dropdown-item{word-wrap:break-word!important;border-bottom:1px solid #eee;border-bottom:1px solid var(--border-color,#eee);color:#333!important;color:var(--text-color,#333)!important;display:block;font-weight:400;overflow-wrap:break-word!important;padding:1rem 2rem;text-decoration:none;transition:background-color .2s ease;white-space:normal!important;width:100%!important}.dropdown-content.mobile .dropdown-item:hover,.dropdown-content.mobile a.dropdown-item:hover,.dropdown-content.mobile button.dropdown-item:hover{background-color:#f5f5f5;background-color:var(--hover-bg,#f5f5f5);color:#333!important;color:var(--text-color,#333)!important}.dropdown-content.mobile .dropdown-header{word-wrap:break-word!important;background-color:#f5f5f5;background-color:var(--bg-alt,#f5f5f5);border-bottom:1px solid #eee;border-bottom:1px solid var(--border-color,#eee);color:#666;color:var(--text-secondary,#666);font-size:.9rem;overflow-wrap:break-word!important;padding:.5rem 1rem;white-space:normal!important;width:100%!important}.mobile-auth-buttons{padding:1rem 0;width:100%}.mobile-login-button{background:none;background-color:initial;border:none;border-bottom:1px solid #ffffff1a;border-radius:0;color:#fff;cursor:pointer;font-size:1rem;padding:1rem;text-align:left;width:100%}.mobile-login-button:hover{background-color:#ffffff1a}}@media (min-width:769px){.hamburger-btn{display:none}.dropdown-content{max-width:350px!important;min-width:220px!important;overflow:visible!important;width:max-content!important}}.encounter-preview-section{align-items:center;background:#f9f9f9;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;display:flex;justify-content:center;max-height:45vh;min-height:250px;overflow:hidden;padding:10px;width:100%}.preview-message{color:#777;font-size:1.1rem;font-weight:500;line-height:1.4;margin:0 auto;max-width:350px;padding:20px}.preview-content-wrapper{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.preview-scaled-content{display:block;height:100%;max-height:100%;max-width:100%;opacity:0;position:relative!important;transition:opacity .4s ease-out;width:100%}.preview-scaled-content .encounter-backdrop,.preview-scaled-content .encounter-character,.preview-scaled-content .encounter-content{max-height:100%!important;max-width:100%!important;object-fit:contain}.preview-scaled-content .encounter-title{font-size:clamp(.8rem,3vw,1.5rem)}.preview-scaled-content .encounter-description{font-size:clamp(.7rem,2.5vw,1rem)}@keyframes fadeInAndScale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.preview-content-fade-in{animation:fadeInAndScale .4s ease-out forwards}@media (max-width:768px){.question-bank-editor{flex-direction:column!important;height:auto!important}.qbe-sidebar{border-bottom:1px solid var(--border-color)!important;border-right:none!important;box-sizing:border-box!important;max-height:300px!important;padding:15px!important;width:100%!important}.question-list{list-style:none!important;margin:0!important;padding:0!important;width:100%!important}.question-list li{font-size:.9rem!important;margin-bottom:6px!important;padding:6px 8px!important}.qbe-main,.question-list li{box-sizing:border-box!important;width:100%!important}.qbe-main{padding:15px!important}.question-editor{width:100%!important}.option-main,.option-row.option-header{gap:6px!important;grid-template-columns:40px 1fr 60px!important}.option-main .delete-btn{font-size:.9rem!important;padding:4px!important}.option-input,.option-rationale-input,.question-editor textarea{box-sizing:border-box!important;font-size:16px!important;padding:8px!important;width:100%!important}.qbe-sidebar .create-btn{box-sizing:border-box!important;font-size:.9rem!important;padding:8px!important;width:100%!important}.tags-grid{display:flex!important;flex-wrap:wrap!important;gap:6px!important}.tag-item{font-size:.85rem!important;padding:4px 8px!important}.tag-item input{height:0;opacity:0;pointer-events:none;position:absolute;width:0}.question-editor .form-group label{font-weight:600!important;margin-bottom:6px!important}.tag-filter{box-sizing:border-box!important;margin-bottom:12px!important}.tag-filter,.tag-filter>div{width:100%!important}}.question-practice-container{box-sizing:border-box;display:flex;flex-direction:column;height:100%;padding:16px;width:100%}.qp-layout{display:flex;flex:1 1;gap:24px;margin:0 auto;max-width:1200px;width:100%}.qp-sidebar{background:#f7f7f7;background:var(--sidebar-bg,#f7f7f7);border-radius:8px;box-shadow:0 2px 4px #0000000d;min-width:200px;overflow-y:auto;padding:16px;width:260px}.qp-sidebar h3{font-size:1.1rem;margin-top:0}.qp-question-list{list-style:none;margin:0;padding:0}.qp-question-list li+li{margin-top:8px}.qp-question-list button{background:#0000;border:none;border-radius:4px;cursor:pointer;font-size:.95rem;padding:8px 10px;text-align:left;transition:background .2s;width:100%}.qp-question-list button:hover,.qp-question-list li.active button{background:#e6e6e6;background:var(--sidebar-active-bg,#e6e6e6)}.qp-main{background:#fff;background:var(--main-bg,#fff);border-radius:8px;box-shadow:0 2px 4px #0000000d;flex:1 1;overflow-y:auto;padding:24px}.qp-placeholder{color:#666;font-size:1rem}.qp-question-text{font-size:1.2rem;font-weight:600;margin:0 0 16px}.qp-options{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.qp-option-label{align-items:center;display:flex;font-size:1rem;gap:8px}.qp-submit-btn{background:#1976d2;background:var(--primary,#1976d2);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background .2s}.qp-submit-btn:disabled{cursor:not-allowed;opacity:.6}.qp-submit-btn:not(:disabled):hover{background:#11529b}.qp-result{font-size:1.1rem;font-weight:600;margin-top:16px}.qp-result.correct{color:#2e7d32}.qp-result.incorrect{color:#c62828}@media (max-width:768px){.qp-layout{flex-direction:column}.qp-sidebar{order:2;width:100%}.qp-main{order:1}}.qp-next-btn{background:#455a64;background:var(--secondary,#455a64);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin-top:16px;padding:10px 20px;transition:background .2s}.qp-next-btn:hover{background:#2c3e50}.qp-complete-msg{color:#2e7d32;font-size:1.1rem;font-weight:600;margin-top:16px}.qp-restart-btn{background:#1976d2;background:var(--primary,#1976d2);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin-top:12px;padding:10px 20px;transition:background .2s}.qp-restart-btn:hover{background:#11529b}.qp-complete-section{align-items:flex-start;display:flex;flex-direction:column}.date-filter-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:12px}.date-filter-btn{background:#0000;border:1px solid #1976d2;border:1px solid var(--primary,#1976d2);border-radius:4px;color:#1976d2;color:var(--primary,#1976d2);cursor:pointer;font-size:.9rem;padding:6px 12px;transition:background .2s,color .2s}.date-filter-btn.active,.date-filter-btn:hover{background:#1976d2;background:var(--primary,#1976d2);color:#fff}.custom-date-range{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1rem}.custom-date-range label{color:#555;display:flex;flex-direction:column;font-size:.8rem;font-weight:500}.custom-date-range input[type=date]{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#374151;font-size:.9rem;margin-top:4px;padding:8px 12px;position:relative;transition:border-color .2s,box-shadow .2s}.custom-date-range input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(32%) sepia(41%) saturate(1808%) hue-rotate(196deg) brightness(92%) contrast(101%)}.custom-date-range input[type=date]:hover{border-color:#a5b4cf}.custom-date-range input[type=date]:focus{border-color:#1976d2;border-color:var(--primary,#1976d2);box-shadow:0 0 0 2px #1976d233;outline:none}.date-picker-group{align-items:center;display:flex;flex-direction:column}.date-picker-group span{color:#555;font-size:.8rem;font-weight:500;margin-bottom:4px}.date-picker-input{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#374151;font-size:.9rem;padding:8px 12px;transition:border-color .2s,box-shadow .2s}.date-picker-input:hover{border-color:#a5b4cf}.date-picker-input:focus{border-color:#1976d2;border-color:var(--primary,#1976d2);box-shadow:0 0 0 2px #1976d233;outline:none}.react-datepicker{border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000014;font-family:sans-serif;font-family:var(--font-primary,sans-serif)}.react-datepicker__header{background-color:#1976d2;background-color:var(--primary,#1976d2);border-bottom:none;padding-top:8px}.react-datepicker__current-month,.react-datepicker__day-name{color:#fff;font-weight:500}.react-datepicker__day--keyboard-selected,.react-datepicker__day--selected{background-color:#1976d2!important;background-color:var(--primary,#1976d2)!important;color:#fff!important}.react-datepicker__navigation--next,.react-datepicker__navigation--previous{top:12px}.react-datepicker__navigation-icon:before{border-color:#fff}.qp-report-table{border-collapse:collapse;margin:1rem auto;width:auto}.qp-report-table td,.qp-report-table th{border:1px solid #e0e0e0;font-size:.9rem;padding:8px 12px;text-align:center;white-space:nowrap}.qp-report-table td:first-child{text-align:left}.qp-report-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.qp-report-table th.sortable:hover{background-color:#f5f5f5}.qp-report-table thead th{background-color:#f0f4ff;font-weight:600}.qp-report-table thead tr:first-child th{border-bottom:2px solid #c0d0ff}.lecture-manager-container{box-sizing:border-box;font-size:var(--font-size-base);margin:0 auto;max-width:900px;overflow-x:hidden;padding:var(--space-4);width:100%}.lecture-actions-wrapper{margin-bottom:var(--space-6)}.add-lecture-btn{background-color:var(--primary);border:none;border-radius:var(--radius-md);color:var(--button-text);cursor:pointer;font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-4)}.add-lecture-btn:hover{background-color:var(--primary-dark)}.lecture-list{list-style:none;margin:var(--space-4) 0;padding:0}.lecture-item,.lecture-list{box-sizing:border-box;width:100%}.lecture-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;padding:var(--space-3)}.lecture-item:hover{background-color:var(--bg-alt)}.lecture-item.pending{background-color:#ffefd9}.lecture-item.pending:hover{background-color:#ffe4c2}.lecture-item.draft{background-color:#fff9d6}.lecture-item.draft:hover{background-color:#fff4b8}.lecture-actions{display:flex;gap:var(--space-2);margin-right:var(--space-3)}.lecture-title{flex:1 1;font-weight:var(--font-weight-medium)}@media (max-width:768px){.lecture-manager-container{padding:1rem!important}.lecture-list,.lecture-manager-container{overflow-x:hidden!important}.lecture-item,.lecture-list,.lecture-manager-container{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.lecture-item{align-items:flex-start!important;flex-direction:column!important;gap:.75rem!important;padding:1rem!important}.lecture-info{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.lecture-action,.lecture-actions{flex-direction:column!important;gap:.5rem!important;margin-right:0!important;max-width:100%!important;width:100%!important}.add-lecture-btn,.lecture-action .btn,.lecture-link-btn{box-sizing:border-box!important;margin:.25rem 0!important;text-align:center!important;width:100%!important}.lecture-title{width:100%!important}}.lecture-editor-container{background-color:#fff;background-color:var(--bg-light-card,#fff);border-radius:8px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;margin:0 auto;max-width:1200px;overflow-x:hidden;padding:20px;width:100%}[data-theme=dark] .lecture-editor-container{background-color:#1e1e1e;background-color:var(--bg-dark-card,#1e1e1e);color:#fff;color:var(--text-dark,#fff)}.lecture-editor-header{align-items:center;border-bottom:1px solid #ddd;border-bottom:1px solid var(--border-light,#ddd);box-sizing:border-box;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:10px;width:100%}[data-theme=dark] .lecture-editor-header{border-bottom-color:#444;border-bottom-color:var(--border-dark,#444)}.lecture-editor-header h2{font-size:1.5rem;margin:0}.back-btn{background:#1976d2;background:var(--primary-light,#1976d2);border-radius:4px;color:#fff;color:var(--button-text-light,#fff);font-size:.9rem;padding:8px 16px}.back-btn:hover{background:#1565c0;background:var(--primary-light-hover,#1565c0);opacity:.9}[data-theme=dark] .back-btn{background:#1565c0;background:var(--primary-dark,#1565c0);color:#fff;color:var(--button-text-dark,#fff)}[data-theme=dark] .back-btn:hover{background:#0d47a1;background:var(--primary-dark-hover,#0d47a1)}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.cancel-btn{background:#0000;border:1px solid #ddd;border:1px solid var(--border-light,#ddd);border-radius:4px;color:#666;color:var(--text-light-secondary,#666);cursor:pointer;font-size:.9rem;padding:10px 18px}.cancel-btn:hover{background:#f5f5f5;background:var(--hover-light,#f5f5f5)}[data-theme=dark] .cancel-btn{border-color:#444;border-color:var(--border-dark,#444);color:#aaa;color:var(--text-dark-secondary,#aaa)}[data-theme=dark] .cancel-btn:hover{background:#2a2a2a;background:var(--hover-dark,#2a2a2a)}.save-btn{background:var(--primary-light,#1976d2);color:var(--button-text-light,#fff);font-size:.9rem;padding:10px 18px}.save-btn:hover{background:#1565c0;background:var(--primary-light-hover,#1565c0);opacity:.9}.save-btn:disabled{cursor:not-allowed;opacity:.5}[data-theme=dark] .save-btn{background:#1565c0;background:var(--primary-dark,#1565c0);color:#fff;color:var(--button-text-dark,#fff)}[data-theme=dark] .save-btn:hover{background:#0d47a1;background:var(--primary-dark-hover,#0d47a1)}.question-bank-section{border-radius:8px;display:flex;flex-direction:column;margin-top:30px;min-height:300px;padding:0 10px}.lecture-edit-form,.lecture-edit-form label,.question-bank-section{box-sizing:border-box;width:100%}.lecture-edit-form label{display:flex;flex-direction:column;margin-bottom:12px}.lecture-edit-form input[type=text],.lecture-edit-form input[type=url],.lecture-edit-form textarea{background-color:#fff;background-color:var(--input-bg-light,#fff);border:1px solid #ccc;border:1px solid var(--border-light,#ccc);border-radius:4px;box-sizing:border-box;color:#000;color:var(--text-light,#000);font-size:1rem;padding:8px;width:100%}[data-theme=dark] .lecture-edit-form input[type=text],[data-theme=dark] .lecture-edit-form input[type=url],[data-theme=dark] .lecture-edit-form textarea{background-color:#2a2a2a;background-color:var(--input-bg-dark,#2a2a2a);border-color:#444;border-color:var(--border-dark,#444);color:#fff;color:var(--text-dark,#fff)}.or-divider{color:#666;color:var(--text-light-secondary,#666);margin:16px 0;text-align:center}[data-theme=dark] .or-divider{color:#aaa;color:var(--text-dark-secondary,#aaa)}.pill-switch{border:1px solid #ccc;border:1px solid var(--border-color,#ccc);border-radius:20px;display:inline-flex;margin-bottom:1rem;overflow:hidden}.pill-switch .pill{background:#f6f6f6;background:var(--bg,#f6f6f6);color:#333;color:var(--text,#333);cursor:pointer;padding:6px 14px;transition:background .2s;-webkit-user-select:none;user-select:none}.pill-switch .pill+.pill{border-left:1px solid #ccc;border-left:1px solid var(--border-color,#ccc)}.pill-switch .pill.active{background:#007bff;background:var(--primary,#007bff);color:#fff}@media (max-width:768px){.lecture-editor-container{box-sizing:border-box!important;max-width:100%!important;overflow-x:hidden!important;padding:15px!important;width:100%!important}.lecture-editor-header{align-items:flex-start!important;flex-direction:column!important;gap:10px!important;width:100%!important}.lecture-edit-form,.lecture-edit-form input[type=file],.lecture-edit-form input[type=text],.lecture-edit-form input[type=url],.lecture-edit-form label,.lecture-edit-form textarea{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.form-actions{flex-direction:column!important;gap:10px!important;width:100%!important}.form-actions button{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.pill-switch{display:flex!important;justify-content:center!important;width:100%!important}.pill-switch .pill{flex:1 1!important;text-align:center!important}}.student-lecture-list-container{box-sizing:border-box;margin:0 auto;max-width:900px;overflow-x:hidden;padding:var(--space-4);width:100%}.student-lecture-list{box-sizing:border-box;list-style:none;margin:var(--space-4) 0;padding:0;width:100%}.student-lecture-item{align-items:center;border-bottom:1px solid var(--border-color);box-sizing:border-box;display:flex;justify-content:space-between;padding:var(--space-3);width:100%}.lecture-info{flex:1 1}.lecture-meta{align-items:center;display:flex;margin:0 var(--space-3);min-width:160px}.lecture-desc{color:var(--text-muted);margin:var(--space-1) 0}.lecture-release-date,.received-date{color:var(--text-muted);font-size:.85rem}.lecture-action .btn{white-space:nowrap}.lecture-action{align-items:center;display:flex}.student-explanation{max-width:800px}@media (max-width:768px){.student-lecture-list-container{padding:1rem!important}.student-lecture-list,.student-lecture-list-container{overflow-x:hidden!important}.student-lecture-item,.student-lecture-list,.student-lecture-list-container{box-sizing:border-box!important;max-width:100%!important;width:100%!important}.student-lecture-item{align-items:flex-start!important;flex-direction:column!important;gap:.75rem!important;padding:1rem!important}.lecture-info{box-sizing:border-box!important}.lecture-info,.lecture-meta{max-width:100%!important;width:100%!important}.lecture-meta{margin:0!important;min-width:0!important}.lecture-action{flex-direction:column!important;gap:.5rem!important;max-width:100%!important;width:100%!important}.lecture-action .btn,.lecture-link-btn{box-sizing:border-box!important;text-align:center!important;width:100%!important}}.journal-list-container{box-sizing:border-box;margin:0 auto;max-width:900px;overflow-x:hidden;padding:1rem;width:100%}.journal-list{list-style:none;padding:0}.journal-list,.journal-list li{box-sizing:border-box;width:100%}.journal-list li{margin-bottom:8px}.journal-list button{background:#fff;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;cursor:pointer;padding:10px 12px;text-align:left;width:100%}.journal-list li.completed button{background:#e8f5e9;border-color:#c8e6c9}.status{color:#2e7d32;float:right;font-size:.9rem}.journal-writer-container{box-sizing:border-box;margin:0 auto;max-width:800px;overflow-x:hidden;padding:1rem;width:100%}.back-btn{background:none;border:none;color:#1976d2;cursor:pointer;margin-bottom:12px}.prompt-text{font-style:italic;margin-bottom:12px}.prompt-text,.response-textarea{box-sizing:border-box;width:100%}.response-textarea{border:1px solid #ccc;border-radius:4px;padding:10px;resize:vertical}.char-counter{font-size:.9rem;margin-top:4px}.save-btn{background:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:12px;padding:10px 20px}.save-msg{color:#2e7d32;margin-left:12px}.student-explanation{box-sizing:border-box;color:#666;color:var(--text-muted,#666);font-size:.95rem;line-height:1.5;margin-bottom:15px;width:100%}@media (max-width:768px){.journal-list-container{max-width:100%!important;overflow-x:hidden!important;padding:1rem!important}.journal-list,.journal-list li,.journal-list-container{box-sizing:border-box!important;width:100%!important}.journal-list button{align-items:flex-start!important;display:flex!important;flex-direction:column!important;padding:1rem!important}.status{float:none!important;margin-top:.5rem!important;text-align:left!important;width:100%!important}.journal-writer-container{max-width:100%!important;overflow-x:hidden!important;padding:1rem!important}.journal-writer-container,.prompt-text{box-sizing:border-box!important;width:100%!important}.prompt-text{padding:.5rem!important}.response-textarea{min-height:150px!important}.response-textarea,.save-btn{box-sizing:border-box!important;width:100%!important}.save-btn{margin-bottom:1rem!important}.save-msg{display:block!important;margin:.5rem 0!important;text-align:center!important}}.journal-mgr-container{box-sizing:border-box;margin:0 auto;max-width:1200px;overflow-x:hidden;padding:1rem;width:100%}.add-btn{background-color:#1976d2;background-color:var(--primary,#1976d2);border:none;border-radius:4px;color:#fff;color:var(--button-text,#fff);cursor:pointer;margin-bottom:8px;padding:6px 12px}.prompt-table{border-collapse:collapse;box-sizing:border-box;width:100%}.prompt-table td,.prompt-table th{border:1px solid #ddd;box-sizing:border-box;padding:8px}.prompt-table th{background:#f5f5f5}.prompt-table button{border:none;border-radius:4px;cursor:pointer;margin-right:4px;padding:4px 8px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:999}.modal-panel{background:#fff;border-radius:8px;box-sizing:border-box;max-width:600px;padding:20px;position:relative;width:90%}.modal-panel label{box-sizing:border-box;display:block;margin-bottom:12px;width:100%}.modal-panel input[type=text],.modal-panel textarea{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;padding:8px;width:100%}.modal-actions{display:flex;gap:8px;justify-content:flex-end;text-align:right}.modal-actions button{margin-left:8px}.stats-table{border-collapse:collapse;box-sizing:border-box;margin:12px 0;width:100%}.stats-table td,.stats-table th{border:1px solid #ddd;box-sizing:border-box;padding:6px}.stats-table th{background:#f0f0f0}.btn-primary{background:#1976d2;color:#fff}.btn-primary:hover{background:#11529b}.btn-secondary{background:#607d8b}.btn-secondary:hover{background:#455a64}.btn-warning{background:#f9a825;color:#fff}.btn-warning:hover{background:#c17900}.btn-danger{background:#c62828;color:#fff}.btn-danger:hover{background:#8e0000}.close-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;position:absolute;right:8px;top:8px}.admin-explanation{color:#666;color:var(--text-muted,#666);line-height:1.5;margin-bottom:20px;max-width:800px}@media (max-width:768px){.journal-mgr-container{max-width:100%!important;overflow-x:hidden!important;padding:1rem!important}.add-btn,.journal-mgr-container{box-sizing:border-box!important;width:100%!important}.add-btn{margin-bottom:1rem!important}.prompt-table{box-sizing:border-box!important;display:block!important;overflow-x:auto!important;width:100%!important}.prompt-table tbody tr{border-bottom:2px solid #ddd!important;border-bottom:2px solid var(--border-color,#ddd)!important;display:flex!important;flex-direction:column!important;margin-bottom:1rem!important}.prompt-table thead{display:none!important}.prompt-table td{border:none!important;border-bottom:1px solid #eee!important;border-bottom:1px solid var(--border-color-light,#eee)!important;box-sizing:border-box!important;display:flex!important;padding:.5rem!important;text-align:left!important;width:100%!important}.prompt-table td:first-of-type:before{content:"ID: ";font-weight:700;margin-right:.5rem}.prompt-table td:nth-of-type(2):before{content:"Title: ";font-weight:700;margin-right:.5rem}.prompt-table td:nth-of-type(3):before{content:"Created: ";font-weight:700;margin-right:.5rem}.prompt-table td:nth-of-type(4):before{content:"Last Released: ";font-weight:700;margin-right:.5rem}.prompt-table td:nth-of-type(5){flex-direction:row!important;flex-wrap:wrap!important;gap:.5rem!important}.prompt-table td:last-child{border-bottom:none!important}.prompt-table td:nth-of-type(5) button{box-sizing:border-box!important;flex:1 1!important;margin:.25rem!important;min-width:calc(50% - .5rem)!important;text-align:center!important}.modal-panel{box-sizing:border-box!important;max-height:90vh!important;max-width:95%!important;overflow-y:auto!important;padding:1rem!important;width:95%!important}.modal-actions{flex-direction:column!important;gap:.5rem!important;width:100%!important}.modal-actions button{margin:0!important}.modal-actions button,.stats-table{box-sizing:border-box!important;width:100%!important}.stats-table{display:block!important;overflow-x:auto!important}.stats-table tbody tr{border-bottom:2px solid #ddd!important;border-bottom:2px solid var(--border-color,#ddd)!important;display:flex!important;flex-direction:column!important;margin-bottom:1rem!important}.stats-table thead{display:none!important}.stats-table td{border:none!important;border-bottom:1px solid #eee!important;border-bottom:1px solid var(--border-color-light,#eee)!important;box-sizing:border-box!important;display:flex!important;padding:.5rem!important;text-align:left!important;width:100%!important}.stats-table td:first-of-type:before{content:"User: ";font-weight:700;margin-right:.5rem}.stats-table td:nth-of-type(2):before{content:"Released: ";font-weight:700;margin-right:.5rem}.stats-table td:nth-of-type(3):before{content:"Characters: ";font-weight:700;margin-right:.5rem}.stats-table td:nth-of-type(4):before{content:"Submitted: ";font-weight:700;margin-right:.5rem}}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{margin-left:-4px;position:absolute;width:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border:8px solid #0000;box-sizing:initial;content:"";height:0;left:-8px;position:absolute;width:1px;z-index:-1}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-bottom-color:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{margin-top:-8px;top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#f0f0f0;border-top:none}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#aeaeae;top:-1px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{bottom:0;margin-bottom:-8px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-bottom:none;border-top-color:#fff}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after{bottom:0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-top-color:#aeaeae;bottom:-1px}.react-datepicker-wrapper{border:0;display:inline-block;padding:0}.react-datepicker{background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;color:#000;display:inline-block;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;position:relative}.react-datepicker--time-only .react-datepicker__triangle{left:35px}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__triangle{left:50px;position:absolute}.react-datepicker-popper{z-index:1}.react-datepicker-popper[data-placement^=bottom]{padding-top:10px}.react-datepicker-popper[data-placement=bottom-end] .react-datepicker__triangle,.react-datepicker-popper[data-placement=top-end] .react-datepicker__triangle{left:auto;right:50px}.react-datepicker-popper[data-placement^=top]{padding-bottom:10px}.react-datepicker-popper[data-placement^=right]{padding-left:8px}.react-datepicker-popper[data-placement^=right] .react-datepicker__triangle{left:auto;right:42px}.react-datepicker-popper[data-placement^=left]{padding-right:8px}.react-datepicker-popper[data-placement^=left] .react-datepicker__triangle{left:42px;right:auto}.react-datepicker__header{background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative;text-align:center}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__year-dropdown-container--select{display:inline-block;margin:0 15px}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#000;font-size:.944rem;font-weight:700;margin-top:0}.react-datepicker-time__header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__navigation{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;overflow:hidden;padding:0;position:absolute;text-align:center;text-indent:-999em;top:2px;width:32px;z-index:1}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{display:block;margin-left:auto;margin-right:auto;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{font-size:20px;position:relative;top:-1px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__input-time-container{clear:both;float:left;margin:5px 0 10px 15px;text-align:left;width:100%}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{display:inline-block;margin-left:5px}.react-datepicker__time-container{border-left:1px solid #aeaeae;float:right;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.3rem;display:inline;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.3rem;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{border-bottom-right-radius:.3rem;margin:0 auto;overflow-x:hidden;text-align:center;width:85px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:initial;height:calc(195px + .85rem);list-style:none;margin:0;overflow-y:scroll;padding-left:0;padding-right:0;width:100%}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background-color:#f0f0f0;cursor:pointer}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{background-color:initial;cursor:default}.react-datepicker__week-number{color:#ccc;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected,.react-datepicker__week-number--keyboard-selected):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__week-number--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__week-number--keyboard-selected{background-color:#2a87d0;border-radius:.3rem;color:#fff}.react-datepicker__week-number--keyboard-selected:hover{background-color:#1d5d90}.react-datepicker__day-names{margin-bottom:-8px;white-space:nowrap}.react-datepicker__week{white-space:nowrap}.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__time-name{color:#000;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:hover,.react-datepicker__month-text:hover,.react-datepicker__quarter-text:hover,.react-datepicker__year-text:hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{background-color:#3dcc4a;border-radius:.3rem;color:#fff}.react-datepicker__day--highlighted:hover,.react-datepicker__month-text--highlighted:hover,.react-datepicker__quarter-text--highlighted:hover,.react-datepicker__year-text--highlighted:hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{background-color:#ff6803;border-radius:.3rem;color:#fff;position:relative}.react-datepicker__day--holidays .holiday-overlay,.react-datepicker__month-text--holidays .holiday-overlay,.react-datepicker__quarter-text--holidays .holiday-overlay,.react-datepicker__year-text--holidays .holiday-overlay{background-color:#333;border-radius:4px;bottom:100%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__day--holidays:hover,.react-datepicker__month-text--holidays:hover,.react-datepicker__quarter-text--holidays:hover,.react-datepicker__year-text--holidays:hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .holiday-overlay,.react-datepicker__month-text--holidays:hover .holiday-overlay,.react-datepicker__quarter-text--holidays:hover .holiday-overlay,.react-datepicker__year-text--holidays:hover .holiday-overlay{opacity:1;visibility:visible}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__month-text--in-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--selected,.react-datepicker__quarter-text--in-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--selected,.react-datepicker__year-text--in-range,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__day--in-range:hover,.react-datepicker__day--in-selecting-range:hover,.react-datepicker__day--selected:hover,.react-datepicker__month-text--in-range:hover,.react-datepicker__month-text--in-selecting-range:hover,.react-datepicker__month-text--selected:hover,.react-datepicker__quarter-text--in-range:hover,.react-datepicker__quarter-text--in-selecting-range:hover,.react-datepicker__quarter-text--selected:hover,.react-datepicker__year-text--in-range:hover,.react-datepicker__year-text--in-selecting-range:hover,.react-datepicker__year-text--selected:hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{background-color:#bad9f1;border-radius:.3rem;color:#000}.react-datepicker__day--keyboard-selected:hover,.react-datepicker__month-text--keyboard-selected:hover,.react-datepicker__quarter-text--keyboard-selected:hover,.react-datepicker__year-text--keyboard-selected:hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{color:#ccc;cursor:default}.react-datepicker__day--disabled:hover,.react-datepicker__month-text--disabled:hover,.react-datepicker__quarter-text--disabled:hover,.react-datepicker__year-text--disabled:hover{background-color:initial}.react-datepicker__input-container{display:inline-block;position:relative;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{box-sizing:initial;padding:.5rem;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__month-read-view,.react-datepicker__month-year-read-view,.react-datepicker__year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover,.react-datepicker__year-read-view:hover{cursor:pointer}.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{right:-16px;top:0;transform:rotate(135deg)}.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown,.react-datepicker__year-dropdown{background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;left:25%;position:absolute;text-align:center;top:30px;width:50%;z-index:1}.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover,.react-datepicker__year-dropdown:hover{cursor:pointer}.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable,.react-datepicker__year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__month-option,.react-datepicker__month-year-option,.react-datepicker__year-option{display:block;line-height:20px;margin-left:auto;margin-right:auto;width:100%}.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type,.react-datepicker__year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type,.react-datepicker__year-option:last-of-type{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem;-webkit-user-select:none;user-select:none}.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover,.react-datepicker__year-option:hover{background-color:#ccc}.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected,.react-datepicker__year-option--selected{left:15px;position:absolute}.react-datepicker__close-icon{background-color:initial;border:0;cursor:pointer;display:table-cell;height:100%;outline:0;padding:0 6px 0 0;position:absolute;right:0;top:0;vertical-align:middle}.react-datepicker__close-icon:after{background-color:#216ba5;border-radius:50%;color:#fff;content:"×";cursor:pointer;display:table-cell;font-size:12px;height:16px;line-height:1;padding:2px;text-align:center;vertical-align:middle;width:16px}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{background-color:#ccc;cursor:default}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;clear:left;cursor:pointer;font-weight:700;padding:5px 0;text-align:center}.react-datepicker__portal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2147483647}.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:3rem;width:3rem}@media (max-height:550px),(max-width:400px){.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:2rem;width:2rem}}.react-datepicker__portal .react-datepicker-time__header,.react-datepicker__portal .react-datepicker__current-month{font-size:1.44rem}.react-datepicker__children-container{height:auto;margin:.4rem;padding-left:.2rem;padding-right:.2rem;width:13.8rem}.react-datepicker__aria-live{border:0;clip-path:circle(0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker__calendar-icon{height:1em;vertical-align:-.125em;width:1em}.site-health-container{font-family:sans-serif;padding:20px}.site-health-container h1{color:#333;margin-bottom:30px;text-align:center}.health-group{background-color:#f9f9f9;border:1px solid #eee;border-radius:8px;margin-bottom:30px;padding:15px}.health-group h2{border-bottom:1px solid #ddd;color:#555;margin-bottom:15px;margin-top:0;padding-bottom:10px}.health-group ul{list-style:none;padding:0}.health-status-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;padding:8px 0}.health-status-item:last-child{border-bottom:none}.health-indicator{border-radius:50%;flex-shrink:0;height:12px;margin-right:10px;width:12px}.status-ok .health-indicator{background-color:#4caf50}.status-error .health-indicator{background-color:#f44336}.service-name{color:#333;font-weight:700}.error-message{color:#d32f2f;font-size:.9em;margin-left:5px}.service-detail{color:#777;font-size:.9em;margin-left:5px}.header-content{align-items:center;display:flex;justify-content:space-between;width:100%}@media (max-width:768px){.header-logo{height:auto!important;width:250px!important}.main-header{flex-wrap:wrap;position:relative}.mobile-nav-container{display:none;width:100%}.mobile-nav-container.open{display:flex}.hamburger-btn{background:none;border:none;cursor:pointer;display:flex!important;flex-direction:column;height:22px;justify-content:space-between;padding:0;width:28px;z-index:101}.hamburger-btn .bar{background-color:#fff;display:block;height:3px;transition:all .3s ease;width:100%}.hamburger-btn.open .bar:first-child{transform:translateY(9px) rotate(45deg)}.hamburger-btn.open .bar:nth-child(2){opacity:0}.hamburger-btn.open .bar:nth-child(3){transform:translateY(-9px) rotate(-45deg)}.main-nav{align-items:flex-start;padding:1rem 0}.main-nav,.main-tabs.mobile{flex-direction:column;gap:0;width:100%}.main-tabs.mobile .main-tab{border-bottom:1px solid #ffffff1a;border-radius:0;padding:1rem;text-align:left;width:100%}.main-tabs.mobile .dropdown{width:100%}.main-tabs.mobile .dropdown-content.mobile{background-color:var(--bg-alt);border:none;border-radius:0;box-shadow:none;position:relative;width:100%}.main-tabs.mobile .dropdown-item{background-color:var(--bg-alt);padding-left:2rem}.main-content{padding:var(--space-4)!important}.welcome-banner{height:calc(100vh - 120px)!important}.welcome-banner .splash-image{object-fit:cover!important}}@media (min-width:769px){.hamburger-btn{display:none!important}.header-logo{height:auto;max-width:100%;width:500px}}.dropdown{position:relative}.dropdown-content{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;box-shadow:var(--shadow-lg);left:0;max-width:350px!important;min-width:220px;overflow:visible!important;position:absolute;top:100%;width:max-content!important;z-index:100}.dropdown-header{background-color:var(--bg-alt);border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:8px 12px 4px;text-transform:uppercase}.dropdown-header:first-child{border-top:none}.dropdown-item{background-color:var(--bg-alt);border:none;color:var(--text-color);cursor:pointer;display:block;font-size:.9rem;font-weight:400;padding:.6rem 1.1rem;text-align:left;transition:background-color .2s ease;white-space:nowrap;width:100%}.dropdown-item:hover{background-color:var(--hover-bg);color:var(--text-color)}.dropdown-item:focus{background-color:var(--hover-bg);outline:1px dashed var(--primary);outline-offset:-2px}.dropdown-item.active{background-color:var(--bg-alt);color:var(--text-color);font-weight:700}.main-tab{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.6rem 1rem;position:relative;transition:background-color .2s;white-space:nowrap}.main-tab:hover{background-color:#ffffff1a}.main-tab.active{background-color:#fff3;font-weight:500}.caret{display:inline-block;font-size:.7rem;margin-left:.4rem;transition:transform .2s ease}.dropdown.open .caret{transform:rotate(180deg)}@media (max-width:768px){.dropdown-content.mobile{max-width:none!important;width:100%!important}.dropdown-content.mobile .dropdown-header,.dropdown-content.mobile .dropdown-item,.dropdown-content.mobile a.dropdown-item,.dropdown-content.mobile button.dropdown-item{word-wrap:break-word!important;overflow-wrap:break-word!important;white-space:normal!important;width:100%!important}}.mobile-poll-container{background-color:#f5f5f5;box-sizing:border-box;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;min-height:100vh;padding:1rem;position:relative;width:100%}.registration-form{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:auto;max-width:500px;padding:2rem;text-align:center;width:100%}.registration-form h2{color:#333;margin-top:0}.registration-form input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:16px;margin-bottom:1rem;padding:12px;width:100%}.registration-form button{align-items:center;background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:16px 24px;width:100%}.registration-form button:hover{background-color:#45a049}.poll-placeholder{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;color:#666;margin:auto;padding:2rem;text-align:center}.poll-placeholder h2{color:#333;margin-top:0}.poll-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.poll-header h2{color:#333;margin:0}.show-results-btn{align-items:center;background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:16px 24px}.show-results-btn:hover{background-color:#0b7dda}.poll-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.poll-option{align-items:center;background-color:#fff;border:none;border-radius:8px;box-shadow:0 2px 5px #0000001a;color:#333;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:16px 32px;text-align:center;transition:none;width:100%}.poll-option:hover:not(.disabled){background-color:#f0f0f0}.poll-option.selected{background-color:#e8f5e9;border:2px solid #4caf50}.option-text{color:#333;font-size:18px;font-weight:500}.results-container{background-color:#f0f0f0;border-radius:12px;height:24px;margin-top:.5rem;overflow:hidden;position:relative}.result-bar{background-color:#4caf50;height:100%;left:0;position:absolute;top:0;transition:width .5s ease}.vote-percentage{color:#333;font-weight:700;position:absolute;right:10px;top:50%;transform:translateY(-50%);z-index:1}.total-votes{color:#666;font-size:14px;margin-top:1rem;text-align:center}@media (max-width:320px){.poll-header{align-items:flex-start;flex-direction:column;gap:.5rem}.option-text{font-size:16px}}.debug-panel{background-color:#000000e6;color:#0f0;font-family:monospace;font-size:14px;left:0;max-height:60vh;overflow-y:auto;padding:10px;position:fixed;right:0;top:0;z-index:9999}.debug-panel h3{color:#fff;margin-top:0;text-align:center}.debug-panel p{margin:5px 0}.debug-actions{display:flex;gap:8px;margin-top:10px}.debug-actions button{background-color:#333;border:1px solid #555;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;padding:8px}.debug-actions button:hover{background-color:#444}.poll-logo{display:block;height:auto;margin:0 auto 1rem;max-width:none;width:100%}.option-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.presenter-btn-container{margin-bottom:4rem;margin-top:2rem;text-align:center}.presenter-btn{align-items:center;background-color:#ff9800;border:none;border-radius:4px;box-shadow:0 2px 5px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:16px 32px;text-align:center;width:100%}.presenter-btn:hover{background-color:#fb8c00}.mobile-poll-timer{color:#2e7d32;font-family:monospace;font-size:20px;font-weight:600;margin:1rem auto;text-align:center}.placeholder-actions{gap:1rem;margin-top:1.5rem}.floating-login-btn{position:absolute;right:15px;top:15px;z-index:10}.floating-login-btn button{background-color:#2196f3;border:none;border-radius:4px;box-shadow:0 2px 5px #0003;color:#fff;cursor:pointer;font-size:14px;opacity:.8;padding:8px 16px;transition:opacity .2s}.floating-login-btn button:hover{opacity:1}.registration-options{align-items:center;display:flex;flex-direction:column;gap:1rem;width:100%}.registration-options .btn,.registration-options button{max-width:280px;width:100%}.login-prompt{font-size:1rem;font-weight:500;margin-bottom:.5rem}.options-divider{margin:.5rem 0;text-align:center;width:100%}.options-divider span{color:#666;font-size:.875rem}.btn-secondary{background-color:#4caf50;color:#fff}.btn-secondary:hover{background-color:#45a049}.presenter-msg-btn{position:relative}.presenter-msg-btn .unread-badge{align-items:center;background-color:red;border-radius:10px;color:#fff;display:flex;font-size:11px;font-weight:700;height:16px;justify-content:center;line-height:16px;min-width:16px;padding:0 3px;position:absolute;right:6px;top:2px}.presenter-msg-btn.has-unread{background-color:#ff9800;border-color:#ff9800;color:#fff}.presenter-msg-btn.has-unread:hover{background-color:#fb8c00;border-color:#fb8c00}.profile-modal-overlay{align-items:center;background:#000c;display:flex;height:100vh;justify-content:center;left:0;pointer-events:all;position:fixed;top:0;width:100vw;z-index:9999}.profile-modal-content{background:#0000;background:linear-gradient(135deg,#ff9a9e,#fad0c4 55%,#fbc2eb);border:none;border-radius:12px;box-shadow:0 6px 24px #00000040;display:flex;flex-direction:column;max-height:80vh;max-width:600px;overflow-y:auto;padding:20px;position:relative;width:95%}.close-modal-btn{background:none;border:none;color:#555;cursor:pointer;font-size:24px;line-height:1;padding:5px;position:absolute;right:15px;top:10px}.presenter-profile h2{color:#fff;font-size:24px;margin-bottom:15px;margin-top:10px;text-align:center;text-shadow:0 2px 4px #00000040}.profile-image-container{margin-bottom:20px;text-align:center}.profile-image{border:3px solid #e0e0e0;border-radius:50%;height:150px;object-fit:cover;width:150px}.profile-title h3{color:#fff;font-size:18px;font-weight:400;margin-bottom:15px;text-align:center;text-shadow:0 2px 4px #00000040}.profile-bio{background-color:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:15px}.profile-bio p{color:#fff;line-height:1.5;margin:0}.profile-credentials h4,.profile-organization h4{color:#fff;font-size:16px;margin-bottom:5px;text-shadow:0 2px 4px #00000040}.profile-organization p{margin-bottom:15px;margin-top:0}.profile-credentials ul{margin:0;padding-left:20px}.profile-credentials li{margin-bottom:5px}.profile-error,.profile-loading{color:#555;padding:30px 0;text-align:center}.placeholder-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;max-width:350px;width:100%}.placeholder-actions .btn{width:100%}@media (min-width:768px){.placeholder-actions{flex-direction:row;flex-wrap:wrap;justify-content:center}.placeholder-actions .btn{width:auto}}@media (max-width:600px){.profile-modal-content{height:auto;max-height:80vh;max-width:none;width:100%}}.profile-picture-preview{border:none!important;border-radius:12px;box-shadow:none!important}.presenter-profile h2,.presenter-profile h3,.presenter-profile h4{color:#fff;text-shadow:0 2px 4px #00000040}.presenter-profile li,.presenter-profile p{color:#fff}.profile-picture-section{border:none!important;box-shadow:none!important}.profile-bio p{color:#222!important}.profile-organization h4,.profile-organization p{color:#000!important;text-shadow:none!important}.reward-popup-overlay{align-items:center;background:#000000b3;display:flex;height:100vh;justify-content:center;left:0;pointer-events:all;position:fixed;top:0;width:100vw;z-index:10000}.reward-popup-content{align-items:center;background:linear-gradient(135deg,#a1c4fd,#c2e9fb);border-radius:12px;box-shadow:0 8px 30px #0003;display:flex;flex-direction:column;max-width:450px;padding:25px;position:relative;text-align:center;width:90%}.reward-popup-content h2{color:#fff;font-size:22px;margin-bottom:15px;margin-top:0}.reward-popup-content .reward-details p{color:#f8f9fa;font-size:16px;margin:8px 0}.reward-popup-content .btn-primary{background-color:#28a745;border-color:#28a745;font-size:16px;margin-top:20px;padding:10px 20px}
/*# sourceMappingURL=main.5d66e0c8.css.map*/