@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,600,700");@import url("https://fonts.googleapis.com/css?family=Source+Serif+Pro:400,600,700");@import url("https://fonts.googleapis.com/css?family=Nunito:400,600,700");:root{--font-mono:ui-monospace,Menlo,Monaco,"Cascadia Mono","Segoe UI Mono","Roboto Mono","Oxygen Mono","Ubuntu Monospace","Source Code Pro","Fira Mono","Droid Sans Mono","Courier New",monospace;--foreground-rgb:0,0,0;--background-color:var(--background);--primary-glow:conic-gradient(from 180deg at 50% 50%,#16abff33 0deg,#0885ff33 55deg,#54d6ff33 120deg,#0071ff33 160deg,transparent 360deg);--secondary-glow:radial-gradient(#fff,hsla(0,0%,100%,0));--tile-start-rgb:239,245,249;--tile-end-rgb:228,232,233;--tile-border:conic-gradient(#00000080,#00000040,#00000030,#00000020,#00000010,#00000010,#00000080);--callout-rgb:238,240,241;--callout-border-rgb:172,175,176;--card-rgb:180,185,188;--card-border-rgb:131,134,135}body{background-color:var(--background)!important;margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.button-box{display:flex;flex-wrap:wrap;justify-content:space-between}.vertical-center{display:flex;flex-direction:column;justify-content:center}.flex-item{display:inline-block}.flex-grow{flex-grow:1;flex-shrink:1}.navbar{flex-direction:column;margin:2rem 0 1rem}.navbar,.navbar ul{justify-content:center}.navbar ul{list-style-type:none;display:flex;flex-direction:row;margin:auto;padding:0;align-items:center}.navbar li{padding:0 1rem}.navbar a{color:#000;opacity:.5;font-weight:700;text-decoration:none}.question-text{font-size:24px;font-weight:400}[type=radio]{display:none}.radio-button-fixed{min-width:100px}[type=date]::-webkit-calendar-picker-indicator,[type=date]::-webkit-inner-spin-button{display:none}.progress-bar{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--gradient-primary);border-radius:3px;transition:width .3s ease}.skeleton{animation:skeleton-loading 1.5s linear infinite;background:linear-gradient(90deg,#f3f4f6,#e5e7eb 50%,#f3f4f6);background-size:200% 100%;border-radius:4px}.skeleton-title{height:24px;width:70%}.skeleton-subtitle{height:16px;width:90%}.skeleton-text{height:14px;width:100%}.skeleton-badge{height:28px;width:80px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.nav-sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.nav-sidebar-title{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.nav-sidebar-subtitle{font-size:1rem;color:var(--muted);margin:0}.nav-sidebar-divider{height:1px;background:var(--border);margin:1rem 0}.nav-back-button{color:var(--primary)!important;font-weight:500}.nav-back-button:hover{color:var(--primary-hover)!important}.nav-icon{margin-right:.75rem}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:var(--card);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;font-size:1.25rem;color:var(--foreground);cursor:pointer;transition:all .2s ease}.mobile-menu-toggle:hover{background:var(--card-hover)}@media (max-width:767px){.mobile-menu-toggle{display:flex;align-items:center;justify-content:center}}.nav-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999}@media (max-width:767px){.nav-overlay{display:block}}.settings-section{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.landing-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.landing-page .container{max-width:1200px;margin:0 auto;padding:0 1rem}.landing-nav{position:fixed;top:0;left:0;right:0;background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid hsla(0,0%,100%,.2);z-index:1000;padding:1rem 0}.nav-container{max-width:1200px}.nav-logo{font-size:1.5rem;font-weight:700;color:var(--primary)}.nav-cta,.nav-logo{display:flex;align-items:center;gap:.5rem}.nav-cta{background:var(--primary);color:#fff;padding:.75rem 1.5rem;border-radius:50px;text-decoration:none;font-weight:500;transition:all .3s ease}.nav-cta:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 10px 25px rgba(59,130,246,.3);color:#fff}.hero{padding:120px 0 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow:hidden;position:relative}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.hero-container{max-width:1300px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 1fr;grid-gap:4rem;gap:4rem;align-items:center;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:hsla(0,0%,100%,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:50px;font-size:1rem;font-weight:500;margin-bottom:2rem;border:1px solid hsla(0,0%,100%,.3)}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem}.gradient-text{color:var(--primary);font-weight:800}.hero-subtitle{font-size:1.25rem;line-height:1.6;opacity:.9;margin-bottom:2rem}.hero-buttons{display:flex;gap:1rem}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:#fff;color:var(--primary);padding:1rem 2rem;border-radius:50px;text-decoration:none;font-weight:600;transition:all .3s ease;border:none;cursor:pointer}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 15px 35px rgba(0,0,0,.2);color:var(--primary)}.btn-primary.large{padding:1.25rem 2.5rem;font-size:1.125rem}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:#fff;padding:1rem 2rem;border-radius:50px;text-decoration:none;font-weight:500;border:2px solid hsla(0,0%,100%,.3);transition:all .3s ease}.btn-secondary:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.5);color:#fff}.hero-stats{display:flex;gap:2rem}.stat{text-align:center}.stat-number{display:block;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{opacity:.8}.hero-visual{position:relative}.hero-image-container{background:hsla(0,0%,100%,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:1rem;width:100%;border:1px solid hsla(0,0%,100%,.3)}.hero-image{width:100%;height:auto;border-radius:10px}.image-caption{text-align:center;font-size:1rem;opacity:.8;margin-top:1rem}.features{padding:100px 0;background:#fff}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.section-header p{font-size:1.125rem;color:var(--muted);max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));grid-gap:1.5rem;gap:1.5rem}.feature-card{background:#fff;padding:2.5rem 1.5rem;border-radius:20px;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.1);transition:all .3s ease;border:1px solid var(--border)}.feature-card:hover{transform:translateY(-10px);box-shadow:0 20px 40px rgba(0,0,0,.15)}.feature-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2rem;color:#fff}.feature-card h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--foreground)}.feature-card p{color:var(--muted);line-height:1.6}.how-it-works{padding:100px 0;background:var(--background)}.timeline{max-width:800px;margin:0 auto}.timeline-step{display:flex;gap:2rem;margin-bottom:3rem;position:relative}.timeline-step:not(:last-child):after{content:"";position:absolute;left:1.5rem;top:3rem;bottom:-3rem;width:2px;background:var(--border)}.timeline-number{width:3rem;height:3rem;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;flex-shrink:0}.timeline-content h4{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:var(--foreground)}.timeline-time{color:var(--primary);font-weight:600;font-size:1rem;margin-bottom:.75rem}.timeline-content p{color:var(--muted);line-height:1.6;margin:0}.faq{padding:100px 0;background:#fff}.faq-list{max-width:800px;margin:0 auto}.faq-item{border:1px solid var(--border);border-radius:15px;margin-bottom:1rem;overflow:hidden}.faq-question{padding:1.5rem 2rem;background:var(--card);cursor:pointer;font-weight:600;font-size:1.125rem;list-style:none;transition:background .3s ease}.faq-question:hover{background:var(--card-hover)}.faq-answer{padding:1.5rem 2rem;background:#fff;border-top:1px solid var(--border)}.faq-answer ol,.faq-answer ul{margin:1rem 0;padding-left:1.5rem}.faq-answer li{margin-bottom:.5rem}.cta{padding:100px 0;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;text-align:center}.cta-content h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-content p{font-size:1.25rem;opacity:.9;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.footer{background:var(--foreground);color:#fff;padding:3rem 0 1rem}.footer-content{justify-content:space-between;margin-bottom:2rem}.footer-content,.footer-logo{display:flex;align-items:center}.footer-logo{gap:.5rem;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.footer-left p{opacity:.8;margin:0}.footer-links{display:flex;gap:2rem}.footer-links a{color:#fff;text-decoration:none;opacity:.8;transition:opacity .3s ease}.footer-links a:hover{opacity:1;color:#fff}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid hsla(0,0%,100%,.1)}.footer-bottom p{opacity:.6;margin:0}.dashboard-page{height:100vh;background:var(--background);display:flex;flex-direction:column}.dashboard-nav{background:#fff;border-bottom:1px solid var(--border);padding:1rem 0;position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:var(--shadow-sm);height:80px}.fa,.fab,.fal,.far,.fas,svg[data-icon]{display:inline-block;width:1em;height:1em}.nav-container{max-width:1400px;margin:0 auto;padding:0 2rem;justify-content:space-between}.nav-container,.nav-left{display:flex;align-items:center}.nav-left{gap:1rem}.nav-left .nav-logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--primary);text-decoration:none;transition:color .2s ease}.nav-left .nav-logo:hover{color:var(--primary-hover)}.nav-breadcrumbs{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--muted)}.breadcrumb-separator{color:var(--muted);margin:0 .25rem}.breadcrumb-link{color:var(--primary);text-decoration:none;font-weight:500;transition:color .2s ease}.breadcrumb-link:hover{color:var(--primary-hover);text-decoration:underline}.breadcrumb-current{color:var(--foreground);font-weight:600}.user-info{display:flex;align-items:center;gap:1rem}.user-details{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;color:var(--foreground);font-size:1rem}.user-email{font-size:.75rem;color:var(--muted)}.sign-out-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--card);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.sign-out-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.dashboard-container{max-width:1400px;padding:2rem;margin:80px auto 0;flex:1 1}.page-wrapper{height:100vh;background:var(--background)}.page-content{margin-top:80px;height:calc(100vh - 80px);overflow-y:auto}.welcome-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:20px;color:#fff}.welcome-content h1{font-size:2rem;margin-bottom:.5rem;font-weight:700}.welcome-content p{opacity:.9;font-size:1.125rem;margin:0}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:15px;border:1px solid var(--border);display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-sm);transition:all .3s ease}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:60px;height:60px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;flex-shrink:0}.stat-icon.courses{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.active{background:linear-gradient(135deg,var(--success),#22c55e)}.stat-icon.students{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-content{flex:1 1}.stat-label{font-size:1rem;color:var(--muted);margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:var(--foreground)}.skeleton-circle{width:60px;height:60px;border-radius:15px;background:var(--border);animation:skeleton-loading 1.5s linear infinite}.activity-banner{background:#fff;border-radius:15px;padding:1rem 1.5rem;margin-bottom:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.activity-items{display:flex;gap:2rem;flex-wrap:wrap;align-items:center}.activity-banner .activity-item{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--foreground)}.activity-banner .activity-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;flex-shrink:0}.activity-banner .activity-icon.success{background:var(--success)}.activity-banner .activity-icon.info{background:var(--primary)}.activity-banner .activity-icon.warning{background:var(--warning)}.courses-section{min-height:0}.section-header{margin-bottom:1.5rem}.header-title-row{justify-content:space-between;width:100%}.header-left,.header-title-row{display:flex;align-items:center}.header-left{gap:1.5rem}.header-left h2{margin:0}.header-right{gap:2rem}.header-right,.header-stats,.inline-stats{display:flex;align-items:center}.inline-stats{gap:.75rem}.inline-stat{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--card);border:1px solid var(--border);border-radius:6px;font-size:.875rem}.inline-stat .stat-label{color:var(--muted);font-weight:500;font-size:.875rem}.inline-stat .stat-value{color:var(--foreground);font-weight:600;font-size:.875rem}.inline-stat .stat-icon{font-size:.875rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:#fff;flex-shrink:0}.inline-stat:first-child .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.inline-stat:nth-child(2) .stat-icon{background:linear-gradient(135deg,var(--success),#22c55e)}.section-header h2{font-size:1.75rem;font-weight:600;color:var(--foreground);margin:0}.course-count{background:var(--card);color:var(--muted);padding:.5rem 1rem;border-radius:50px;font-size:1rem;border:1px solid var(--border)}.add-course-modal{background:#fff;border-radius:20px;margin-bottom:2rem;border:1px solid var(--border);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.add-course-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.add-course-header h3{margin:0;font-size:1.25rem;font-weight:600}.close-btn{background:none;border:none;color:#fff;font-size:1.5rem;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;opacity:.8}.close-btn:hover{background:hsla(0,0%,100%,.2);opacity:1;transform:scale(1.1)}.add-course-content{padding:2rem}.add-course-form{max-width:none}.form-instructions{background:var(--card);border-radius:12px;padding:1.5rem;margin-bottom:2rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.form-instructions h4{color:var(--foreground);margin-bottom:1rem;font-size:1.125rem}.instruction-steps{display:flex;flex-direction:column;gap:1rem}.instruction-step{display:flex;gap:1rem;align-items:flex-start}.step-number{background:var(--primary)}.step-content{flex:1 1}.step-content p{margin:0 0 .5rem;color:var(--foreground);font-size:1rem}.step-content p:last-child{margin-bottom:0}.step-content ul{margin:.5rem 0;padding-left:1.25rem}.step-content li{color:var(--muted);font-size:1rem;margin-bottom:.25rem}.text-muted{color:var(--muted)!important}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.form-field{display:flex;flex-direction:column}.form-label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--foreground);margin-bottom:.5rem;font-size:1rem}.required{color:var(--danger)}.tooltip-wrapper{position:relative;display:inline-flex;align-items:center}.info-icon{color:var(--muted);cursor:help;font-size:.75rem}.tooltip-content{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--foreground);color:#fff;padding:.5rem;border-radius:.25rem;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:1000;margin-bottom:.25rem}.tooltip-wrapper:hover .tooltip-content{opacity:1}.form-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;background:var(--input);color:var(--foreground);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.form-input.error{border-color:var(--danger)}.date-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background:var(--input);color:var(--foreground);text-align:left;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.date-input:hover{border-color:var(--muted)}.date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.date-input.error{border-color:var(--danger)}.calendar-icon{color:var(--muted);font-size:1rem}.field-error{font-size:.75rem;margin-top:.25rem}.survey-summary{background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.2);border-radius:.75rem;padding:1.5rem;margin-bottom:2rem}.survey-summary h4{color:var(--primary);margin-bottom:.75rem;font-size:1rem}.survey-summary p{margin:.5rem 0;color:var(--foreground);font-size:1rem}.form-actions{display:flex;justify-content:flex-end;margin-top:2rem}.form-actions .btn-primary{min-width:200px}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;border:1px solid var(--border)}.empty-icon{width:80px;height:80px;background:var(--background);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2rem;color:var(--muted)}.empty-state h3{font-size:1.5rem;font-weight:600;margin-bottom:.75rem;color:var(--foreground)}.empty-state p{color:var(--muted);margin-bottom:2rem;max-width:400px;margin-left:auto;margin-right:auto}.empty-features{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.empty-feature{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:1rem}.dashboard-sidebar{display:flex;flex-direction:column;gap:1.5rem}.card-header{padding-bottom:1rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.card-header h3{font-size:1.125rem;font-weight:600;margin:0;color:var(--foreground)}.activity-card{background:#fff}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{gap:1rem}.activity-icon,.activity-item{display:flex;align-items:center}.activity-icon{width:40px;height:40px;border-radius:50%;justify-content:center;font-size:1rem;color:#fff;flex-shrink:0}.activity-icon.success{background:var(--success)}.activity-icon.info{background:var(--primary)}.activity-icon.warning{background:var(--warning)}.activity-content{flex:1 1}.activity-content p{margin:0 0 .25rem;color:var(--foreground);font-size:1rem}.activity-time{font-size:.75rem;color:var(--muted)}.help-card{background:#fff}.help-content p{color:var(--muted);margin-bottom:1rem;font-size:1rem}.help-links{display:flex;flex-direction:column;gap:.75rem}.help-links a{color:var(--primary);text-decoration:none;font-size:1rem;padding:.5rem 0;border-bottom:1px solid var(--border);transition:color .2s ease}.help-links a:hover{color:var(--primary-hover)}.help-links a:last-child{border-bottom:none}.mr-2{margin-right:.5rem}@media (max-width:1200px){.dashboard-grid{grid-template-columns:1fr}.dashboard-sidebar{grid-row:1}}@media (max-width:768px){.hero-container{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-title{font-size:2.5rem}.hero-buttons{flex-direction:column;align-items:center}.hero-stats{justify-content:center}.features-grid{grid-template-columns:1fr}.timeline-step{flex-direction:column;text-align:center}.timeline-step:after{display:none}.footer-content{gap:2rem}.footer-content,.welcome-section{flex-direction:column;text-align:center}.welcome-section{gap:1.5rem}.dashboard-container{padding:1rem}.header-title-row{flex-direction:column;gap:1rem;text-align:center}.header-left{flex-direction:column;gap:1rem;width:100%}.header-left h2{font-size:1.5rem}.header-left .btn-primary{width:100%}.header-right{flex-direction:column;gap:1rem;width:100%}.quick-stats{grid-template-columns:1fr}.user-details{display:none}.empty-features{flex-direction:column;align-items:center}}.settings-section-clean{background:transparent;padding:0}.section-content{background:#fff;border-radius:16px;padding:2rem;border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.04);transition:box-shadow .3s ease}.section-content:hover{box-shadow:0 4px 16px rgba(0,0,0,.08)}.section-header-clean{margin-bottom:2.5rem}.section-header-clean h2{font-size:1.75rem;font-weight:600;color:var(--foreground);margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}.section-icon{color:var(--primary);font-size:1.5rem}.section-description{color:var(--muted);font-size:1rem;line-height:1.6;margin:0}.page-header-clean{margin-bottom:2rem}.page-header-clean h1{font-size:2.25rem;font-weight:700;color:var(--foreground);margin-bottom:.5rem}.page-subtitle{color:var(--muted);font-size:1.125rem;margin:0}.timeline-clean{position:relative;padding-left:30px}.timeline-clean:before{content:"";position:absolute;left:12px;top:24px;bottom:24px;width:2px;background:linear-gradient(180deg,var(--primary) 0,var(--secondary) 100%);opacity:.2}.timeline-event{position:relative;margin-bottom:3rem}.timeline-event:last-child{margin-bottom:0}.timeline-badge{position:absolute;left:-30px;top:0;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.125rem;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1}.timeline-badge.monday{background:linear-gradient(135deg,#3b82f6,#2563eb)}.timeline-badge.thursday{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.timeline-badge.sunday{background:linear-gradient(135deg,#10b981,#059669)}.timeline-panel{background:var(--background);padding:1.5rem;border-radius:12px;margin-left:36px;border:1px solid var(--border);transition:all .3s ease}.timeline-panel:hover{transform:translateX(4px);box-shadow:0 4px 16px rgba(0,0,0,.08)}.timeline-heading{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.timeline-heading h4{font-size:1.125rem;font-weight:600;color:var(--foreground);margin:0}.timeline-date{background:var(--primary);color:#fff;font-size:.75rem;padding:.25rem .75rem;border-radius:50px;font-weight:500}.timeline-panel p{color:var(--muted);font-size:1rem;line-height:1.6;margin:0}.questions-instructions{margin-bottom:2rem}.instruction-card{background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.2);border-radius:12px;padding:1.5rem}.instruction-card h4{font-size:1.125rem;font-weight:600}.instruction-card h4,.instruction-card p{color:var(--foreground);margin-bottom:1rem}.instruction-card p{font-size:1rem;line-height:1.6}.highlight-text{color:var(--primary);font-weight:600}.question-types{margin:1.5rem 0}.question-types h5{font-size:1rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.type-list{display:flex;flex-direction:column;gap:.75rem}.type-item{display:flex;align-items:center;gap:1rem;font-size:1rem;color:var(--foreground)}.type-badge{display:inline-flex;align-items:center;padding:.375rem .75rem;border-radius:8px;font-size:.75rem;font-weight:600;min-width:120px;justify-content:center}.type-badge.text{background:rgba(59,130,246,.1);color:var(--primary)}.type-badge.numeric{background:rgba(139,92,246,.1);color:#8b5cf6}.type-badge.rating{background:rgba(16,185,129,.1);color:var(--success)}.type-badge.qualitative{background:rgba(245,158,11,.1);color:var(--warning)}.drag-hint{display:flex;align-items:center;gap:.5rem;margin-top:1rem;margin-bottom:0}.drag-hint,.drag-icon{color:var(--muted);font-size:1rem}.roster-table{width:100%;border-collapse:collapse;background:var(--background);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1);margin:1rem 0}.roster-table th{background:var(--muted-background);padding:.875rem 1rem;text-align:left;font-weight:600;font-size:1rem;color:var(--foreground);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border)}.roster-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border);transition:all .2s ease}.roster-table tbody tr:hover{background:rgba(0,0,0,.02)}.roster-table tbody tr:last-child td{border-bottom:none}.roster-table.staged{border:2px solid var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.roster-table.staged th{background:rgba(59,130,246,.1);color:var(--primary)}.roster-table.staged td{color:var(--primary)}.roster-table.unstaged{border:1px solid var(--border)}.roster-table.unstaged th{background:var(--muted-background);color:var(--foreground)}.roster-table.unstaged td{color:var(--foreground)}.roster-container{max-height:300px;overflow-y:auto;border-radius:8px;border:1px solid var(--border);margin:1rem 0}.roster-status{text-align:center;margin:1rem 0;padding:.75rem;border-radius:6px}.roster-status.staged{background:rgba(59,130,246,.1);color:var(--primary);border:1px solid rgba(59,130,246,.2)}.roster-status.unstaged{background:var(--muted-background);color:var(--muted);border:1px solid var(--border)}.roster-last-update{font-size:1rem;color:var(--muted);margin-top:.5rem}.questions-table-wrapper{background:var(--background);border-radius:12px;padding:1.5rem;border:1px solid var(--border);box-shadow:0 1px 3px rgba(0,0,0,.1)}.questions-list{margin:0;position:relative}.questions-header{display:grid;grid-template-columns:1fr auto auto;grid-gap:1rem;gap:1rem;padding:1rem 1rem 1.5rem;border-bottom:2px solid var(--border);font-weight:600;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;background:var(--background);position:-webkit-sticky;position:sticky;top:0;z-index:10;margin-bottom:1rem}.questions-header .header-type{min-width:160px}.questions-header .header-actions{min-width:100px}.question-row{display:grid;grid-template-columns:1fr auto auto;grid-gap:1rem;gap:1rem;padding:1rem;border-bottom:1px solid var(--border);align-items:center;transition:all .2s ease;min-height:60px}.question-row .question-type{min-width:160px}.question-row .question-actions{min-width:100px}@media (max-width:1024px) and (min-width:769px){.questions-header .header-type{min-width:140px}.questions-header .header-actions{min-width:80px}.question-row .question-type{min-width:140px}.question-row .question-actions{min-width:80px}}@media (max-width:768px){.questions-header{grid-template-columns:1fr;gap:.5rem;padding:1rem}.questions-header .header-actions,.questions-header .header-type{display:none}.question-row{grid-template-columns:1fr;gap:.75rem;padding:1rem}.question-row .question-type{min-width:unset;order:1;margin-top:.5rem}.question-row .question-actions{min-width:unset;order:2;justify-self:end;margin-top:.5rem}.question-prompt{order:0}}@media (max-width:640px){.questions-table-wrapper{padding:1rem}.question-row,.questions-header{padding:.75rem}.question-row{gap:.5rem}.question-row .question-actions{display:flex;gap:.25rem}.drag-handle{width:20px;height:20px}}.question-row:hover{background:rgba(0,0,0,.02)}.question-row.default{background:rgba(59,130,246,.05);border-radius:8px;margin-bottom:.5rem;border:1px solid rgba(59,130,246,.2)}.question-row.editable{background:#fff;border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1)}.question-row.editable:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(59,130,246,.15);transform:translateY(-1px)}.question-row.editable.dragging{opacity:.8;transform:rotate(2deg);box-shadow:0 8px 25px rgba(0,0,0,.2);z-index:1000}.draggable-wrapper{margin-bottom:.5rem;width:100%}.draggable-wrapper .question-row{margin-bottom:0}.question-prompt{position:relative}.question-textarea{width:100%;min-height:32px;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;font-family:inherit;background:#fff;color:var(--foreground);resize:none;transition:all .2s ease;line-height:1.4;overflow:hidden}.question-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.question-textarea.disabled{background:var(--background);color:var(--muted);cursor:not-allowed}.question-error{position:absolute;bottom:-15px;left:0;color:var(--danger);font-size:.75rem}.question-type{display:flex;align-items:center;justify-self:start}.type-dropdown-wrapper{position:relative;width:100%}.type-select{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;background:#fff;color:var(--foreground);cursor:pointer;transition:all .2s ease;height:auto;min-height:32px;line-height:1.4}.type-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.type-select:disabled{cursor:not-allowed}.type-display,.type-select:disabled{background:var(--background);color:var(--muted)}.type-display{display:inline-flex;align-items:center;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;min-width:150px;min-height:32px;line-height:1.4}.type-display.disabled{opacity:.7}.question-actions{justify-content:flex-end;gap:.5rem}.drag-handle,.question-actions{display:flex;align-items:center}.drag-handle{justify-content:center;width:24px;height:24px;cursor:-webkit-grab;cursor:grab;transition:all .2s ease;position:relative;background:none;border:none;padding:0;border-radius:4px}.drag-handle:hover{background:rgba(0,0,0,.05)}.drag-handle:active{background:rgba(0,0,0,.1)}.drag-handle:before{content:"";position:absolute;width:14px;height:2px;background:var(--muted);box-shadow:0 4px 0 var(--muted),0 8px 0 var(--muted);transition:all .2s ease;opacity:.6}.drag-handle:hover:before{opacity:1;background:var(--foreground);box-shadow:0 4px 0 var(--foreground),0 8px 0 var(--foreground)}.default-label{background:rgba(59,130,246,.1);color:var(--primary);padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.drag-handle:hover{background:var(--background);color:var(--foreground)}.drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}a.btn-primary,button.btn-primary{background:var(--primary)!important;color:#fff!important;border:none!important;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease;cursor:pointer}a.btn-primary:hover,button.btn-primary:hover{background:var(--primary-hover)!important;color:#fff!important;transform:translateY(-1px);box-shadow:var(--shadow-md)}a.btn-secondary,button.btn-secondary{background:var(--card)!important;color:var(--foreground)!important;border:1px solid var(--border)!important;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease;cursor:pointer}a.btn-secondary:hover,button.btn-secondary:hover{background:var(--card-hover)!important;color:var(--foreground)!important;border-color:var(--muted)!important}a.btn-danger,button.btn-danger{background:var(--danger)!important;color:#fff!important;border:1px solid var(--danger)!important;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease;cursor:pointer}a.btn-danger:hover,button.btn-danger:hover{background:#dc2626!important;color:#fff!important;border-color:#dc2626!important}.page-with-nav{min-height:100vh;display:flex;flex-direction:column}.auth-checking-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 80px);margin-top:80px;background:var(--background)}.auth-checking-container p{color:var(--muted);margin-top:1rem;font-size:1.1rem}.settings-page{display:flex;position:relative;margin-top:80px;height:calc(100vh - 80px)}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:var(--card);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;width:48px;height:48px;font-size:1.25rem;color:var(--foreground);cursor:pointer;box-shadow:var(--shadow-md)}.settings-sidebar{width:280px;background:var(--card);border-right:1px solid var(--border);height:calc(100vh - 80px);position:-webkit-sticky;position:sticky;top:0;overflow-y:auto;flex-shrink:0}.sidebar-header{padding:2rem 1.5rem 1rem;border-bottom:1px solid var(--border)}.sidebar-header h3{font-size:1.25rem;margin-bottom:.5rem}.course-info{margin-top:.5rem}.course-name{font-size:1.5rem;font-weight:500;color:var(--foreground);margin-bottom:.25rem;line-height:1.3}.course-id-sidebar{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem;margin-top:.5rem;background:var(--input);border:1px solid var(--border);border-radius:.375rem;font-size:.75rem;color:var(--muted);cursor:pointer;transition:all .2s ease;width:-moz-fit-content;width:fit-content}.course-id-sidebar:hover{background:var(--card-hover);border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.sidebar-back-link{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;color:var(--primary);text-decoration:none;font-weight:500;transition:background .2s ease}.sidebar-back-link:hover{background:rgba(59,130,246,.05)}.sidebar-divider{height:1px;background:var(--border);margin:0}.sidebar-nav{padding:1rem 0}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1.5rem;background:none;color:var(--muted);font-size:1rem;font-weight:500;text-align:left;cursor:pointer;transition:all .2s ease;border:none;border-left:3px solid transparent}.sidebar-nav-item:hover{color:var(--foreground);background:rgba(0,0,0,.02)}.sidebar-nav-item.active{color:var(--primary);background:rgba(59,130,246,.08);border-left-color:var(--primary)}.nav-icon{width:20px;flex-shrink:0}.settings-content{flex:1 1;background:var(--background);overflow-y:auto;height:calc(100vh - 80px)}.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999}@media (max-width:768px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.settings-sidebar{position:fixed;left:0;top:80px;z-index:1000;transform:translateX(-100%);transition:transform .3s ease;height:calc(100vh - 80px)}.settings-sidebar.open{transform:translateX(0)}.mobile-overlay{display:block}.settings-content{margin-left:0}}.text-sm{font-size:1rem}.login-page{min-height:calc(100vh - 80px);display:flex;align-items:center;background:var(--background);padding:2rem 0}.login-container{max-width:1200px;margin:0 auto;padding:0 2rem;gap:4rem;align-items:center;position:relative}.back-to-main{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary);text-decoration:none;font-weight:500;padding:.75rem 1.25rem;border-radius:.5rem;transition:all .2s ease;position:absolute;top:-4rem;left:2rem}.back-to-main:hover{background:rgba(59,130,246,.1);transform:translateX(-4px)}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.loading-spinner{width:40px;height:40px;border-top:3px solid var(--border);border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.auth-loading p{color:var(--muted);margin:0}.auth-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:hsla(0,0%,100%,.95);display:flex;align-items:center;justify-content:center;z-index:9999}.auth-overlay-content{text-align:center}.auth-overlay-content .loading-spinner{width:50px;height:50px;margin:0 auto 1.5rem;border-top:3px solid var(--border);border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.auth-overlay-content p{color:var(--primary);font-size:1.2rem;font-weight:500;margin:0}.login-left{display:flex;flex-direction:column;gap:3rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary);text-decoration:none;font-weight:500;transition:all .2s ease}.back-link:hover{gap:.75rem}.login-hero h1{font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem;color:var(--foreground)}.login-hero p{font-size:1.25rem;color:var(--muted);line-height:1.6}.login-logo{display:inline-flex;align-items:center;gap:.75rem;margin-bottom:2rem}.login-logo svg{font-size:2.5rem;color:var(--primary)}.login-logo span{font-size:2rem;font-weight:700;color:var(--foreground)}.login-features{display:flex;flex-direction:column;gap:1.5rem}.login-feature{display:flex;align-items:flex-start;gap:1rem}.login-feature .feature-icon{font-size:1.25rem;color:var(--primary);background:rgba(59,130,246,.1);padding:.75rem;border-radius:8px;margin-top:.25rem}.login-feature h3{font-size:1.125rem;font-weight:600;margin-bottom:.25rem;color:var(--foreground)}.login-feature p{font-size:1rem;color:var(--muted);margin:0}.login-right{display:flex;align-items:center;justify-content:center}.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2rem;box-shadow:var(--shadow-lg);width:100%;max-width:550px}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{font-size:1.75rem;font-weight:600;margin-bottom:.5rem;color:var(--foreground)}.login-header p{color:var(--muted);font-size:1rem}.auth-container{margin:2rem 0}.firebaseui-container,.firebaseui-idp-button{font-family:inherit!important}.firebaseui-idp-button{border-radius:8px!important;font-size:1rem!important;padding:.75rem!important;transition:all .2s ease!important}.firebaseui-idp-button:hover{transform:translateY(-2px)!important;box-shadow:var(--shadow-md)!important}.login-footer{margin-top:2rem}.divider{text-align:center;margin:1.5rem 0;position:relative}.divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border)}.divider span{background:var(--card);padding:0 1rem;position:relative;color:var(--muted);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.signup-text{text-align:center;color:var(--muted);font-size:1rem;margin:0;line-height:1.5}@media (max-width:768px){.login-container{grid-template-columns:1fr;gap:2rem}.login-left{display:none}.login-card{padding:2rem;max-width:100%}.login-hero h1{font-size:2rem}.login-page{align-items:flex-start;padding:4rem 0 1rem}}.survey-page{min-height:calc(100vh - 80px);background:var(--background);padding:1.5rem 0}.survey-container{max-width:800px;margin:0 auto;padding:0 1rem}.survey-header-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);text-align:center}.survey-header-content{max-width:650px;margin:0 auto}.survey-title{font-size:1.75rem;font-weight:700;color:var(--foreground);margin-bottom:.5rem}.survey-description{font-size:1rem;color:var(--muted);line-height:1.5;margin-bottom:1rem}.back-to-settings{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary);text-decoration:none;font-weight:500;transition:all .2s ease}.back-to-settings:hover{gap:.75rem}.survey-form{width:100%}.survey-questions{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.survey-question{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;box-shadow:var(--shadow-sm);transition:all .2s ease}.survey-question:hover{border-color:var(--primary)}.question-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.question-number{color:var(--primary);font-weight:600;font-size:1rem;flex-shrink:0}.survey-question .question-label{font-size:1rem!important;font-weight:500;color:var(--foreground);line-height:1.4}.question-input{width:100%}.survey-input,.survey-textarea{width:100%;padding:.75rem;background:var(--input);border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;transition:all .2s ease}.survey-textarea{min-height:40px;resize:none;overflow:hidden;box-sizing:border-box}.survey-input:focus,.survey-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.survey-input.error,.survey-textarea.error{border-color:var(--danger)}.rating-options{display:flex;flex-wrap:wrap;gap:.5rem}.rating-option{display:flex;align-items:center;padding:.5rem .75rem;background:var(--input);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.rating-option:hover{background:var(--card-hover);border-color:var(--primary)}.rating-input{display:none}.rating-input:checked+.rating-label{font-weight:600}.rating-input:checked~.rating-label{color:var(--primary)}.rating-option:has(.rating-input:checked){background:rgba(59,130,246,.1);border-color:var(--primary)}.rating-label{font-size:1rem;color:var(--foreground);transition:all .2s ease}.field-error{display:block;color:var(--danger);font-size:.875rem;margin-top:.5rem}.survey-submit-section{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1.5rem;text-align:center;box-shadow:var(--shadow-sm)}.survey-submit{font-size:1rem;padding:.75rem 1.5rem;gap:.5rem}.survey-submit.disabled{opacity:.6;cursor:not-allowed}.preview-note{margin-top:1rem;color:var(--muted);font-size:1rem}.survey-loading-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:3rem 2rem;text-align:center;box-shadow:var(--shadow-sm)}.survey-loading-card .loading-spinner{width:50px;height:50px;margin:0 auto 1.5rem}.survey-loading-card h2{color:var(--foreground);margin-bottom:.5rem;font-size:1.5rem}.survey-loading-card p{color:var(--muted);margin:0}.survey-closed-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:2rem 1.5rem;text-align:center;box-shadow:var(--shadow-sm)}.closed-icon{font-size:2rem;color:var(--warning);margin-bottom:.75rem}.survey-closed-card h2{font-size:1.75rem;font-weight:600;margin-bottom:.5rem;color:var(--foreground)}.survey-closed-card p{font-size:1.125rem;color:var(--muted);margin:0}@media (max-width:768px){.survey-header-card{padding:1rem}.survey-title{font-size:1.5rem}.survey-description{font-size:.875rem}.survey-question{padding:1rem}.rating-options{flex-direction:column}.rating-option{width:100%;justify-content:center}.survey-submit-section{padding:1rem}.survey-submit{width:100%}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.questions-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.footer-note{display:flex;align-items:center;gap:.5rem;background:rgba(59,130,246,.05);padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;color:var(--primary)}.footer-note,.note-icon{font-size:1rem}.footer-actions{justify-content:space-between;align-items:center;flex-wrap:wrap}.action-buttons,.footer-actions{display:flex;gap:1rem}.unsaved-changes-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.3);border-radius:6px;color:#b45309;font-size:1rem;font-weight:500;margin-right:auto}.unsaved-changes-indicator .icon{font-size:1rem}.save-button-with-indicator{position:relative}.save-button-with-indicator.has-changes .btn-primary{background:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.2);animation:pulse-save 2s infinite}@keyframes pulse-save{0%,to{box-shadow:0 0 0 3px rgba(59,130,246,.2)}50%{box-shadow:0 0 0 6px rgba(59,130,246,.1)}}.roster-instructions{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.instruction-panel{background:var(--background);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.instruction-panel.canvas{background:rgba(139,92,246,.05);border-color:rgba(139,92,246,.2)}.instruction-panel h4{font-size:1.125rem;font-weight:600;color:var(--foreground);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.panel-icon{color:#8b5cf6;font-size:1rem}.requirement-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.requirement-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#fff;border-radius:8px;border:1px solid var(--border)}.requirement-label{font-weight:600;color:var(--foreground);min-width:80px;font-size:1rem}.requirement-desc{color:var(--muted);font-size:1rem}.steps-list{flex-direction:column}.step,.steps-list{display:flex;gap:1rem}.step{align-items:flex-start}.step-number{background:#8b5cf6;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;flex-shrink:0}.help-text{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(139,92,246,.2);font-size:1rem;color:var(--muted)}.help-text a{color:#8b5cf6;text-decoration:underline}.help-text a:hover{color:#7c3aed}.roster-form-wrapper{background:var(--background);border-radius:12px;padding:1.5rem;border:1px solid var(--border)}.admins-info{margin-bottom:2rem}.info-card{background:rgba(236,72,153,.05);border:1px solid rgba(236,72,153,.2);border-radius:12px;padding:1.5rem}.info-card h4{font-size:1.125rem;font-weight:600;color:var(--foreground);margin-bottom:.75rem}.info-card p{color:var(--foreground);font-size:1rem;margin-bottom:1rem}.permissions-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.permissions-list li{position:relative;padding-left:1.5rem;color:var(--muted);font-size:1rem}.permissions-list li:before{content:"✓";position:absolute;left:0;color:#ec4899;font-weight:600}.admins-table-wrapper{background:var(--background);border-radius:12px;padding:1.5rem;border:1px solid var(--border)}.admins-header{display:grid;grid-template-columns:60px 1fr 120px;grid-gap:1rem;gap:1rem;padding:1rem;border-bottom:2px solid var(--border);font-weight:600;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.admins-list{display:flex;flex-direction:column}.admin-row{display:grid;grid-template-columns:60px 1fr 120px;grid-gap:1rem;gap:1rem;padding:1rem;border-bottom:1px solid var(--border);align-items:center;transition:background .2s ease}.admin-row:hover{background:rgba(0,0,0,.02)}.admin-row.add-admin{background:#fff;border-bottom:none;margin-top:.5rem;border-radius:8px;border:1px solid var(--border)}.admin-no{color:var(--muted);font-size:1rem;text-align:center}.admin-email{position:relative}.admin-email,.admin-input{color:var(--foreground);font-size:1rem}.admin-input{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:6px;background:var(--background);transition:all .2s ease}.admin-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.input-error{position:absolute;bottom:-16px;left:0;color:var(--danger);font-size:.75rem}.admin-actions{display:flex;justify-content:center;gap:.5rem}.owner-badge{background:rgba(16,185,129,.1);color:var(--success);padding:.25rem .75rem;border-radius:50px;font-size:.75rem;font-weight:600}.btn-icon{width:32px;height:32px;border-radius:8px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1rem}.btn-icon.primary{background:var(--primary);color:#fff}.btn-icon.primary:hover{background:var(--primary-hover);transform:scale(1.1)}.btn-icon.danger{background:rgba(239,68,68,.1);color:var(--danger)}.btn-icon.danger:hover{background:var(--danger);color:#fff;transform:scale(1.1)}