@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Inter:wght@400;600;800&display=swap";:root{--brand-primary: #F05A28;--brand-highlight: #C4452D;--brand-secondary: #F7B89C;--text-dark: #2B1E1A;--text-light: #FBF7F4;--ui-base: #FBF7F4;--ui-surface: #FFFFFF;--ui-border: #E7DDD6;--lux-gold: #D4A373;--pop-highlight: #D4A373;--opus-accent: #0D9488;--opus-accent-soft: rgba(13, 148, 136, .1);--glass-bg: rgba(255, 255, 255, .75);--glass-border: rgba(231, 221, 214, .6);--glass-shadow: 0 12px 40px 0 rgba(43, 30, 26, .08);--glass-blur: blur(20px)}body{margin:0;background-color:var(--ui-base);color:var(--text-dark);font-family:Outfit,IBM Plex Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{scroll-behavior:smooth}.glass-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:16px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.glass-input{background:#fff3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid var(--ui-border);border-radius:8px;padding:.75rem 1rem;color:var(--text-dark);transition:all .3s ease}.glass-input:focus{outline:none;border-color:var(--brand-primary);background:#ffffff80;box-shadow:0 0 0 4px #5b2a6d1a}.glass-button{background:var(--brand-primary);color:#fff;border:none;border-radius:12px;padding:.8rem 1.6rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.glass-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px -10px var(--brand-primary);opacity:.9}.glass-button.secondary{background:var(--brand-highlight)}.glass-button.outline{background:transparent;border:2px solid var(--brand-primary);color:var(--brand-primary)}.glass-button.pop{background:var(--pop-highlight);color:var(--brand-primary);box-shadow:0 8px 25px #7ae0d666}.glass-button.pop:hover{background:#fff;color:var(--brand-primary);box-shadow:0 12px 30px #7ae0d680}.fade-page{opacity:0;width:100%;animation:fadeIn .8s ease forwards}@keyframes fadeIn{to{opacity:1}}.text-positive{color:#10b981;font-weight:600}.text-negative{color:#ef4444;font-weight:600}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;width:100%}.spinner{width:50px;height:50px;border:4px solid rgba(91,42,109,.1);border-left-color:var(--brand-primary);border-right-color:var(--brand-highlight);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem;box-shadow:0 0 20px #5b2a6d1a}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-weight:600;color:var(--brand-primary);letter-spacing:.05em;text-transform:uppercase;font-size:.85rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.page-transition{animation:slideUp .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-wrapper{background-color:var(--ui-base);min-height:100vh;position:relative;overflow-x:hidden;font-family:Outfit,sans-serif}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.bg-gradient-fallback{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;background:radial-gradient(circle at 50% 0%,var(--brand-secondary) 0%,transparent 50%),radial-gradient(circle at 10% 100%,var(--lux-gold) 0%,transparent 40%),radial-gradient(circle at 90% 80%,var(--brand-primary) 0%,transparent 30%);opacity:.15;pointer-events:none}.landing-top-nav{position:fixed;top:0;left:0;width:100%;padding:1.25rem 3rem;display:flex;justify-content:space-between;align-items:center;z-index:999;transition:background-color .3s ease,box-shadow .3s ease}.landing-top-nav.scrolled{background-color:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:0 4px 20px #0000000d;border-bottom:1px solid var(--glass-border)}.nav-brand-placeholder{display:flex;align-items:center;margin-left:2rem}.nav-brand-text{font-size:1.25rem;font-weight:700;color:var(--brand-primary);opacity:0;animation:fadeInText .3s forwards}@keyframes fadeInText{to{opacity:1}}.nav-right{display:flex;align-items:center;gap:1.5rem}.nav-link{text-decoration:none;color:var(--text-dark);font-weight:500;font-size:1rem;transition:color .2s}.nav-link:hover{color:var(--brand-primary)}.btn-login{background-color:var(--text-dark);color:var(--ui-surface);padding:.5rem 1.25rem;border-radius:8px;text-decoration:none;font-weight:600;transition:opacity .2s}.btn-login:hover{opacity:.85}.animated-logo{position:fixed;z-index:1000;pointer-events:none;will-change:transform,top,left}.animated-logo img{width:250px;height:auto;filter:drop-shadow(0 10px 20px rgba(240,90,40,.2))}.hero-section{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 2rem}.hero-content{margin-top:220px;display:flex;flex-direction:column;align-items:center;max-width:800px}.hero-headline{font-size:3.5rem;color:var(--brand-primary);margin-bottom:1rem;line-height:1.1;letter-spacing:-.02em}.hero-subtitle{font-size:1.5rem;color:var(--text-dark);margin-bottom:2.5rem;font-weight:400;letter-spacing:-.01em}.hero-cta-group{display:flex;gap:1rem}.btn-primary,.btn-secondary{padding:1rem 2rem;border-radius:12px;font-size:1.125rem;font-weight:600;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:var(--brand-primary);color:#fff;box-shadow:0 4px 14px #f05a284d}.btn-primary:hover{background-color:var(--brand-highlight);transform:translateY(-2px);box-shadow:0 6px 20px #f05a2866}.btn-secondary{background-color:var(--ui-surface);color:var(--text-dark);border:1px solid var(--glass-border)}.btn-secondary:hover{background-color:var(--ui-base);border-color:var(--brand-secondary)}.landing-main{position:relative;z-index:10;background-color:transparent}.section-features{padding:6rem 0;background:transparent}.landing-section-title{text-align:center;font-size:2.5rem;color:var(--text-dark);margin-bottom:1rem;letter-spacing:-.02em}.landing-section-description{text-align:center;font-size:1.125rem;color:#6b7280;max-width:800px;margin:0 auto 4rem;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.glass-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border)}.feature-card{padding:2rem;border-radius:16px;transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--glass-shadow);border-color:var(--brand-secondary)}.feature-icon{font-size:2.5rem;margin-bottom:1.5rem}.feature-card h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--text-dark)}.feature-card p{color:#4b5563;line-height:1.5;font-size:.95rem}.section-roadmap{padding:6rem 0;background:transparent}.roadmap-content .landing-section-title{color:var(--brand-primary)}.roadmap-content>p{text-align:center;font-size:1.125rem;color:#6b7280;margin-bottom:4rem}.timeline{max-width:800px;margin:0 auto;position:relative}.timeline:before{content:"";position:absolute;top:0;bottom:0;left:20px;width:2px;background:var(--glass-border)}.timeline-item{position:relative;padding-left:60px;margin-bottom:3rem}.timeline-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:12px;top:6px;width:18px;height:18px;border-radius:50%;background:var(--lux-gold);border:4px solid var(--ui-base);box-shadow:0 0 0 2px var(--brand-secondary)}.timeline-card{padding:1.5rem 2rem;border-radius:16px;box-shadow:0 4px 20px #00000008}.timeline-card h4{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-dark)}.timeline-card p{margin:0;color:#4b5563;line-height:1.5}.section-forms{padding:6rem 0;background:transparent}.forms-container{display:grid;grid-template-columns:3fr 2fr;gap:2rem;align-items:start}.form-card{padding:3rem;border-radius:24px;box-shadow:var(--glass-shadow)}.form-card h3{font-size:1.75rem;color:var(--text-dark);margin-bottom:.5rem;margin-top:0}.form-card>p{color:#6b7280;margin-bottom:2rem;line-height:1.5}.form-row{display:flex;gap:1rem}.form-row>.form-group{flex:1}.styled-form .form-group{margin-bottom:1.5rem}.styled-form label{display:block;font-size:.9rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.styled-form input{width:100%;padding:.875rem 1rem;border:1px solid var(--glass-border);border-radius:8px;font-size:1rem;font-family:inherit;background:var(--ui-base);transition:border-color .2s;box-sizing:border-box}.styled-form input:focus{outline:none;border-color:var(--brand-secondary);background:var(--ui-surface)}.role-toggles{display:flex;gap:.75rem;flex-wrap:wrap}.role-toggle{background:var(--ui-base);border:1px solid var(--glass-border);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;color:var(--text-dark);cursor:pointer;transition:all .2s ease}.role-toggle.active{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.btn-submit{width:100%;padding:1rem;background:var(--brand-primary);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-submit:hover{background:var(--brand-highlight)}.btn-secondary-submit{width:100%;padding:1rem;background:var(--text-dark);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-secondary-submit:hover{opacity:.85}.form-success{background:#16a34a1a;border:1px solid rgba(22,163,74,.2);padding:2rem;border-radius:12px;text-align:center}.form-success h4{color:#16a34a;margin:0 0 .5rem;font-size:1.25rem}.form-success p{color:#15803d;margin:0}.landing-footer{border-top:1px solid var(--glass-border);padding:4rem 0 2rem;border-radius:24px 24px 0 0;margin-top:2rem}.footer-top-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;flex-wrap:wrap;gap:2rem}.footer-brand{display:flex;align-items:center;gap:1rem}.footer-icon{height:40px;width:auto}.footer-brand-name{font-size:1.5rem;font-weight:700;color:var(--brand-primary)}.footer-links{display:flex;gap:2rem}.footer-links a{color:var(--text-dark);text-decoration:none;font-weight:500;transition:color .2s}.footer-links a:hover{color:var(--brand-primary)}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid var(--glass-border);color:#9ca3af;font-size:.9rem}@media(max-width:768px){.hero-headline{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.hero-cta-group{flex-direction:column;width:100%;max-width:300px}.forms-container{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}.footer-top-row{flex-direction:column;justify-content:center;text-align:center}}.login-container{max-width:420px;margin:6rem auto;padding:3rem 2.5rem;background:#fff6;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.5);border-radius:24px;box-shadow:0 20px 40px #0000000d;color:var(--text-dark)}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--brand-primary);text-decoration:none;font-size:.95rem;margin-bottom:2rem;transition:all .2s;font-weight:500}.back-link:hover{color:var(--brand-highlight);transform:translate(-4px)}.login-container h2{margin-bottom:2rem;text-align:center;font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--brand-primary)}.login-container label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;color:var(--text-dark);opacity:.8}.login-container input{width:100%;padding:.85rem 1rem;background:#ffffffb3;border:1px solid var(--ui-border);border-radius:12px;margin-bottom:1.5rem;font-size:1rem;transition:all .3s;box-sizing:border-box}.login-container input:focus{outline:none;border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 4px #f05a281a}.login-container button{width:100%;padding:1rem;background:var(--brand-primary);border:none;border-radius:12px;color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 8px 20px #f05a2833}.login-container button:hover{background:var(--brand-highlight);transform:translateY(-2px);box-shadow:0 12px 24px #f05a284d}.error{background-color:#fee2e2;color:#dc2626;padding:1rem;border-radius:12px;margin-bottom:1.5rem;text-align:center;font-size:.9rem;font-weight:500;border:1px solid #fecaca}.dashboard{display:flex;height:100vh;font-family:Outfit,sans-serif;overflow:hidden;background-color:var(--ui-base)}.sidebar{width:260px;background:linear-gradient(180deg,var(--brand-primary) 0%,var(--brand-highlight) 100%);color:#fff;padding:2.5rem 1.5rem;display:flex;flex-direction:column;gap:1.5rem;height:100vh;box-sizing:border-box;box-shadow:4px 0 24px #0000001a;z-index:10}.sidebar h2{font-size:1.6rem;margin:0 0 1rem;letter-spacing:-.02em;font-weight:700}.sidebar-logo{color:#fff;text-decoration:none;display:block}.sidebar-logo:hover{opacity:.9}.sidebar nav{flex:1;overflow-y:auto;padding-right:5px}.sidebar nav::-webkit-scrollbar{width:4px}.sidebar nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:10px}.sidebar nav ul{list-style:none;padding:0;margin:0}.sidebar nav ul li{margin:.5rem 0}.sidebar nav ul li a{color:#ffffffb3;text-decoration:none;font-weight:500;padding:.75rem 1rem;border-radius:12px;transition:all .2s ease;display:flex;align-items:center;gap:.85rem;font-size:.95rem}.sidebar nav ul li a:hover{background:#ffffff14;color:#fff}.sidebar nav ul li a.active{background:var(--ui-surface);color:var(--brand-primary);box-shadow:0 4px 15px #f05a2826;font-weight:700;position:relative}.sidebar nav ul li a.active:before{content:"";position:absolute;left:-1.5rem;top:50%;transform:translateY(-50%);width:5px;height:24px;background:var(--opus-accent);border-radius:0 10px 10px 0;box-shadow:4px 0 12px var(--opus-accent)}.sidebar nav ul li a svg{opacity:.8;transition:opacity .2s}.sidebar nav ul li a.active svg{opacity:1}.studio-subtitle{font-size:.8rem;color:#fff9;margin-top:-1rem;margin-bottom:2rem;font-weight:400;text-transform:uppercase;letter-spacing:.1em}.logout-button{margin-top:auto;padding:.8rem;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:12px;width:100%;cursor:pointer;font-weight:600;transition:all .2s}.logout-button:hover{background:#ef444433;border-color:#ef44444d}.main-content{flex:1;padding:2.5rem;background-color:var(--ui-base);color:var(--text-dark);overflow-y:auto;position:relative}.main-content h2{font-size:2.2rem;margin-bottom:1.5rem;font-weight:700;letter-spacing:-.02em;position:relative;z-index:1}.dashboard-home{display:flex;flex-direction:column;gap:2rem;position:relative;z-index:1}.bento-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.widget{background:var(--ui-surface);border-radius:20px;padding:1.75rem;box-shadow:0 10px 30px #2b1e1a0d;border:1px solid var(--ui-border);display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease}.widget:hover{transform:translateY(-5px);box-shadow:0 12px 30px #00000014}.widget h3{margin-top:0;margin-bottom:1.25rem;font-size:1.2rem;color:var(--brand-primary);font-weight:700;display:flex;align-items:center;justify-content:space-between}.widget h3:after{content:"";width:40px;height:4px;background:var(--opus-accent);border-radius:10px;display:block;margin-top:6px;opacity:.8}.schedule-item{display:flex;justify-content:space-between;align-items:center;background:var(--ui-base);padding:1rem;border-radius:12px;border-left:4px solid var(--brand-primary);margin-bottom:.75rem}.schedule-item-details strong{display:block;color:var(--text-dark);font-size:1rem}.schedule-item-time{font-weight:700;color:var(--brand-highlight);background:#fff;border:1px solid var(--brand-secondary);padding:.3rem .6rem;border-radius:6px;font-size:.85rem}.quick-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.action-btn{background:var(--brand-primary);color:#fff;padding:1rem;border-radius:14px;text-decoration:none;text-align:center;font-weight:600;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:.9rem}.action-btn:hover{filter:brightness(1.2);transform:scale(1.02)}.action-btn.secondary{background:var(--pop-highlight);color:var(--brand-primary);box-shadow:0 8px 20px #7ae0d633}.action-btn.secondary:hover{background:#fff;color:var(--brand-primary);box-shadow:0 10px 25px #7ae0d64d}.glass-widget{background:#fff9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.4)}.account-page{max-width:700px;margin:2rem auto;padding:3rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:24px;box-shadow:var(--glass-shadow);font-family:Outfit,sans-serif}.account-page h2{margin-bottom:2.5rem;color:var(--brand-primary);font-size:2.2rem;font-weight:800;letter-spacing:-.02em;text-align:center}.account-page.editing h2:after{content:" (Editing Mode)";font-size:.9rem;font-weight:600;color:var(--brand-highlight);display:block;margin-top:.5rem}.account-form{display:flex;flex-direction:column;gap:1.75rem}.form-group{display:flex;flex-direction:column;gap:.6rem}.form-group label{font-weight:700;color:var(--text-dark);font-size:.95rem;opacity:.9}.form-group input{padding:.85rem 1.25rem;border:1px solid var(--ui-border);border-radius:12px;font-size:1rem;background:#fff9;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-dark)}.form-group input:focus{outline:none;border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 4px #f05a2814}.form-group input::placeholder{color:var(--ui-border)}.button-row{display:flex;justify-content:center;gap:1.25rem;margin-top:1.5rem}button.edit-button,button.save-button,button.cancel-button{padding:1rem 2rem;font-size:1rem;font-weight:700;border:none;border-radius:14px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #0000000d}button.edit-button{background-color:var(--brand-primary);color:#fff;width:100%;box-shadow:0 8px 20px #f05a2833}button.edit-button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 12px 24px #f05a284d}button.save-button{background-color:var(--brand-highlight);color:#fff;flex:2;box-shadow:0 8px 20px #c4452d33}button.save-button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 12px 24px #c4452d4d}button.cancel-button{background-color:var(--ui-base);color:var(--text-dark);flex:1;border:1px solid var(--ui-border)}button.cancel-button:hover{background-color:var(--ui-border);color:#fff}.editable-input{background-color:#fff!important;border:2px solid var(--brand-primary)!important;box-shadow:0 0 15px #f05a2826!important;animation:editPulse 2s infinite ease-in-out}@keyframes editPulse{0%{border-color:var(--brand-primary);box-shadow:0 0 5px #f05a2833}50%{border-color:var(--brand-highlight);box-shadow:0 0 15px #c4452d4d}to{border-color:var(--brand-primary);box-shadow:0 0 5px #f05a2833}}.readonly-input{background-color:#00000005!important;color:#555;border:1px solid rgba(0,0,0,.05)!important;cursor:default;font-weight:500}.readonly-input:focus{box-shadow:none!important;border-color:#0000000d!important}.edit-tag{font-size:.75rem;background:var(--brand-highlight);color:#fff;padding:.2rem .5rem;border-radius:6px;margin-left:.5rem;vertical-align:middle;text-transform:uppercase;letter-spacing:.05em;font-weight:800;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translate(-5px)}to{opacity:1;transform:translate(0)}}.success-toast{background-color:var(--pop-highlight);color:var(--brand-primary);padding:1.25rem 2rem;border-radius:16px;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;font-weight:700;box-shadow:0 10px 30px #d4a37333;border-left:6px solid var(--brand-primary)}.success-toast button{background:none;border:none;color:var(--brand-primary);font-size:1.5rem;cursor:pointer;line-height:1;padding:0;opacity:.6}.success-toast button:hover{opacity:1}.phone-input-wrapper{display:flex;gap:.5rem;padding:.65rem .9rem!important;background:#fff;border:1px solid var(--ui-border);border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.phone-input-wrapper .phone-country-select,.phone-input-wrapper .phone-number-input{padding:.2rem;border:none;background:transparent!important;font-size:1rem;color:inherit;outline:none}.readonly-input .phone-country-select,.readonly-input .phone-number-input{appearance:none}.phone-input-wrapper .phone-country-select{width:100px}.phone-input-wrapper .phone-country-select:disabled{opacity:1}.phone-input-wrapper .phone-number-input{flex:1;min-width:0}.phone-input-wrapper .phone-number-input::placeholder{color:#888}.roster-page{padding:2.5rem;color:var(--text-dark);font-family:Outfit,sans-serif}.roster-title{font-size:2.2rem;margin-bottom:2rem;color:var(--brand-primary);font-weight:800;letter-spacing:-.02em}.roster-table-container{overflow-x:auto;background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000008;border:1px solid rgba(0,0,0,.05)}.roster-table{width:100%;border-collapse:collapse}.roster-table th,.roster-table td{padding:1.25rem 1.5rem;text-align:left;border-bottom:1px solid var(--ui-base)}.roster-table th{background-color:#5b2a6d0d;font-weight:700;color:var(--brand-primary);text-transform:uppercase;font-size:.85rem;letter-spacing:.05em}.roster-table td{color:var(--text-dark);font-size:.95rem}.balance-positive{color:#10b981;font-weight:700}.balance-negative{color:var(--brand-highlight);font-weight:700}.roster-search{margin-bottom:1.5rem;padding:.85rem 1.2rem;width:100%;max-width:450px;font-size:1rem;background:#fff;border:1px solid var(--ui-border);border-radius:14px;outline:none;transition:all .3s;box-shadow:0 2px 8px #00000005}.roster-search:focus{border-color:var(--brand-primary);box-shadow:0 0 0 4px #5b2a6d1a}.roster-table tbody tr{transition:background-color .2s}.roster-table tbody tr:hover{background-color:var(--brand-secondary);cursor:pointer}.filter-section{display:flex;flex-direction:column;gap:1.2rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);padding:1.5rem 2rem;border-radius:20px;margin-bottom:2rem;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.filter-select,.filter-input{padding:.65rem 1rem;border:1px solid var(--ui-border);border-radius:10px;background:#fff;color:var(--text-dark);font-size:.95rem;outline:none;min-width:140px;transition:all .2s}.filter-select:focus,.filter-input:focus{border-color:var(--brand-primary)}.filter-add{padding:.65rem 1.25rem;background:var(--brand-primary);color:#fff;border:none;border-radius:10px;font-weight:700;cursor:pointer;font-size:1rem;transition:all .2s}.filter-add:hover{filter:brightness(1.2);transform:translateY(-1px)}.filter-remove{width:32px;height:32px;background:var(--brand-secondary);color:var(--brand-highlight);border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.filter-remove:hover{background:var(--brand-highlight);color:#fff}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1a1a1f66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10050}.modal-content{background:#fff;border-radius:24px;padding:2.5rem;min-width:520px;max-width:85vw;max-height:85vh;box-shadow:0 40px 100px #0000001a;border:1px solid rgba(255,255,255,.8);overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.modal-content h3{color:var(--brand-primary);font-weight:800;font-size:1.5rem;margin:0}.reports-page{padding:0;color:var(--text-dark);font-family:Outfit,sans-serif}.reports-title{font-size:2.2rem;font-weight:800;margin-bottom:2rem;color:var(--brand-primary);letter-spacing:-.02em}.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}.report-card{background:#fff;padding:2rem;border-radius:24px;box-shadow:0 4px 20px #0000000a;text-align:left;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.03);position:relative;overflow:hidden}.report-card:after{content:"";position:absolute;top:-50px;right:-50px;width:100px;height:100px;background:var(--brand-secondary);opacity:.1;border-radius:50%}.report-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #00000014}.report-card h3{font-size:1rem;margin-bottom:.75rem;color:var(--brand-primary);text-transform:uppercase;letter-spacing:.05em;font-weight:700;opacity:.8}.report-card p{font-size:2.5rem;font-weight:800;color:var(--text-dark);margin:0;letter-spacing:-.02em}.report-details-container{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:24px;padding:2.5rem;box-shadow:var(--glass-shadow)}.report-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem;gap:1.5rem;flex-wrap:wrap}.tabs{display:flex;gap:.5rem;background:#0000000d;padding:.4rem;border-radius:14px}.tab{background:none;border:none;color:var(--text-dark);font-size:.95rem;font-weight:600;cursor:pointer;padding:.6rem 1.2rem;transition:all .2s;border-radius:10px;opacity:.7}.tab.active{background:#fff;color:var(--brand-primary);box-shadow:0 4px 12px #00000014;opacity:1}.tab:hover:not(.active){opacity:1;background:#ffffff80}.export-actions{display:flex;gap:.75rem}.btn-secondary{background:#fff;color:var(--text-dark);border:1px solid var(--ui-border);padding:.6rem 1.2rem;border-radius:12px;cursor:pointer;font-weight:600;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.btn-secondary:hover:not(:disabled){background:var(--ui-base);border-color:var(--brand-primary);color:var(--brand-primary)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.report-select{background:var(--brand-primary);color:#fff;border:none;padding:.6rem 2.5rem .6rem 1.2rem;border-radius:12px;cursor:pointer;font-weight:700;transition:all .2s;font-size:.9rem;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 5 3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;box-shadow:0 4px 12px #f05a2833}.report-select:hover{filter:brightness(1.2);transform:translateY(-1px);box-shadow:0 6px 15px #f05a284d}.report-select:focus{box-shadow:0 0 0 4px #f05a2866}.attendance-filters{background:#fff6!important;border:1px solid rgba(255,255,255,.6)!important;padding:1.5rem!important;border-radius:16px!important}.filter-btn{padding:.5rem 1rem;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid transparent}.filter-btn.active{background:var(--brand-primary);color:#fff}.filter-btn.inactive{background:#fff;color:var(--text-dark);border-color:var(--ui-border)}.table-wrapper{overflow-x:auto;margin-top:1rem}.report-table{width:100%;border-collapse:separate;border-spacing:0;text-align:left}.report-table th{color:var(--brand-primary);font-weight:700;text-transform:uppercase;font-size:.75rem;letter-spacing:.1em;padding:1rem;border-bottom:2px solid var(--ui-border);opacity:.7}.report-table td{padding:1.25rem 1rem;border-bottom:1px solid rgba(0,0,0,.05);font-size:.95rem;color:var(--text-dark)}.report-table tr:last-child td{border-bottom:none}.report-table tr:hover td{background-color:#fff6}.loading-text,.empty-text{text-align:center;color:var(--ui-border);font-style:italic;padding:4rem 0;font-weight:500}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{overflow:visible;text-transform:none;-webkit-appearance:button;-moz-appearance:button;appearance:button;cursor:pointer}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{-webkit-box-sizing:border-box;box-sizing:border-box;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar *:before,.rbc-calendar *:after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{overflow:hidden;position:absolute;inset:0}.rbc-ellipsis,.rbc-show-more,.rbc-row-segment .rbc-event-content,.rbc-event-label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{overflow:hidden;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;text-align:center;vertical-align:middle;font-weight:700;font-size:90%;min-height:0;border-bottom:1px solid #ddd}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{color:inherit;background:none;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.rbc-row-content{position:relative;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{height:100%;overflow-y:scroll;-ms-overflow-style:none;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:10px;font-size:16px}.rbc-toolbar .rbc-toolbar-label{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{color:#373a3c;display:inline-block;margin:0;text-align:center;vertical-align:middle;background:none;background-image:none;border:1px solid #ccc;padding:.375rem 1rem;border-radius:4px;line-height:normal;white-space:nowrap}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px #00000020;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media(max-width:767px){.rbc-toolbar{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}}.rbc-event,.rbc-day-slot .rbc-background-event{border:none;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;margin:0;padding:2px 5px;background-color:#3174ad;border-radius:5px;color:#fff;cursor:pointer;width:100%;text-align:left}.rbc-slot-selecting .rbc-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-slot-selecting .rbc-background-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected,.rbc-day-slot .rbc-selected.rbc-background-event{background-color:#265985}.rbc-event:focus,.rbc-day-slot .rbc-background-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{-webkit-box-shadow:-1px 1px 5px 0px rgba(51,51,51,.5);box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;z-index:4;font-weight:700;font-size:85%;height:auto;line-height:normal;color:#3174ad}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{position:relative;border:1px solid #ddd;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;height:100%}.rbc-month-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-month-row{display:-webkit-box;display:-ms-flexbox;display:flex;position:relative;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px;overflow:hidden;height:100%}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:hidden;right:1px}.rbc-day-bg{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{position:absolute;z-index:5;border:1px solid #e5e5e5;background-color:#fff;-webkit-box-shadow:0 5px 15px rgba(0,0,0,.25);box-shadow:0 5px 15px #00000040;padding:10px}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{width:100%;border:1px solid #ddd;border-spacing:0;border-collapse:collapse}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{padding:3px 5px;text-align:left;border-bottom:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{-webkit-box-flex:1;-ms-flex:1;flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.rbc-time-gutter,.rbc-header-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{inset:0;position:absolute;margin-right:10px}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;display:-webkit-box;display:-ms-flexbox;display:flex;max-height:100%;min-height:20px;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column wrap;flex-flow:column wrap;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{-webkit-box-flex:0;-ms-flex:none;flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{width:100%;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;word-wrap:break-word;line-height:1;height:100%;min-height:1em}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{position:sticky;left:0;background-color:#fff;border-right:1px solid #ddd;z-index:10;margin-right:-1px}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{min-width:auto;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{width:140px;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;-ms-flex-preferred-size:0 px;flex-basis:0 px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;position:absolute;background-color:#00000080;color:#fff;font-size:75%;width:100%;padding:3px}.rbc-slot-selecting{cursor:move}.rbc-time-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1;flex:1;width:100%;border:1px solid #ddd;min-height:0}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{-webkit-box-sizing:content-box;box-sizing:content-box;width:100%;height:100%;position:relative}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{-webkit-box-sizing:border-box;box-sizing:border-box;min-height:20px}.rbc-time-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-right-width:0;border-left:1px solid #ddd}.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;min-width:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;border-left:1px solid #ddd}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;-ms-flex-negative:0;flex-shrink:0}.rbc-time-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;width:100%;border-top:2px solid #ddd;overflow-y:auto;position:relative}.rbc-time-content>.rbc-time-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none}.rbc-current-time-indicator{position:absolute;z-index:3;left:0;right:0;height:1px;background-color:#74ad31;pointer-events:none}.rbc-resource-grouping.rbc-time-header-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.schedule-container{max-width:1400px;margin:0 auto;font-family:Outfit,sans-serif}.schedule-controls{display:flex;gap:15px;margin:20px 0;align-items:center;flex-wrap:wrap;padding:1.25rem 2rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:20px;box-shadow:var(--glass-shadow)}.primary-btn{background:var(--brand-primary);color:#fff;border:none;padding:.85rem 1.5rem;border-radius:12px;cursor:pointer;font-weight:700;transition:all .3s;box-shadow:0 4px 15px #5b2a6d33}.primary-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 20px #5b2a6d4d}.filter-group{display:flex;align-items:center;gap:1rem;margin-left:auto}.filter-group label{font-weight:600;color:var(--brand-primary);font-size:.9rem}.filter-group select{padding:.65rem 1rem;border-radius:10px;border:1px solid var(--ui-border);background:#fff;color:var(--text-dark);outline:none;transition:all .3s}.filter-group select:focus{border-color:var(--brand-primary);box-shadow:0 0 0 4px #5b2a6d1a}.calendar-wrap{background:#fff;padding:2rem;border-radius:24px;box-shadow:0 4px 30px #00000008;border:1px solid rgba(0,0,0,.05)}.rbc-calendar{font-family:Outfit,sans-serif;color:var(--text-dark)}.rbc-header{font-weight:700;padding:15px;color:var(--brand-primary);border-bottom:2px solid var(--ui-base)!important}.rbc-event{border-radius:4px!important;padding:1px 4px!important;border:none!important;font-size:.78rem!important;font-weight:500!important;line-height:1.3!important;overflow:hidden!important;box-shadow:none!important}.rbc-event:hover{filter:brightness(1.15);z-index:10}.rbc-event-label{display:none!important}.rbc-toolbar button{color:var(--brand-primary)!important;border-radius:10px!important;font-weight:700!important;border:1px solid var(--ui-border)!important;padding:6px 14px!important;transition:all .2s!important}.rbc-toolbar button:hover{background-color:var(--brand-secondary)!important}.rbc-toolbar button.rbc-active{background-color:var(--brand-primary)!important;color:#fff!important;border-color:var(--brand-primary)!important;box-shadow:0 4px 12px #5b2a6d33!important}.rbc-today{background-color:#7ae0d61a!important}.gcal-event{padding:1px 2px;line-height:1.25;overflow:hidden;height:100%;display:flex;flex-direction:column}.gcal-event-title{font-weight:700;font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.gcal-event-meta{font-size:.7rem;opacity:.92;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.session-modal-overlay{position:fixed;inset:0;background:#2b1e1a66;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);display:flex;align-items:center;justify-content:center;z-index:10000;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.session-modal{background:var(--ui-surface);color:var(--text-dark);width:92%;max-width:560px;max-height:85vh;border-radius:20px;overflow-y:auto;box-shadow:0 25px 60px #00000026;border:1px solid var(--ui-border);animation:modalSlideUp .25s ease}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.session-modal-header{padding:1.5rem 1.75rem;border-bottom:1px solid var(--ui-border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--ui-surface);z-index:1}.session-modal-header h3{margin:0;font-size:1.4rem;color:var(--brand-primary);font-weight:800}.session-modal-close{background:none;border:none;color:var(--text-dark);font-size:2rem;cursor:pointer;line-height:1;padding:0;opacity:.5;transition:opacity .2s}.session-modal-close:hover{opacity:1}.session-modal-body{padding:1.5rem 1.75rem}.session-modal-body input:not([type=checkbox]),.session-modal-body select,.session-modal-body textarea{width:100%;padding:.8rem 1rem;border:1px solid var(--ui-border);border-radius:12px;background:#fffc;color:var(--text-dark);font-size:.95rem;margin-bottom:12px;box-sizing:border-box;transition:all .2s}.session-modal-body input:focus,.session-modal-body select:focus,.session-modal-body textarea:focus{outline:none;border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 4px #f05a281a}.session-modal-body label{font-size:.88rem;font-weight:700;color:var(--text-dark);display:block;margin-bottom:6px;margin-top:4px}.session-modal-body div[style*="display: flex"] label,.session-modal-body div[style*="display: flex"] input[type=checkbox]{display:inline-flex;align-items:center;margin:0;width:auto}.session-modal-body input[type=checkbox]{width:18px;height:18px;margin:0;cursor:pointer}.session-modal-footer{padding:1.25rem 1.75rem;border-top:1px solid var(--ui-border);display:flex;flex-wrap:wrap;gap:12px;position:sticky;bottom:0;background:var(--ui-surface)}.modal-save-btn{background:var(--brand-primary);color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:700;cursor:pointer;font-size:.9rem;transition:all .2s;box-shadow:0 4px 12px #f05a2833}.modal-save-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #f05a284d}.modal-cancel-btn{background:#fff;color:var(--text-dark);border:1px solid var(--ui-border);border-radius:12px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;font-size:.9rem;margin-left:auto;transition:all .2s}.modal-cancel-btn:hover{background:var(--ui-base);border-color:var(--text-dark)}.modal-cascade-btn{background:#f59e0b;color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:700;cursor:pointer;font-size:.9rem;transition:all .2s}.modal-extend-btn{background:#10b981;color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:700;cursor:pointer;font-size:.9rem;transition:all .2s}.modal-delete-btn{background:#ef4444;color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:700;cursor:pointer;font-size:.9rem;transition:all .2s}.modal-delete-series-btn{background:#b91c1c;color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:700;cursor:pointer;font-size:.9rem;transition:all .2s}.modal-danger-zone{margin-top:0;padding:1.5rem 1.75rem;border-top:1px solid #fee2e2;display:flex;flex-wrap:wrap;gap:12px;background:snow;border-bottom-left-radius:20px;border-bottom-right-radius:20px}.teacher-legend{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}.teacher-legend-item{display:flex;align-items:center;gap:5px;font-size:.8rem;font-weight:500}.teacher-legend-dot{width:12px;height:12px;border-radius:3px}@media(max-width:768px){.gcal-event-title{font-size:.68rem}.gcal-event-meta{font-size:.6rem}.session-modal{width:96%;max-width:none}}.attendance-modal-overlay{position:fixed;inset:0;background:#2b1e1a66;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);display:flex;align-items:center;justify-content:center;z-index:10000;animation:modalFadeIn .2s ease}.attendance-modal{background:var(--ui-surface);color:var(--text-dark);width:92%;max-width:600px;border-radius:20px;padding:2.5rem;box-shadow:0 25px 60px #00000026;max-height:85vh;overflow-y:auto;border:1px solid var(--ui-border);animation:modalSlideUp .25s ease}.attendance-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--ui-border);padding-bottom:1.5rem;margin-bottom:1.5rem}.attendance-header h2{margin:0;font-size:1.8rem;color:var(--brand-primary);font-weight:800}.header-actions{display:flex;gap:1rem;align-items:center}.edit-btn{background:#3b82f6;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:10px;cursor:pointer;font-weight:700;transition:all .2s}.edit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.print-btn{background:#8b5cf6;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:10px;cursor:pointer;font-weight:700;transition:all .2s}.print-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--text-dark);line-height:1;opacity:.5;transition:opacity .2s}.close-btn:hover{opacity:1}.attendance-details p{margin:.6rem 0;font-size:1.05rem;color:var(--text-dark)}.attendance-details strong{color:var(--brand-primary)}.walk-in-section{margin:2rem 0;padding:1.5rem;background:var(--ui-base);border-radius:16px;border:1px solid var(--ui-border)}.walk-in-section h4{margin-top:0;color:var(--brand-primary);font-weight:700;margin-bottom:1rem}.walk-in-controls{display:flex;gap:12px}.walk-in-controls select{flex-grow:1;padding:.8rem 1rem;border-radius:10px;border:1px solid var(--ui-border);background:#fff;color:var(--text-dark)}.add-walk-in-btn{background:var(--brand-primary);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:10px;cursor:pointer;font-weight:700;transition:all .2s}.add-walk-in-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f05a284d}.roster-table{width:100%;border-collapse:separate;border-spacing:0 8px;margin-top:1.5rem}.roster-table th{text-align:left;padding:.75rem 1rem;font-size:.9rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.roster-table td{padding:1rem;background:#fff;border-top:1px solid var(--ui-border);border-bottom:1px solid var(--ui-border)}.roster-table td:first-child{border-left:1px solid var(--ui-border);border-top-left-radius:12px;border-bottom-left-radius:12px}.roster-table td:last-child{border-right:1px solid var(--ui-border);border-top-right-radius:12px;border-bottom-right-radius:12px}.roster-table tr:hover td{background:var(--ui-base)}.status-toggle-group{display:inline-flex;background:var(--ui-base);padding:4px;border-radius:12px;border:1px solid var(--ui-border)}.status-option-btn{padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;border:none;background:transparent;color:#64748b;transition:all .2s;min-width:80px}.status-option-btn.active.present{background:var(--opus-accent);color:#fff;box-shadow:0 4px 12px var(--opus-accent-soft)}.status-option-btn.active.absent{background:#ef4444;color:#fff;box-shadow:0 4px 12px #ef444433}.status-option-btn:not(.active):hover{background:#0000000d;color:var(--text-dark)}.no-students{text-align:center;padding:3rem;color:#64748b;font-style:italic;background:var(--ui-base);border-radius:12px}.admin-create-page{max-width:800px;margin:2rem auto;padding:2.5rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:24px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.admin-create-page h2{color:var(--brand-primary);font-size:2.2rem;font-weight:800;margin-bottom:2rem;text-align:center;letter-spacing:-.02em}.create-section{padding:2rem;background:#ffffff4d;border-radius:16px;border:1px solid rgba(255,255,255,.4);margin-bottom:2rem;box-shadow:0 4px 12px #00000005}.create-section h4{margin:0 0 1.5rem;color:var(--brand-primary);font-size:1.25rem;font-weight:700}.admin-create-page label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;color:var(--text-dark)}.admin-create-page input,.admin-create-page select,.admin-create-page textarea{width:100%;padding:.8rem 1rem;background:#fff9;border:1px solid var(--ui-border);border-radius:10px;font-size:1rem;transition:all .3s;box-sizing:border-box}.admin-create-page input:focus,.admin-create-page select:focus,.admin-create-page textarea:focus{outline:none;border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 4px #5b2a6d1a}.admin-create-page .submit-btn{width:100%;padding:1.1rem;background:var(--pop-highlight);color:var(--brand-primary);border:none;border-radius:14px;font-size:1.15rem;font-weight:800;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #7ae0d666;margin-top:1.5rem;text-transform:uppercase;letter-spacing:.05em}.admin-create-page .submit-btn:hover{background:#fff;transform:translateY(-3px);box-shadow:0 15px 30px #7ae0d680}.contact-card{background:#ffffff80;border:1px solid rgba(255,255,255,.6);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;position:relative}.contact-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.contact-card-header strong{color:var(--brand-primary);font-size:.95rem}.remove-btn{background:transparent;color:#ef4444;border:none;cursor:pointer;font-size:.85rem;font-weight:600}.remove-btn:hover{text-decoration:underline}.checkbox-group{display:flex;gap:1.5rem;flex-wrap:wrap;background:#ffffff4d;padding:1rem;border-radius:10px;margin-top:1rem}.checkbox-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;font-size:.9rem!important;margin-bottom:0!important}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin:0;cursor:pointer}.studio-settings-page{max-width:600px;margin:0 auto;padding:2rem}.studio-settings-page h2{margin-bottom:2rem;color:#1a1a1a;font-size:2rem;font-weight:500}.studio-settings-page.editing h2:after{content:" (Editing)";font-size:.8rem;font-weight:400;color:#f59e0b}.studio-form{display:flex;flex-direction:column;gap:1.5rem}.studio-form .form-group textarea{padding:.75rem;border:none;border-radius:6px;font-size:1rem;resize:vertical;font-family:inherit}.costumes-page{padding:2rem;max-width:1300px;margin:0 auto}.costumes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.costumes-header h1{font-size:2rem;margin:0;color:var(--text-dark);font-weight:800}.costumes-tabs{display:flex;gap:.3rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:.35rem;border-radius:14px;border:1px solid var(--glass-border)}.costumes-tabs button{padding:.55rem 1.2rem;background:transparent;color:var(--ui-border);border:none;border-radius:10px;cursor:pointer;font-weight:700;font-size:.9rem;transition:all .25s ease}.costumes-tabs button.active{background:var(--brand-primary);color:#fff;box-shadow:0 4px 12px #f05a2826}.costumes-tabs button:not(.active):hover{color:var(--text-dark);background:#ffffff80}.costumes-action-bar{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center}.btn-create-costume{background:var(--brand-primary);color:#fff;border:none;padding:.7rem 1.4rem;border-radius:12px;cursor:pointer;font-weight:700;font-size:.9rem;transition:all .2s;box-shadow:0 4px 12px #f05a2833}.btn-create-costume:hover{filter:brightness(1.15);transform:translateY(-1px);box-shadow:0 6px 16px #f05a284d}.costume-form{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:var(--glass-shadow);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.costume-form h3{margin:0 0 1.5rem;color:var(--brand-primary);font-size:1.2rem}.costume-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.costume-form-grid.full{grid-template-columns:1fr}.costume-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;color:var(--text-dark)}.costume-form input,.costume-form textarea,.costume-form select{padding:.65rem .9rem;border:1px solid var(--ui-border);border-radius:10px;font-size:.9rem;background:#fff;color:var(--text-dark);transition:border-color .2s,box-shadow .2s;outline:none}.costume-form input:focus,.costume-form textarea:focus,.costume-form select:focus{border-color:var(--brand-primary);box-shadow:0 0 0 4px #f05a2814}.costume-form textarea{resize:vertical;min-height:60px}.costume-form-actions{margin-top:1.5rem;display:flex;gap:1rem}.btn-save{background:var(--brand-primary);color:#fff;border:none;padding:.7rem 1.5rem;border-radius:12px;cursor:pointer;font-weight:700;font-size:.9rem;transition:all .2s}.btn-cancel{background:transparent;color:var(--text-dark);border:1px solid var(--ui-border);padding:.7rem 1.5rem;border-radius:12px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s}.btn-cancel:hover{border-color:var(--brand-highlight);color:var(--brand-highlight)}.costumes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.costume-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;box-shadow:var(--glass-shadow);transition:transform .25s,box-shadow .25s;position:relative}.costume-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px #2b1e1a26}.costume-card-image{width:100%;height:180px;background:linear-gradient(135deg,var(--brand-secondary) 0%,rgba(240,90,40,.05) 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}.costume-card-image img{width:100%;height:100%;object-fit:cover}.costume-card-image .placeholder-icon{font-size:3rem;opacity:.3}.costume-card-body{padding:1.2rem 1.4rem 1.4rem}.costume-card-body h3{margin:0 0 .4rem;color:var(--text-dark);font-size:1.1rem;font-weight:700}.costume-card-body .costume-desc{color:var(--ui-border);font-size:.85rem;margin-bottom:1rem;line-height:1.4;min-height:20px}.costume-meta-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.85rem;border-top:1px solid rgba(201,204,214,.3)}.costume-meta-row:first-of-type{border-top:none}.costume-meta-row .label{color:var(--ui-border);font-weight:500}.costume-meta-row .value{color:var(--text-dark);font-weight:700}.costume-meta-row .value.fee{color:var(--brand-primary)}.availability-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-radius:20px;font-size:.78rem;font-weight:700}.availability-badge.available{background:#d4a37326;color:var(--lux-gold)}.availability-badge.limited{background:#c4452d1a;color:var(--brand-highlight)}.availability-badge.none{background:#c4452d26;color:#b91c1c}.availability-badge .dot{width:7px;height:7px;border-radius:50%;display:inline-block}.availability-badge.available .dot{background:var(--lux-gold)}.availability-badge.limited .dot{background:var(--brand-highlight)}.availability-badge.none .dot{background:#b91c1c}.costume-card-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(201,204,214,.3)}.btn-checkout{flex:1;background:var(--pop-highlight);color:var(--text-dark);border:none;padding:.55rem;border-radius:10px;cursor:pointer;font-weight:700;font-size:.85rem;transition:all .2s}.btn-checkout:hover{filter:brightness(.95);transform:translateY(-1px)}.btn-checkout:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-edit{background:transparent;color:var(--brand-primary);border:1px solid var(--brand-primary);padding:.55rem .9rem;border-radius:10px;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s}.btn-edit:hover{background:var(--brand-primary);color:#fff}.btn-delete-costume{position:absolute;top:.8rem;right:.8rem;background:#0000004d;color:#fff;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:2}.btn-delete-costume:hover{background:#ef4444}.rentals-table-wrapper{overflow-x:auto;border-radius:16px;border:1px solid var(--glass-border);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow)}.rentals-table{width:100%;min-width:800px;border-collapse:collapse}.rentals-table thead{background:#f05a280a;border-bottom:2px solid rgba(201,204,214,.3)}.rentals-table th{padding:1rem 1.2rem;text-align:left;color:var(--brand-primary);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.rentals-table td{padding:.9rem 1.2rem;border-bottom:1px solid rgba(201,204,214,.2);font-size:.9rem;color:var(--text-dark)}.rentals-table tbody tr{transition:background .15s}.rentals-table tbody tr:hover{background:#f05a2805}.status-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:700}.status-badge.checked-out{background:#c4452d1a;color:var(--brand-highlight)}.status-badge.returned{background:#d4a37326;color:var(--lux-gold)}.fee-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .7rem;border-radius:20px;font-size:.78rem;font-weight:700}.fee-badge.no-fee{color:var(--ui-border);font-weight:500}.btn-checkin{background:transparent;color:var(--pop-highlight);border:1.5px solid var(--pop-highlight);padding:.4rem .9rem;border-radius:10px;cursor:pointer;font-weight:700;font-size:.82rem;transition:all .2s}.btn-checkin:hover{background:var(--pop-highlight);color:var(--text-dark)}.btn-mark-paid{background:transparent;color:var(--brand-primary);border:1.5px solid var(--brand-primary);padding:.4rem .9rem;border-radius:10px;cursor:pointer;font-weight:700;font-size:.82rem;transition:all .2s;margin-left:.5rem}.btn-mark-paid:hover{background:var(--brand-primary);color:#fff}.costume-modal-overlay{position:fixed;inset:0;background:#1a1a1f99;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.costume-modal{background:#fff;border-radius:20px;padding:2.5rem;width:90%;max-width:500px;box-shadow:0 20px 60px #0003;animation:scaleIn .25s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.costume-modal h3{margin:0 0 1.5rem;color:var(--text-dark);font-size:1.3rem}.costume-modal label{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem;font-size:.85rem;font-weight:600;color:var(--text-dark)}.costume-modal input,.costume-modal select{padding:.65rem .9rem;border:1px solid var(--ui-border);border-radius:10px;font-size:.9rem;background:#fff;color:var(--text-dark);outline:none;transition:border-color .2s,box-shadow .2s}.costume-modal input:focus,.costume-modal select:focus{border-color:var(--brand-primary);box-shadow:0 0 0 4px #f05a281a}.costume-modal-actions{display:flex;gap:1rem;margin-top:2rem}.fee-confirmation{background:#f05a280f;border:1px solid rgba(240,90,40,.15);border-radius:12px;padding:1rem 1.2rem;margin-top:1rem}.fee-confirmation .fee-amount{font-size:1.5rem;font-weight:800;color:var(--brand-primary)}.fee-confirmation .fee-label{font-size:.85rem;color:var(--ui-border);margin-bottom:.3rem}.fee-warning-box{background:#c4452d14;border:1px solid rgba(196,69,45,.2);border-radius:12px;padding:1.2rem;margin-bottom:1.5rem;text-align:center}.fee-warning-box .warning-icon{font-size:2rem;margin-bottom:.5rem}.fee-warning-box .warning-text{font-size:.95rem;color:var(--brand-highlight);font-weight:600}.fee-warning-box .warning-amount{font-size:1.3rem;font-weight:800;color:var(--brand-highlight);margin-top:.3rem}.costumes-empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:16px;border:1px dashed var(--ui-border);color:var(--ui-border);font-style:italic}.costumes-empty .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}.costumes-fade-in{animation:costumesFadeIn .35s ease}@keyframes costumesFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.costumes-header{flex-direction:column;align-items:flex-start}.costume-form-grid,.costumes-grid{grid-template-columns:1fr}}.competitions-page{padding:2rem;font-family:IBM Plex Sans,sans-serif;max-width:1400px;margin:0 auto}.competitions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.competitions-header h1{font-size:2rem;font-weight:700;color:var(--text-dark);margin:0}.comp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem;margin-bottom:2rem}.comp-card{background:var(--ui-surface);border-radius:12px;padding:1.5rem;box-shadow:0 4px 15px #2b1e1a0d;border:1px solid var(--ui-border);transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column}.comp-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001f}.comp-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.comp-card-header h2{font-size:1.3rem;font-weight:700;color:var(--text-dark);margin:0}.comp-card-meta{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem;font-size:.9rem;color:#4b5563}.comp-card-meta span{display:flex;align-items:center;gap:.4rem}.deadline-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.deadline-pill{display:flex;justify-content:space-between;align-items:center;background:#d4a3731a;border:1px solid var(--lux-gold);border-radius:6px;padding:.4rem .75rem;font-size:.82rem;color:var(--brand-highlight)}.deadline-pill.past{background:#c4452d1f;border-color:var(--brand-highlight);color:var(--brand-highlight)}.payment-status-bar{background:var(--ui-base);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.payment-progress{height:8px;background:#2b1e1a0d;border-radius:4px;overflow:hidden;margin-top:.4rem}.payment-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.payment-status-text{display:flex;justify-content:space-between;font-size:.8rem;color:#6b7280;margin-top:.3rem}.comp-card-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--ui-border)}.comp-card-actions button{flex:1;padding:.6rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease;border:none}.btn-manage{background:var(--brand-primary);color:#fff}.btn-manage:hover{filter:brightness(1.15)}.btn-edit{background:var(--ui-surface);color:var(--text-dark);border:1px solid var(--ui-border)!important}.btn-edit:hover{background:var(--ui-base)}.btn-delete{background:#c4452d14;color:var(--brand-highlight);border:1px solid rgba(196,69,45,.2)!important}.btn-delete:hover{background:#c4452d1f}.btn-primary-comp{background:var(--brand-primary);color:#fff;border:none;padding:.7rem 1.5rem;border-radius:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #f05a2833}.btn-primary-comp:hover{filter:brightness(1.15);transform:translateY(-1px)}.comp-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.comp-modal{background:#fff;border-radius:16px;padding:2rem;width:90%;max-width:650px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.comp-modal h2{font-size:1.6rem;font-weight:800;color:var(--brand-primary);margin:0 0 1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-row.full{grid-template-columns:1fr}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group label{font-size:.85rem;font-weight:600;color:#374151}.form-group input,.form-group select,.form-group textarea{padding:.6rem .75rem;border-radius:6px;border:1px solid #d1d5db;font-size:.9rem;font-family:inherit;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 4px #f05a281a}.deadline-editor{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-bottom:1rem}.deadline-editor h4{font-size:.9rem;color:#374151;margin:0 0 .75rem}.deadline-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.5rem;margin-bottom:.5rem;align-items:end}.deadline-row input{padding:.5rem;border-radius:4px;border:1px solid #d1d5db;font-size:.85rem}.btn-remove-deadline{background:#fee2e2;color:#dc2626;border:none;border-radius:4px;width:32px;height:32px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}.btn-add-deadline{background:none;border:1px dashed #9ca3af;color:#6b7280;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;margin-top:.25rem}.btn-add-deadline:hover{border-color:#1a1a1a;color:#1a1a1a}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.btn-cancel{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-weight:600}.btn-save{background:var(--brand-primary);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:700;transition:all .2s}.btn-save:hover{filter:brightness(1.15)}.comp-detail{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.comp-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.comp-detail-header h2{margin:0;font-size:1.6rem;color:var(--text-dark)}.btn-back{background:none;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;color:#374151;display:flex;align-items:center;gap:.4rem}.btn-back:hover{background:#f3f4f6}.detail-meta{display:flex;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem;font-size:.9rem;color:#4b5563}.entries-section{margin-top:2rem}.entries-section h3{font-size:1.15rem;font-weight:700;color:#1a1a1a;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.entry-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem;margin-bottom:1rem}.entry-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.entry-card-header h4{margin:0;font-size:1.05rem;color:#1a1a1a}.entry-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#6b7280;margin-bottom:.75rem}.entry-meta span{background:#e5e7eb;padding:.2rem .5rem;border-radius:4px}.entry-students{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.entry-student-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.9rem}.entry-student-row:not(:last-child){border-bottom:1px dashed #e5e7eb}.student-name{font-weight:700;color:var(--text-dark)}.fee-badge{padding:.2rem .5rem;border-radius:4px;font-size:.78rem;font-weight:600}.fee-badge.paid{background:#d4a37326;color:var(--lux-gold)}.fee-badge.partial{background:#f7b89c26;color:var(--brand-primary)}.fee-badge.unpaid{background:#c4452d1f;color:var(--brand-highlight)}.fee-badge.no-fee{background:#f3f4f6;color:#6b7280}.payment-dashboard{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem;margin-bottom:2rem}.payment-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1rem}.payment-summary-card{background:var(--ui-surface);border-radius:12px;padding:1rem;text-align:center;border:1px solid var(--ui-border)}.payment-summary-card .label{font-size:.78rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.payment-summary-card .value{font-size:1.4rem;font-weight:700;margin-top:.25rem}.payment-summary-card .value.green{color:var(--lux-gold)}.payment-summary-card .value.yellow{color:var(--brand-primary)}.payment-summary-card .value.red{color:var(--brand-highlight)}.comp-empty{text-align:center;padding:4rem 2rem;color:#9ca3af}.comp-empty h3{font-size:1.2rem;color:#6b7280;margin-bottom:.5rem}.add-student-inline{display:flex;gap:.5rem;margin-top:.75rem;align-items:center}.add-student-inline select,.add-student-inline input{padding:.45rem .6rem;border-radius:4px;border:1px solid #d1d5db;font-size:.85rem}.add-student-inline select{flex:2}.add-student-inline input{flex:1;max-width:100px}.btn-add-sm{background:var(--brand-primary);color:#fff;border:none;padding:.45rem .8rem;border-radius:6px;font-size:.85rem;cursor:pointer;white-space:nowrap;font-weight:700}.btn-add-sm:hover{filter:brightness(1.15)}.btn-remove-sm{background:none;border:none;color:#dc2626;cursor:pointer;font-size:.9rem;padding:.2rem .4rem}.btn-remove-sm:hover{background:#fee2e2;border-radius:4px}.god-mode-container{padding:3rem 2rem;max-width:900px;margin:0 auto;font-family:Inter,sans-serif;color:#e2e8f0;animation:fadeIn .8s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%{box-shadow:0 0 10px #00f0ff33,inset 0 0 10px #00f0ff1a}50%{box-shadow:0 0 20px #00f0ff80,inset 0 0 15px #00f0ff33}to{box-shadow:0 0 10px #00f0ff33,inset 0 0 10px #00f0ff1a}}@keyframes glitchLine{0%{width:0%;left:0}50%{width:100%;left:0}to{width:0%;left:100%}}.god-header{text-align:center;margin-bottom:3rem;position:relative;padding-bottom:1rem}.god-title{font-family:Share Tech Mono,monospace;font-size:3rem;margin:0;color:#fff;text-transform:uppercase;letter-spacing:4px;text-shadow:0 0 10px rgba(0,240,255,.8)}.god-subtitle{color:#94a3b8;font-size:1.1rem;letter-spacing:1px}.god-header:after{content:"";position:absolute;bottom:0;left:0;height:2px;background:#00f0ff;animation:glitchLine 3s infinite linear}.god-section{background:#0f172acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(0,240,255,.3);border-radius:16px;padding:2.5rem;margin-bottom:3rem;box-shadow:0 8px 32px #00000080;transition:transform .3s ease,border-color .3s ease}.god-section:hover{border-color:#00f0ffcc;transform:translateY(-5px)}.section-title{font-family:Share Tech Mono,monospace;font-size:1.5rem;color:#00f0ff;margin-top:0;margin-bottom:2rem;display:flex;align-items:center;gap:15px}.section-title:before{content:">>";color:#3b82f6}.god-grid{display:grid;grid-template-columns:minmax(200px,1fr) minmax(200px,1fr);gap:1.5rem}.god-fieldset{grid-column:1 / -1;background:#0000004d;padding:1.5rem;border-radius:12px;border-left:4px solid #3b82f6}.god-fieldset.credentials{border-left-color:#10b981}.god-fieldset h4{margin:0 0 1.5rem;color:#cbd5e1;font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.85rem}.input-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.god-input{background:#0f172ae6;border:1px solid #334155;color:#00f0ff;padding:1rem;border-radius:8px;width:100%;font-family:Share Tech Mono,monospace;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.god-input::placeholder{color:#475569}.god-input:focus{outline:none;border-color:#00f0ff;box-shadow:0 0 15px #00f0ff33;background:#000}.god-select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2300f0ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1em}.god-label{display:block;margin-bottom:.8rem;color:#94a3b8;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.god-btn{grid-column:1 / -1;background:transparent;color:#00f0ff;border:2px solid #00f0ff;padding:1.2rem;border-radius:12px;font-family:Share Tech Mono,monospace;font-size:1.2rem;font-weight:700;letter-spacing:2px;cursor:pointer;text-transform:uppercase;transition:all .3s ease;margin-top:1rem;position:relative;overflow:hidden}.god-btn:hover:not(:disabled){background:#00f0ff1a;box-shadow:0 0 20px #00f0ff66}.god-btn:active:not(:disabled){transform:scale(.98)}.god-btn:disabled{border-color:#334155;color:#475569;cursor:not-allowed;background:#00000080}.god-btn-execute{background:#10b9811a;color:#10b981;border-color:#10b981;animation:pulseGlow 2s infinite}.god-btn-execute:hover:not(:disabled){background:#10b98133;box-shadow:0 0 25px #10b98199}.terminal-box{margin-top:2rem;background:#000;border:1px solid #334155;border-radius:12px;overflow:hidden;font-family:Share Tech Mono,monospace}.terminal-header{background:#1e293b;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #334155}.terminal-title{margin:0;color:#00f0ff;font-size:1.1rem}.terminal-body{padding:1.5rem}.terminal-faults{max-height:200px;overflow-y:auto;background:#dc26261a;border:1px solid rgba(220,38,38,.3);padding:1rem;border-radius:8px;margin-bottom:1.5rem}.terminal-faults h4{margin:0 0 1rem;color:#fca5a5}.terminal-faults ul{margin:0;padding-left:1.5rem;color:#f87171;font-family:Share Tech Mono,monospace;font-size:.9rem}.terminal-guard{background:#f59e0b1a;border:1px dashed rgba(245,158,11,.5);padding:1.2rem;border-radius:8px;color:#fcd34d;margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.student-portal{display:flex;min-height:100vh;background-color:var(--ui-base);font-family:Outfit,sans-serif}.student-portal-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.2rem;color:var(--brand-primary)}.portal-sidebar{width:270px;background:linear-gradient(180deg,var(--brand-primary) 0%,#3d1c4a 100%);color:#fff;display:flex;flex-direction:column;padding:2.5rem 1.5rem;box-shadow:4px 0 24px #0000001a;z-index:10}.portal-sidebar h2{font-size:1.6rem;font-weight:800;margin-bottom:.5rem;color:#fff;letter-spacing:-.02em}.role-badge{background:#ffffff26;padding:.35rem .85rem;border-radius:8px;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;display:inline-block;margin-bottom:2.5rem;align-self:flex-start;font-weight:700;border:1px solid rgba(255,255,255,.1)}.sibling-switcher{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem;background:#00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.25rem;border-radius:16px;border:1px solid rgba(255,255,255,.1)}.sibling-switcher label{font-size:.75rem;color:#fff9;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sibling-switcher select{padding:.75rem;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:.95rem;font-weight:700;outline:none;cursor:pointer;transition:all .3s}.sibling-switcher select:hover{background:#fff3}.sibling-switcher select option{color:var(--text-dark)}.portal-sidebar nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.portal-sidebar nav li{padding:.85rem 1.25rem;border-radius:12px;cursor:pointer;color:#ffffffb3;transition:all .2s;font-weight:600;display:flex;align-items:center;gap:.8rem}.portal-sidebar nav li:hover{background-color:#ffffff14;color:#fff}.portal-sidebar nav li.active{background-color:var(--brand-highlight);color:#fff;box-shadow:0 6px 15px #e94e774d}.logout-btn{margin-top:auto;background-color:#ef44441a;color:#fecaca;border:1px solid rgba(239,68,68,.2);padding:.85rem;border-radius:12px;cursor:pointer;font-weight:700;transition:all .2s;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.logout-btn:hover{background-color:#ef4444;color:#fff}.portal-content{flex:1;padding:3rem;display:flex;flex-direction:column;overflow-y:auto;position:relative}.portal-content:before{content:"";position:absolute;top:0;right:0;width:500px;height:500px;background:radial-gradient(circle,var(--brand-secondary) 0%,rgba(246,209,218,0) 70%);opacity:.3;z-index:0;pointer-events:none}.portal-content>*{position:relative;z-index:1}.portal-content header h1{font-size:2.2rem;color:var(--brand-primary);margin-bottom:2.5rem;font-weight:800;letter-spacing:-.02em}.portal-cards-dynamic{display:flex;flex-direction:column;gap:2rem}.portal-card{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 4px 20px #00000008;border:1px solid rgba(0,0,0,.04)}.portal-card h3{margin-top:0;margin-bottom:1.5rem;color:var(--brand-primary);font-size:1.4rem;font-weight:700;padding-bottom:1rem;border-bottom:2px solid var(--ui-base)}.helper-text{color:var(--text-dark);font-size:1rem;margin-bottom:2rem;line-height:1.6;opacity:.7}.portal-table{width:100%;border-collapse:collapse}.portal-table th,.portal-table td{padding:1.25rem;text-align:left;border-bottom:1px solid var(--ui-base)}.portal-table th{background-color:#5b2a6d08;color:var(--brand-primary);font-weight:700;text-transform:uppercase;font-size:.85rem;letter-spacing:.05em}.portal-table tbody tr:hover{background-color:var(--brand-secondary)}.portal-error-flag{background:#fef2f2;color:#dc2626;padding:1.25rem 2rem;border-radius:16px;border:1px solid #fecaca;font-weight:700;display:flex;align-items:center;gap:.75rem}.costumes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.costume-item{border:1px solid rgba(0,0,0,.05);border-radius:20px;padding:2rem;background:#fff;box-shadow:0 4px 12px #00000005;transition:all .3s}.costume-item:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0000000f}.costume-item h4{margin:0 0 .5rem;color:var(--brand-primary);font-weight:700;font-size:1.2rem}.costume-item .desc{color:var(--text-dark);font-size:.9rem;margin-bottom:1.5rem;opacity:.7}.costume-meta{display:flex;flex-direction:column;gap:.5rem;font-size:.95rem;background:var(--ui-base);padding:1.25rem;border-radius:12px;border:1px solid var(--ui-border)}.billing-header{display:flex;justify-content:space-between;align-items:center;background:#7ae0d61a;padding:2.5rem;border-radius:24px;border:1px solid rgba(122,224,214,.3)}.balance-box span{color:var(--brand-primary);font-weight:700;text-transform:uppercase;font-size:.85rem;letter-spacing:.1em}.balance-box h1{margin:.5rem 0 0;font-size:3.5rem;color:var(--brand-primary);font-weight:800;letter-spacing:-.04em}.pay-now-btn{background:var(--brand-highlight);color:#fff;border:none;padding:1.1rem 2.5rem;border-radius:16px;font-size:1.2rem;font-weight:800;cursor:pointer;box-shadow:0 10px 25px #e94e774d;transition:all .3s}.pay-now-btn:hover{filter:brightness(1.1);transform:translateY(-3px);box-shadow:0 15px 35px #e94e7766}.enroll-btn{background:var(--brand-primary);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 10px #5b2a6d33}.enroll-btn:hover{filter:brightness(1.2);transform:scale(1.05)}
