@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.page-not-found{min-height:100vh;display:flex;flex-direction:column;background-color:var(--off-white);position:relative;overflow:hidden}.not-found-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 24px;text-align:center;position:relative;z-index:1}.not-found-bg-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(199,146,62,.08) 0%,transparent 70%);pointer-events:none;z-index:0;border-radius:50%}.not-found-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}.not-found-404{font-size:clamp(6rem,15vw,12rem);font-weight:900;color:var(--gray-900);letter-spacing:-.05em;line-height:1;margin-bottom:16px;text-shadow:0 12px 32px rgba(0,0,0,.04)}.not-found-title{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:800;color:var(--accent);margin-bottom:24px;letter-spacing:-.02em}.not-found-desc{font-size:1.15rem;color:var(--gray-600);max-width:500px;margin:0 auto 40px;line-height:1.6}.not-found-btn{display:inline-flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--gray-800) 0%,var(--gray-900) 100%);color:var(--white);padding:16px 36px;border-radius:50px;font-weight:700;font-size:1.1rem;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 8px 24px #00000014}.not-found-btn:hover{transform:translateY(-4px);box-shadow:0 16px 32px #0000001f;background:linear-gradient(135deg,var(--gray-900) 0%,#000 100%)}.primary-btn,.secondary-btn{padding:.8rem 1.5rem;border-radius:.75rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;font-family:inherit;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.primary-btn{background:var(--accent);color:#fff;box-shadow:0 4px 15px var(--accent-glow);border:1px solid rgba(255,255,255,.1)}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.primary-btn.danger{background:var(--red);box-shadow:0 4px 15px var(--red-glow)}.secondary-btn.danger{color:var(--red);border-color:#ef44444d}.secondary-btn.danger:hover{background:#ef44441a;border-color:var(--red)}.secondary-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);box-shadow:0 2px 8px #00000005}.secondary-btn:hover{background:var(--surface-hover);border-color:var(--text-dim)}.secondary-btn.big,.primary-btn.big{padding:1rem 2rem;font-size:1.2rem}.music-app{--bg: #f7f7f5;--bg2: #ffffff;--bg3: #f0eeeb;--surface: rgba(255, 255, 255, .88);--surface-hover: rgba(255, 255, 255, .96);--border: rgba(0, 0, 0, .06);--border-hover: rgba(0, 0, 0, .12);--text: #1a1a1a;--text-dim: #6a6a6a;--text-muted: #b0b0b0;--accent: #c7923e;--accent2: #d9ab5e;--accent-glow: rgba(199, 146, 62, .25);--accent-bg: rgba(199, 146, 62, .06);--green: #22c55e;--green-glow: rgba(34, 197, 94, .25);--amber: #f59e0b;--red: #ef4444;--red-glow: rgba(239, 68, 68, .25);--dark: #0e0e12;--dark-card: #16161e;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden;overflow-y:auto;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;cursor:auto!important;z-index:9999}.music-app *,.music-app *:before,.music-app *:after{box-sizing:border-box;margin:0;padding:0;cursor:inherit}.back-btn{position:absolute;top:1rem;left:1rem;background:none;border:none;color:var(--text-dim);font-size:.9rem;cursor:pointer;padding:.5rem 1rem;border-radius:.5rem;transition:all .2s;font-family:inherit;z-index:10}.back-btn:hover{color:var(--text);background:var(--surface)}.back-link{color:var(--text-muted);text-decoration:none;font-size:.85rem;margin-top:2rem;transition:color .2s}.back-link:hover{color:var(--text-dim)}.primary-btn{width:100%;padding:1rem 2rem;background:var(--text);color:#fff;border:none;border-radius:8px;font-size:1.05rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.primary-btn:hover:not(:disabled){background:#2a2a2a;transform:translateY(-1px);box-shadow:0 4px 16px #0000001f}.primary-btn:disabled{opacity:.4;cursor:not-allowed}.primary-btn.big{font-size:1.3rem;padding:1.2rem 3rem;max-width:400px}.error-msg{color:var(--red);font-size:.85rem;margin:.5rem 0;text-align:center}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.8}to{transform:scale(1.5);opacity:0}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-8px)}80%{transform:translate(8px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow),0 0 80px var(--accent-glow)}}.role-select-screen{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:var(--bg);position:relative;overflow:hidden}.role-select-screen:before{content:"";position:absolute;top:-40%;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(199,146,62,.12),transparent 70%);pointer-events:none}.role-select-header{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;margin-bottom:3rem;width:100%}.app-logo{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}.app-title{font-size:clamp(2.5rem,7vw,4rem);font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1.1}.app-subtitle{color:var(--text-dim);font-size:1rem;margin-top:.5rem}.role-buttons{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:360px}.role-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1.5rem;background:var(--bg2);border:1px solid var(--border);border-radius:14px;color:var(--text);cursor:pointer;transition:all .3s;font-family:inherit;text-align:center;box-shadow:0 4px 20px #00000008}.role-btn:hover{background:var(--surface-hover);border-color:var(--border-hover);transform:translateY(-3px)}.role-btn-student:hover{box-shadow:0 8px 30px #c7923e26;border-color:var(--accent)}.role-btn-teacher:hover{box-shadow:0 8px 30px #c7923e1a;border-color:var(--accent2)}.role-icon{font-size:2.5rem}.role-label{font-size:1.2rem;font-weight:700}.role-desc{font-size:.8rem;color:var(--text-muted)}.student-join{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.join-card{width:100%;max-width:480px;background:var(--bg2);border:1px solid var(--border);box-shadow:0 20px 40px #00000008;border-radius:1.5rem;padding:2.5rem 2rem;text-align:center}.join-card h2{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.join-icon{font-size:3rem;margin-bottom:1rem}.name-input,.code-input{width:100%;padding:1rem 1.2rem;background:var(--surface);border:1.5px solid var(--border);border-radius:.75rem;color:var(--text);font-size:1.1rem;font-weight:500;font-family:inherit;outline:none;transition:all .2s;margin-bottom:1.5rem;text-align:center;box-shadow:inset 0 2px 4px #00000003}.name-input:focus,.code-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.name-input::placeholder,.code-input::placeholder{color:var(--text-muted)}.instrument-card{max-width:600px;max-height:90vh;max-height:90dvh;display:flex;flex-direction:column}.search-bar{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--border);border-radius:.75rem;padding:0 1rem;margin-bottom:1rem}.search-icon{font-size:1rem}.search-input{flex:1;padding:.8rem 0;background:none;border:none;color:var(--text);font-size:1rem;font-family:inherit;outline:none}.search-input::placeholder{color:var(--text-muted)}.search-clear{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1rem;padding:.3rem}.instrument-list{flex:1;overflow-y:auto;margin-bottom:1rem;max-height:50vh;padding-right:.5rem}.instrument-list::-webkit-scrollbar{width:4px}.instrument-list::-webkit-scrollbar-track{background:transparent}.instrument-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.instrument-category{margin-bottom:1.5rem}.category-title{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.6rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.instrument-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.instrument-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.8rem .4rem;background:var(--surface);border:2px solid transparent;border-radius:.75rem;color:var(--text);cursor:pointer;transition:all .2s;font-family:inherit}.instrument-btn:hover{background:var(--surface-hover);border-color:var(--border-hover)}.instrument-btn.selected{border-color:var(--accent);background:var(--accent-bg);box-shadow:0 0 15px var(--accent-glow)}.inst-icon{font-size:1.5rem}.inst-name{font-size:.75rem;font-weight:500}.inst-cat{font-size:.65rem;color:var(--text-muted)}.no-results{padding:2rem;text-align:center;color:var(--text-muted)}.join-btn{margin-top:.5rem}.student-waiting{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.waiting-card{width:100%;max-width:480px;background:var(--bg2);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;text-align:center;box-shadow:0 10px 40px #00000008}.pulse-circle{width:100px;height:100px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:pulse 2s ease-in-out infinite;position:relative}.pulse-circle:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:2px solid var(--accent);animation:pulse-ring 2s ease-out infinite}.waiting-icon{font-size:2.5rem}.waiting-instrument{color:var(--text-dim);margin-bottom:.3rem}.waiting-msg{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.players-list h3{font-size:.9rem;color:var(--text-dim);margin-bottom:1rem}.player-groups{display:flex;flex-direction:column;gap:.8rem;text-align:left}.player-group{background:var(--surface);border-radius:.75rem;padding:.8rem}.group-header{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;margin-bottom:.5rem}.group-count{margin-left:auto;background:var(--accent);color:#fff;font-size:.7rem;padding:.1rem .5rem;border-radius:1rem}.group-members{display:flex;flex-wrap:wrap;gap:.3rem}.member-tag{font-size:.75rem;padding:.2rem .6rem;background:var(--bg3);border-radius:1rem;color:var(--text-dim)}.member-tag.is-me{background:var(--accent-bg);color:var(--accent);font-weight:600}.student-play{height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.countdown-overlay{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.countdown-number{font-size:clamp(5rem,20vw,10rem);font-weight:900;color:var(--accent);text-shadow:0 0 40px var(--accent-glow),0 0 80px var(--accent-glow);animation:countdown-pulse 1s ease-in-out infinite;line-height:1}@keyframes countdown-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.countdown-tip{font-size:clamp(1rem,3vw,1.3rem);color:var(--text-dim);text-align:center;max-width:300px;line-height:1.4;animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.play-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.2rem;background:var(--bg2);border-bottom:1px solid var(--border)}.play-instrument{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem}.play-name{color:var(--text-dim);font-size:.85rem}.rhythm-track{position:relative;height:100px;overflow:hidden;background:var(--bg2);border-bottom:1px solid var(--border)}.rhythm-track.mirror{direction:rtl}.rhythm-notes{display:flex;align-items:center;height:100%;padding-left:50%;transition:transform .05s linear}.rhythm-note{flex-shrink:0;height:70px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:.6rem;margin:0 2px;background:#6366f10f;border:1.5px solid rgba(99,102,241,.15);position:relative;transition:all .15s}.rhythm-note .note-icon,.rhythm-note svg{height:85%!important;width:auto!important;aspect-ratio:1 / 1;max-width:90%;color:var(--text);opacity:.7}.rhythm-note.active{background:#818cf833;border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow);transform:scale(1.05)}.rhythm-note.past{opacity:.3}.rhythm-note.rest{background:#0f172a05;border-color:#0f172a14;border-style:dashed}.rhythm-note.perfect{background:#22c55e33;border-color:var(--green)}.rhythm-note.good{background:#3b82f633;border-color:#3b82f6}.rhythm-note.ok{background:#f59e0b33;border-color:var(--amber)}.rhythm-note.miss{background:#ef444426;border-color:var(--red)}.note-symbol{font-size:1.5rem}.note-score{position:absolute;bottom:-2px;font-size:.7rem;font-weight:700}.playhead{position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),var(--accent2));box-shadow:0 0 10px var(--accent-glow),0 0 20px var(--accent-glow);z-index:10}.progress-bar{height:4px;background:var(--bg3)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .1s linear;border-radius:0 2px 2px 0}.tap-area{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem;background:radial-gradient(circle at center,rgba(129,140,248,.03),transparent 60%)}.tap-circle{width:min(300px,80vw);height:min(300px,80vw);border-radius:50%;background:#6366f10a;border:4px solid rgba(99,102,241,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s;position:relative;touch-action:none;user-select:none;-webkit-user-select:none;box-shadow:0 8px 30px #00000008}.tap-circle:active,.tap-circle.pressed{transform:scale(.92);background:linear-gradient(135deg,#818cf84d,#a78bfa4d);border-color:var(--accent);box-shadow:0 0 40px var(--accent-glow),0 0 80px var(--accent-glow)}.tap-circle.perfect{border-color:var(--green)!important;box-shadow:0 0 40px var(--green-glow),0 0 80px var(--green-glow)!important}.tap-circle.good{border-color:#3b82f6!important;box-shadow:0 0 40px #3b82f64d!important}.tap-circle.miss{border-color:var(--red)!important;box-shadow:0 0 40px var(--red-glow)!important}.tap-inner{text-align:center}.tap-text{font-size:clamp(.9rem,3vw,1.2rem);font-weight:700;color:var(--text-dim);letter-spacing:.05em}.tap-hold{font-size:clamp(1.2rem,4vw,1.8rem);font-weight:900;color:var(--accent);animation:pulse .5s ease-in-out infinite}.tap-feedback{font-size:clamp(1rem,3.5vw,1.5rem);font-weight:800}.score-tally{display:flex;justify-content:center;gap:1.2rem;padding:1rem;background:var(--bg2);border-top:1px solid var(--border)}.tally-item{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.3rem}.student-play.feedback-perfect{animation:flash-green .3s}.student-play.feedback-good{animation:flash-blue .3s}.student-play.feedback-ok{animation:flash-amber .3s}.student-play.feedback-miss{animation:flash-red .3s}@keyframes flash-green{50%{background-color:#22c55e1a}}@keyframes flash-blue{50%{background-color:#3b82f61a}}@keyframes flash-amber{50%{background-color:#f59e0b1a}}@keyframes flash-red{50%{background-color:#ef44441a}}.student-results{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.results-card{width:100%;max-width:420px;background:var(--bg2);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;text-align:center;box-shadow:0 10px 40px #00000008}.results-title{font-size:1.5rem;font-weight:800;margin-bottom:1.5rem}.score-circle{position:relative;width:160px;height:160px;margin:0 auto 1.5rem}.score-ring{width:100%;height:100%}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);font-size:2.5rem;font-weight:900}.score-label{position:absolute;top:50%;left:50%;transform:translate(-50%,60%);font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.results-instrument{display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-dim)}.results-breakdown{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1.5rem}.breakdown-item{display:flex;align-items:center;gap:.5rem;padding:.6rem .8rem;background:var(--surface);border-radius:.6rem}.bd-icon{font-size:1rem}.bd-label{font-size:.8rem;color:var(--text-dim);flex:1;text-align:left}.bd-count{font-weight:700;font-size:1.1rem}.results-points{color:var(--text-dim);font-size:.9rem;margin-bottom:1.5rem}.results-points span:first-child{font-weight:700;color:var(--accent);font-size:1.2rem}.results-loading{text-align:center;color:var(--text-dim)}.teacher-login{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.login-card{width:100%;max-width:400px;background:var(--bg2);border:1px solid var(--border);border-radius:1.5rem;padding:2.5rem 2rem;text-align:center}.login-card.shake{animation:shake .5s}.login-icon{font-size:3rem;margin-bottom:1rem}.login-sub{color:var(--text-dim);margin-bottom:1.5rem;font-size:.9rem}.teacher-dashboard{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;max-width:640px;margin:0 auto;background:var(--bg)}.td-topbar{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1.2rem;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.td-logo{font-weight:800;font-size:1.15rem;letter-spacing:-.02em}.td-topbar-right{display:flex;align-items:center;gap:.6rem}.td-session-pill{background:#22c55e1f;color:var(--green);padding:.3rem .8rem;border-radius:2rem;font-size:.72rem;font-weight:600;letter-spacing:.02em}.td-exit-btn{padding:.4rem 1rem;background:#ef444414;border:1px solid rgba(239,68,68,.18);border-radius:.5rem;color:var(--red);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:500;transition:all .2s}.td-exit-btn:hover{background:#ef44442e}.td-back-btn{background:none;border:none;color:var(--text-dim);font-size:.9rem;font-weight:500;cursor:pointer;font-family:inherit;padding:.4rem 0;transition:color .2s}.td-back-btn:hover{color:var(--text)}.td-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.td-welcome-icon{font-size:4.5rem;margin-bottom:1.2rem;animation:float 3s ease-in-out infinite}.td-welcome-title{font-size:clamp(1.8rem,5vw,2.4rem);font-weight:800;color:var(--text);margin-bottom:.6rem;letter-spacing:-.03em}.td-welcome-sub{color:var(--text-dim);font-size:.95rem;max-width:320px;line-height:1.5;margin-bottom:2.5rem}.td-create-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1.1rem 2.5rem;background:var(--text);color:#fff;border:none;border-radius:12px;font-size:1.15rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .25s;box-shadow:0 4px 20px #0000001a;min-height:52px}.td-create-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #00000026}.td-create-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes td-spin{to{transform:rotate(360deg)}}.td-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:td-spin .6s linear infinite}.td-builder{flex:1;padding:1.2rem 1rem 7rem;overflow-y:auto}.td-builder-title{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.3rem}.td-builder-sub{color:var(--text-dim);font-size:.85rem;margin-bottom:1.5rem;line-height:1.4}.td-section{background:var(--bg2);border:1px solid var(--border);border-radius:14px;margin-bottom:.8rem;overflow:hidden;transition:box-shadow .3s}.td-section.open{box-shadow:0 4px 20px #0000000a}.td-section-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.2rem;background:none;border:none;cursor:pointer;font-family:inherit;color:var(--text);min-height:52px;transition:background .15s}.td-section-header:hover{background:#00000004}.td-section-left{display:flex;align-items:center;gap:.6rem}.td-section-num{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.td-section-icon{font-size:1.1rem}.td-section-title{font-size:.95rem;font-weight:700}.td-section-right{display:flex;align-items:center;gap:.5rem}.td-section-badge{font-size:.7rem;padding:.2rem .6rem;background:var(--accent-bg);color:var(--accent);font-weight:600;border-radius:2rem}.td-chevron{font-size:.9rem;color:var(--text-muted);transition:transform .2s;display:inline-block}.td-chevron.open{transform:rotate(180deg)}.td-section-body{padding:0 1.2rem 1.2rem;animation:td-fadeIn .2s ease-out}@keyframes td-fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.td-hint{font-size:.82rem;color:var(--text-dim);margin-bottom:.8rem;line-height:1.4}.td-search-bar{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:.5rem .8rem;margin-bottom:.6rem;transition:border-color .2s}.td-search-bar:focus-within{border-color:var(--accent)}.td-search-icon{font-size:1rem;flex-shrink:0}.td-search-input{flex:1;background:none;border:none;outline:none;font-family:inherit;font-size:.9rem;color:var(--text);min-height:36px}.td-search-input::placeholder{color:var(--text-muted)}.td-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:.2rem;border-radius:50%;transition:all .15s}.td-search-clear:hover{color:var(--text);background:var(--bg3)}.td-or-divider{display:flex;align-items:center;text-align:center;color:var(--text-muted);font-size:.75rem;margin:.8rem 0}.td-or-divider:before,.td-or-divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.td-or-divider span{padding:0 .8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.td-search-wrap{position:relative;margin-bottom:.8rem;border-radius:12px;padding:2px;background:linear-gradient(135deg,#8a2be2,#4169e1,#00bfff);background-size:200% 200%;animation:gradientShift 6s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.td-search-wrap .td-search-bar{margin-bottom:0;border:none;background:var(--bg)}.td-ai-badge{position:absolute;top:-10px;right:12px;background:linear-gradient(135deg,#8a2be2,#4169e1);color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:1rem;box-shadow:0 2px 8px #8a2be266;pointer-events:none}.td-ai-hero{text-align:center;padding:2rem 1.5rem;background:linear-gradient(180deg,color-mix(in srgb,#8a2be2 10%,transparent),transparent);border:1px dashed color-mix(in srgb,#4169e1 30%,transparent);border-radius:12px;margin-bottom:.6rem}.td-ai-hero-icon{font-size:2.5rem;margin-bottom:.8rem;filter:drop-shadow(0 4px 12px rgba(65,105,225,.3))}.td-ai-hero-title{font-size:1.1rem;font-weight:700;margin-bottom:.4rem;background:linear-gradient(135deg,#8a2be2,#4169e1);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.td-ai-hero-sub{color:var(--text-dim);font-size:.85rem;margin-bottom:1.5rem;line-height:1.4}.td-genre-pills{display:flex;gap:.3rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.3rem;margin-bottom:.8rem;scrollbar-width:none}.td-genre-pills::-webkit-scrollbar{display:none}.td-genre-pill{flex-shrink:0;padding:.4rem .7rem;background:var(--surface);border:1px solid var(--border);border-radius:2rem;font-family:inherit;font-size:.72rem;font-weight:600;color:var(--text-dim);cursor:pointer;transition:all .15s;min-height:32px;white-space:nowrap}.td-genre-pill:hover{background:var(--surface-hover)}.td-genre-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.td-songs-grid{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.6rem}.td-song-card{display:flex;align-items:center;gap:.6rem;padding:.7rem .8rem;background:linear-gradient(135deg,color-mix(in srgb,var(--preset-color) 6%,transparent),transparent);border:1.5px solid color-mix(in srgb,var(--preset-color) 15%,transparent);border-radius:10px;cursor:pointer;font-family:inherit;color:var(--text);transition:all .15s;text-align:left;width:100%;min-height:48px}.td-song-card:hover{transform:translateY(-1px);box-shadow:0 4px 14px color-mix(in srgb,var(--preset-color) 12%,transparent);border-color:color-mix(in srgb,var(--preset-color) 35%,transparent)}.td-song-card:active{transform:scale(.98)}.td-song-emoji{font-size:1.3rem;flex-shrink:0;width:28px;text-align:center}.td-song-info{flex:1;display:flex;flex-direction:column;gap:.05rem;min-width:0}.td-song-name{font-size:.85rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.td-song-artist{font-size:.7rem;color:var(--text-muted);font-weight:500}.td-song-bpm{font-size:.72rem;font-weight:700;color:var(--text-dim);background:var(--surface);padding:.2rem .5rem;border-radius:1rem;flex-shrink:0}.td-ai-section{text-align:center;padding:1.5rem 1rem;background:var(--surface);border-radius:12px;margin-bottom:.6rem}.td-ai-text{color:var(--text-dim);font-size:.85rem;margin-bottom:1rem}.td-ai-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.5rem;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px}.td-ai-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}.td-ai-btn:disabled{opacity:.6;cursor:not-allowed}.td-ai-error{color:var(--red);font-size:.78rem;margin-top:.8rem}.td-ai-alt{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 0;margin-bottom:.4rem;font-size:.78rem;color:var(--text-muted)}.td-ai-link{background:none;border:none;color:var(--accent);font-family:inherit;font-weight:600;font-size:.78rem;cursor:pointer;padding:.3rem .5rem;border-radius:4px;transition:all .15s}.td-ai-link:hover{background:var(--accent-bg)}.td-ai-link:disabled{opacity:.5}.td-custom-bar{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.8rem 1rem;background:var(--surface);border:1.5px dashed var(--border);border-radius:10px;cursor:pointer;font-family:inherit;font-size:.88rem;font-weight:600;color:var(--text);transition:all .15s;min-height:48px}.td-custom-bar:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.td-note-cat{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.4rem;margin-top:.2rem}.td-note-cat:first-of-type{margin-top:0}.td-tempo-display{display:flex;align-items:baseline;justify-content:center;gap:.3rem;margin-bottom:1rem}.td-tempo-bpm{font-size:2.8rem;font-weight:900;letter-spacing:-.04em;color:var(--text);line-height:1}.td-tempo-unit{font-size:.9rem;font-weight:600;color:var(--text-dim);margin-right:.6rem}.td-tempo-zone{font-size:.78rem;font-weight:600;color:var(--accent);background:var(--accent-bg);padding:.2rem .7rem;border-radius:2rem}.td-bpm-slider{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(90deg,var(--bg3),var(--accent-bg),var(--bg3));border-radius:4px;outline:none;margin-bottom:.4rem}.td-bpm-slider::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));cursor:pointer;box-shadow:0 2px 10px var(--accent-glow);border:3px solid #fff}.td-tempo-labels{display:flex;justify-content:space-between;font-size:.65rem;color:var(--text-muted);margin-bottom:.8rem;padding:0 2px}.td-tempo-nudge{display:flex;justify-content:center;gap:.5rem}.td-tempo-nudge button{padding:.5rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .15s;min-height:40px;min-width:52px}.td-tempo-nudge button:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}.td-tempo-nudge button:active{transform:scale(.95)}.td-tab-bar{display:flex;background:var(--bg3);border-radius:10px;padding:3px;margin-bottom:.8rem}.td-tab{flex:1;padding:.55rem 1rem;background:none;border:none;border-radius:8px;font-family:inherit;font-size:.88rem;font-weight:600;color:var(--text-dim);cursor:pointer;transition:all .2s;min-height:40px}.td-tab.active{background:var(--bg2);color:var(--text);box-shadow:0 1px 4px #0000000f}.td-note-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem;margin-bottom:1rem}.td-note-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.7rem .4rem;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit;min-height:48px}.td-note-btn:hover{background:var(--surface-hover);border-color:var(--accent);transform:translateY(-1px)}.td-note-btn:active{transform:scale(.95);background:var(--accent-bg)}.td-note-btn.rest{border-style:dashed}.td-note-btn .note-icon-lg{height:24px;width:auto}.td-note-label{font-size:.62rem;color:var(--text-dim);font-weight:500;text-align:center;line-height:1.1}.td-preview{background:var(--surface);border-radius:10px;padding:.8rem}.td-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.78rem;color:var(--text-dim);font-weight:500;flex-wrap:wrap;gap:.4rem}.td-preview-actions{display:flex;gap:.3rem}.td-small-btn{padding:.3rem .7rem;background:var(--bg2);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);cursor:pointer;font-family:inherit;font-size:.72rem;font-weight:500;transition:all .15s;min-height:30px}.td-small-btn:hover{background:var(--surface-hover);color:var(--text)}.td-small-btn:disabled{opacity:.3;cursor:not-allowed}.td-small-btn.danger:hover{border-color:var(--red);color:var(--red)}.td-preview-notes{display:flex;flex-wrap:wrap;gap:3px;min-height:44px;align-items:center}.td-preview-empty{color:var(--text-muted);font-size:.82rem;text-align:center;width:100%;padding:.5rem 0}.td-pnote{flex-shrink:0;height:38px;display:flex;align-items:center;justify-content:center;background:#c7923e14;border:1px solid rgba(199,146,62,.2);border-radius:5px}.td-pnote.rest{background:#00000005;border-style:dashed;border-color:#00000014}.td-pnote .note-icon,.td-pnote svg{height:70%!important;width:auto!important;max-width:85%;color:var(--text);opacity:.65}.td-setting-group{margin-bottom:1.5rem}.td-setting-group:last-child{margin-bottom:0}.td-setting-label{font-size:.9rem;font-weight:700;margin-bottom:.2rem}.td-setting-desc{font-size:.78rem;color:var(--text-dim);margin-bottom:.8rem;line-height:1.3}.td-diff-row{display:flex;gap:.5rem}.td-diff-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.8rem .4rem;background:var(--surface);border:2px solid transparent;border-radius:12px;cursor:pointer;font-family:inherit;color:var(--text);transition:all .2s;min-height:48px}.td-diff-card:hover{background:var(--surface-hover);border-color:var(--border-hover)}.td-diff-card.active{border-color:var(--accent);background:var(--accent-bg);box-shadow:0 0 14px var(--accent-glow)}.td-diff-emoji{font-size:1.4rem}.td-diff-name{font-size:.82rem;font-weight:700}.td-diff-desc{font-size:.62rem;color:var(--text-muted);text-align:center;line-height:1.2}.td-disasters{display:flex;flex-direction:column;gap:.5rem}.td-disaster-row{display:flex;align-items:center;gap:.8rem;padding:.8rem 1rem;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;cursor:pointer;font-family:inherit;color:var(--text);transition:all .2s;text-align:left;width:100%;min-height:48px}.td-disaster-row:hover{background:var(--surface-hover)}.td-disaster-row.active{border-color:var(--amber);background:#f59e0b0f}.td-disaster-icon{font-size:1.4rem;flex-shrink:0}.td-disaster-info{flex:1;display:flex;flex-direction:column;gap:.1rem}.td-disaster-name{font-weight:600;font-size:.88rem}.td-disaster-desc{font-size:.72rem;color:var(--text-muted);line-height:1.3}.td-toggle{width:42px;height:24px;border-radius:12px;background:var(--bg3);border:1px solid var(--border);position:relative;transition:all .25s;flex-shrink:0}.td-toggle.on{background:var(--green);border-color:var(--green)}.td-toggle-dot{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .25s;box-shadow:0 1px 3px #0000001a}.td-toggle.on .td-toggle-dot{transform:translate(18px)}.td-footer{position:fixed;bottom:0;left:0;right:0;padding:.8rem 1rem;padding-bottom:max(.8rem,env(safe-area-inset-bottom));background:var(--bg2);border-top:1px solid var(--border);box-shadow:0 -4px 20px #0000000f;z-index:100;display:flex;justify-content:center}.td-lobby-btn{width:100%;max-width:600px;padding:1rem 2rem;background:var(--text);color:#fff;border:none;border-radius:12px;font-size:1.05rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;min-height:52px}.td-lobby-btn:hover:not(:disabled){background:#2a2a2a;transform:translateY(-1px);box-shadow:0 4px 16px #0000001f}.td-lobby-btn:disabled{opacity:.35;cursor:not-allowed}.td-lobby{flex:1;padding:1.5rem 1rem;overflow-y:auto}.td-lobby-title{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.3rem}.td-lobby-sub{color:var(--text-dim);font-size:.85rem;margin-bottom:1.5rem;line-height:1.4}.td-code-box{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.8rem 1.5rem;background:var(--bg2);border:2px solid var(--border);border-radius:18px;margin-bottom:1rem;box-shadow:0 4px 20px #00000008}.td-code-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted)}.td-code-digits{font-size:clamp(3rem,12vw,5rem);font-weight:900;letter-spacing:.15em;color:var(--accent);font-family:SF Mono,Fira Code,Cascadia Code,monospace;line-height:1;text-shadow:0 2px 12px var(--accent-glow)}.td-code-url{font-size:.78rem;color:var(--text-dim);font-weight:500}.td-summary-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1.5rem}.td-summary-item{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.7rem .4rem;background:var(--bg2);border:1px solid var(--border);border-radius:10px}.td-summary-val{font-size:1.2rem;font-weight:800;color:var(--text)}.td-summary-label{font-size:.65rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.td-players-section{margin-bottom:1.5rem}.td-players-heading{font-size:1rem;font-weight:700;margin-bottom:.8rem}.td-no-players{text-align:center;padding:2rem 1rem;color:var(--text-dim)}.td-waiting-pulse{width:70px;height:70px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.8rem;animation:pulse 2s ease-in-out infinite;position:relative}.td-waiting-pulse:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:2px solid var(--accent);animation:pulse-ring 2s ease-out infinite}.td-player-groups{display:flex;flex-direction:column;gap:.6rem}.td-pgroup{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:.8rem}.td-pgroup-header{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.88rem;margin-bottom:.5rem}.td-pgroup-count{margin-left:auto;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:1rem}.td-pgroup-chips{display:flex;flex-wrap:wrap;gap:.4rem}.td-player-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:.8rem;font-weight:500;transition:background .15s}.td-player-chip:hover{background:var(--surface-hover)}.td-ping-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.td-player-name{font-weight:600;font-size:.8rem}.td-kick-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.7rem;padding:.1rem .25rem;border-radius:4px;transition:all .15s;margin-left:.1rem}.td-kick-btn:hover{color:var(--red);background:#ef444414}.td-start-area{text-align:center;padding-top:.5rem}.td-start-btn{width:100%;max-width:400px;margin:0 auto;display:block;padding:1.2rem 2rem;background:var(--text);color:#fff;border:none;border-radius:14px;font-size:1.3rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .25s;animation:glow 2.5s ease-in-out infinite;min-height:56px}.td-start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #00000026}.td-start-btn:disabled{opacity:.35;cursor:not-allowed;animation:none}.td-start-hint{color:var(--text-muted);font-size:.8rem;margin-top:.8rem}@media (min-width: 768px){.teacher-dashboard{max-width:720px}.td-presets-row{grid-template-columns:repeat(4,1fr)}.td-note-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}@media (max-width: 380px){.td-presets-row{grid-template-columns:1fr}.td-diff-row{flex-direction:column}.td-summary-strip{grid-template-columns:repeat(2,1fr)}.td-tempo-nudge button{padding:.4rem .7rem;min-width:44px;font-size:.8rem}}.teacher-game{height:100vh;height:100dvh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg),var(--bg3));overflow:hidden}.tg-topbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg2);border-bottom:1px solid var(--border)}.tg-info{display:flex;gap:2rem}.tg-bpm{font-weight:700;font-size:1.2rem}.tg-progress{color:var(--accent);font-weight:600;font-size:1.2rem}.end-game-btn{padding:.6rem 1.5rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:var(--red);cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.end-game-btn:hover{background:#ef44444d}.tg-rhythm-display{flex:2;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--bg2);border-bottom:1px solid var(--border)}.tg-rhythm-track{width:100%;height:100%;position:relative;overflow:hidden}.tg-rhythm-notes{display:flex;align-items:center;height:100%;padding-left:10%}.tg-note{flex-shrink:0;height:85%;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:1rem;background:#6366f10a;border:2px solid rgba(99,102,241,.12);box-sizing:border-box;transition:all .15s;overflow:hidden}.tg-note .tg-note-icon-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex:1;padding:8%}.tg-note .note-icon{height:80%!important;width:auto!important;aspect-ratio:1 / 1;max-width:85%;color:var(--text);opacity:.8}.tg-note.active{background:#6366f11f;border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow);transform:scale(1.03)}.tg-note.active .note-icon{color:var(--accent);opacity:1;filter:drop-shadow(0 0 8px var(--accent-glow))}.tg-note.past{opacity:.15}.tg-note.rest{background:#0f172a05;border-style:dashed;border-color:#0f172a1a}.tg-note-symbol{font-size:clamp(3rem,6vw,6rem)}.tg-note-label{font-size:clamp(.6rem,1vw,.9rem);color:var(--text-muted);margin-top:.2rem;font-weight:500;text-align:center;white-space:nowrap}.tg-playhead{position:absolute;left:10%;top:3%;bottom:3%;width:3px;background:linear-gradient(180deg,var(--accent),var(--accent2));box-shadow:0 0 12px var(--accent-glow),0 0 24px var(--accent-glow);border-radius:2px;z-index:10}.tg-progress-bar{height:6px;background:var(--bg3)}.tg-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2),#c084fc);transition:width .1s linear}.tg-groups{display:flex;flex-wrap:wrap;gap:1rem;padding:1.5rem 2rem;justify-content:center;overflow-y:auto;flex:1}.tg-group-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1rem 1.5rem;background:var(--bg2);border:2px solid var(--border);border-radius:1rem;min-width:140px;transition:all .3s}.tg-group-card.great{border-color:var(--green);box-shadow:0 0 15px var(--green-glow)}.tg-group-card.ok{border-color:var(--amber);box-shadow:0 0 15px #f59e0b33}.tg-group-card.struggling{border-color:var(--red);box-shadow:0 0 15px var(--red-glow)}.tg-group-icon{font-size:2rem}.tg-group-name{font-weight:700;font-size:1rem}.tg-group-count{font-size:.75rem;color:var(--text-dim)}.tg-group-status{font-size:1.5rem}.tg-group-mistakes{font-size:.7rem;color:var(--text-muted)}.teacher-results{min-height:100vh;min-height:100dvh;padding:2rem;max-width:900px;margin:0 auto}.tr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.tr-header h1{font-size:clamp(2rem,4vw,3rem);font-weight:900}.tr-header .primary-btn{flex-shrink:0}.tr-podium{margin-bottom:2rem}.podium-cards{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.podium-card{background:var(--bg2);border:1px solid var(--border);box-shadow:0 10px 30px #0000000a;border-radius:1.25rem;padding:1.5rem 2rem;text-align:center;min-width:160px;transition:transform .3s}.podium-card.rank-1{border:1.5px solid #fbbf24;box-shadow:0 15px 40px #fbbf2426;transform:scale(1.08)}.podium-card.rank-2{border-color:silver}.podium-card.rank-3{border-color:#cd7f32}.podium-medal{font-size:2rem;margin-bottom:.3rem}.podium-icon{font-size:1.8rem}.podium-name{font-size:1.1rem;font-weight:700;margin:.2rem 0}.podium-score{font-size:.9rem;color:var(--accent);font-weight:600}.podium-players{font-size:.75rem;color:var(--text-dim)}.tr-leaderboard{display:flex;flex-direction:column;gap:.4rem;margin-bottom:2rem}.tr-player-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg2);border:1px solid var(--border);border-radius:1rem;transition:all .2s;box-shadow:0 2px 10px #00000003}.tr-player-row:hover{background:var(--surface)}.tr-player-row.top-three{background:#818cf80f;border-color:#818cf833}.tr-rank{font-weight:700;font-size:1rem;min-width:2rem;text-align:center;color:var(--text-dim)}.tr-player-info{display:flex;flex-direction:column;min-width:100px}.tr-player-name{font-weight:600;font-size:.9rem}.tr-player-inst{font-size:.75rem;color:var(--text-dim)}.tr-player-stats{flex:1;display:flex;align-items:center;gap:.5rem}.tr-accuracy-bar{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;max-width:200px}.tr-accuracy-fill{height:100%;border-radius:3px;transition:width .5s ease}.tr-accuracy-num{font-weight:600;font-size:.85rem;min-width:3rem;text-align:right}.tr-player-points{font-size:.8rem;color:var(--text-dim);min-width:60px;text-align:right}.no-results-msg{color:var(--text-muted);text-align:center;padding:2rem}.tr-actions{text-align:center;padding:2rem 0;display:flex;justify-content:center;gap:2rem}.results-card.clean{max-width:360px}.results-message{display:flex;flex-direction:column;align-items:center;gap:.2rem;margin-bottom:.8rem}.results-emoji{font-size:2rem}.results-msg-text{font-size:1.1rem;font-weight:700;color:var(--text)}.results-breakdown.compact{display:flex;justify-content:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.results-breakdown.compact .bd-item{display:flex;flex-direction:column;align-items:center;gap:.15rem}.results-breakdown.compact .bd-num{font-size:1.2rem;font-weight:700}.results-breakdown.compact .bd-lbl{font-size:.7rem;color:var(--text-dim)}.results-points{text-align:center;margin-bottom:1.2rem;font-size:.9rem;color:var(--text-dim)}.points-value{font-size:1.4rem;font-weight:700;color:var(--accent)}.points-max{font-size:.9rem;color:var(--text-muted)}@media (max-width: 480px){.role-buttons{gap:.8rem}.role-btn{padding:1.2rem}.role-icon{font-size:2rem}.role-label{font-size:1rem}.join-card{padding:1.5rem}.instrument-grid{grid-template-columns:repeat(3,1fr)}.tap-circle{width:min(200px,55vw);height:min(200px,55vw)}.score-tally{gap:.8rem}.tally-item{font-size:.75rem}.teacher-dashboard,.dashboard-panel{padding:1rem}}@media (min-width: 1200px){.tg-note-symbol{font-size:4rem}.tg-group-card{min-width:180px;padding:1.5rem 2rem}.tg-group-icon{font-size:2.5rem}.tg-group-name{font-size:1.2rem}.tg-group-status{font-size:2rem}}.game-code-display{background:var(--bg2);border:2px solid var(--accent);border-radius:1rem;padding:2rem;text-align:center;margin-bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;box-shadow:0 0 30px #818cf826}.code-label{font-size:.9rem;color:var(--text-dim);letter-spacing:.1em;font-weight:700}.code-value{font-size:5rem;font-weight:900;color:var(--accent);letter-spacing:.2rem;line-height:1;font-variant-numeric:tabular-nums;text-shadow:0 0 20px var(--accent-glow)}.code-inst{font-size:1.1rem;margin-top:.5rem}.tg-player-chip{display:inline-flex;align-items:center;gap:.5rem;background:var(--bg3);padding:.3rem .8rem;border-radius:1rem;margin:.2rem;border:1px solid var(--border)}.tg-name{font-size:.9rem;font-weight:600}.kick-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:.2rem;line-height:1;border-radius:50%;transition:all .2s}.kick-btn:hover{background:#ef444433;color:var(--red)}.tr-actions-top{display:flex;gap:1rem}.danger-btn{background:#ef444426;color:var(--red);border:1px solid rgba(239,68,68,.3)}.danger-btn:hover{background:#ef44444d;box-shadow:0 0 15px #ef444433}.results-actions{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.waiting-msg{color:var(--text-dim);font-size:.9rem;font-style:italic;animation:pulse 2s infinite}.text-symbol{font-family:monospace;font-weight:700;letter-spacing:-2px}.code-input{background:var(--bg3);border:2px solid var(--border);border-radius:1rem;padding:1rem;font-size:2.5rem;width:200px;text-align:center;color:var(--text);margin:1.5rem 0;letter-spacing:.5rem;outline:none;transition:all .2s}.code-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.waiting-code{background:var(--bg3);padding:.5rem 1rem;border-radius:.5rem;margin:1rem 0;display:flex;flex-direction:column;align-items:center;gap:.2rem}.waiting-code span{font-size:.8rem;color:var(--text-dim)}.waiting-code strong{font-size:1.5rem;color:var(--accent);letter-spacing:.1em}.text-btn{background:none;border:none;text-decoration:underline;cursor:pointer;color:var(--text-dim);padding:.5rem}.text-btn:hover{color:var(--text)}.text-btn.danger:hover{color:var(--red)}.countdown-number{font-variant-numeric:tabular-nums;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.note-icon{display:inline-block;vertical-align:middle;fill:currentColor}.note-btn .note-icon-lg{width:2.5rem;height:2.5rem;margin-bottom:.2rem}.top-countdown{position:absolute;top:5rem;left:0;width:100%;text-align:center;font-size:2rem;font-weight:900;color:var(--accent);z-index:100;text-transform:uppercase;letter-spacing:.1em;animation:pulse 1s infinite;pointer-events:none}.tap-circle.disabled{opacity:.5;pointer-events:none;border-color:var(--text-muted);filter:grayscale(1)}.presets-section{margin-bottom:1.5rem}.preset-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.preset-btn{padding:.5rem 1rem;background:var(--bg3);border:1px solid var(--border);border-radius:.5rem;color:var(--text-dim);cursor:pointer;font-size:.85rem;transition:all .2s;font-family:inherit}.preset-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--accent)}.rhythm-actions{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.group-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.group-stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:.8rem;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.3rem;text-align:center}.group-stat-icon{font-size:1.8rem}.group-stat-name{font-size:.85rem;font-weight:600;color:var(--text-dim)}.group-stat-value{font-size:1.2rem;font-weight:700;color:var(--accent)}.disaster-void .tg-rhythm-track{mask-image:linear-gradient(to right,transparent 0%,transparent 15%,black 40%,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,transparent 15%,black 40%,black 100%)}.disaster-void .student-play .tap-circle{opacity:0}.disaster-earthquake.music-app,.disaster-earthquake.teacher-game,.disaster-earthquake.student-play,.disaster-earthquake .tg-rhythm-display,.student-play.disaster-earthquake,.tg-rhythm-display.disaster-earthquake{animation:earthquake .5s infinite linear}@keyframes earthquake{0%{transform:translate(0) rotate(0)}10%{transform:translate(-5px,-5px) rotate(-1deg)}20%{transform:translate(5px,5px) rotate(1deg)}30%{transform:translate(-5px,5px) rotate(0)}40%{transform:translate(5px,-5px) rotate(1deg)}50%{transform:translate(-5px,-5px) rotate(-1deg)}60%{transform:translate(5px,5px) rotate(0)}70%{transform:translate(-5px,5px) rotate(-1deg)}80%{transform:translate(5px,-5px) rotate(1deg)}90%{transform:translate(0) rotate(0)}to{transform:translate(0) rotate(0)}}.disaster-spin .tg-rhythm-display,.tg-rhythm-display.disaster-spin,.student-play.disaster-spin,.disaster-spin .student-play{animation:spin-cycle 10s infinite ease-in-out;transform-origin:center center}@keyframes spin-cycle{0%{transform:rotate(0) scale(1)}25%{transform:rotate(15deg) scale(.85)}50%{transform:rotate(0) scale(1)}75%{transform:rotate(-15deg) scale(.85)}to{transform:rotate(0) scale(1)}}.td-music-toggle{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:.3rem;margin-right:.5rem;border-radius:50%;transition:background .2s}.td-music-toggle:hover{background:#0000000d}.page-extras-premium{padding:0}.extras-premium-hero{position:relative;min-height:40vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--off-white);overflow:hidden;padding:80px 24px 30px}.extras-hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.extras-hero-orb-1{width:400px;height:400px;background:#e85d1a0f;top:-100px;right:-100px;animation:extrasOrbFloat 10s ease-in-out infinite alternate}.extras-hero-orb-2{width:300px;height:300px;background:#c7923e0d;bottom:-50px;left:-80px;animation:extrasOrbFloat 10s ease-in-out infinite alternate-reverse}@keyframes extrasOrbFloat{0%{transform:translate(0) scale(1)}50%{transform:translate(30px,-40px) scale(1.1)}to{transform:translate(-20px,20px) scale(.9)}}.extras-premium-hero-content{position:relative;z-index:1;opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.extras-premium-hero.visible .extras-premium-hero-content{opacity:1;transform:translateY(0)}.extras-premium-title{margin-bottom:12px}.extras-title-main{font-size:clamp(3rem,10vw,6rem);font-weight:900;letter-spacing:-.04em;line-height:1;color:var(--gray-900)}.extras-premium-subtitle{font-size:1.1rem;color:var(--gray-500);font-weight:300;font-style:italic}.extras-accent-text{color:var(--accent);font-style:normal;font-weight:500}.extras-links-grid{max-width:900px;margin:0 auto;padding:16px 24px 100px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.extras-link-card{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--gray-200);border-radius:20px;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #00000005;min-height:180px}.extras-link-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 32px #00000014;border-color:#c7923e4d}.extras-card-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 24px;width:100%;height:100%}.extras-card-content.standard{gap:20px}.extras-link-icon{color:var(--accent);flex-shrink:0}.extras-link-title{font-size:1.45rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;text-shadow:0 2px 10px rgba(255,255,255,.8)}.extras-card-subtitle{font-size:.95rem;font-weight:600;color:var(--accent);letter-spacing:.02em;text-transform:uppercase;text-shadow:0 2px 10px rgba(255,255,255,.8)}.tap-premium-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none;transition:transform .6s cubic-bezier(.16,1,.3,1)}.extras-link-card:hover .tap-premium-bg{transform:scale(1.05)}.staff-lines{opacity:.5}.staff-line-1{animation:waveSlide 8s linear infinite}.staff-line-2{animation:waveSlide 8s linear infinite reverse}.staff-line-3{animation:waveSlide 10s linear infinite}.staff-line-4{animation:waveSlide 10s linear infinite reverse}.staff-line-5{animation:waveSlide 12s linear infinite}@keyframes waveSlide{0%{stroke-dasharray:400 400;stroke-dashoffset:0}to{stroke-dasharray:400 400;stroke-dashoffset:800}}.wave{opacity:.6}.wave-1{animation:pulseWave 1.5s ease-in-out infinite alternate}.wave-2{animation:pulseWave 1.2s ease-in-out infinite alternate .2s}.wave-3{animation:pulseWave 1.8s ease-in-out infinite alternate .4s}.wave-4{animation:pulseWave 1.4s ease-in-out infinite alternate .1s}.wave-5{animation:pulseWave 1.6s ease-in-out infinite alternate .5s}.wave-6{animation:pulseWave 1.3s ease-in-out infinite alternate .3s}@keyframes pulseWave{0%{transform:scaleY(.4);transform-origin:center;opacity:.2}to{transform:scaleY(1.2);transform-origin:center;opacity:.8}}.floating-note{animation:floatNote 4s ease-in-out infinite}.fn-1{animation-delay:0s;transform-origin:80px 120px}.fn-2{animation-delay:1.5s;transform-origin:320px 100px}.fn-3{animation-delay:2.5s;transform-origin:150px 140px}.fn-4{animation-delay:.8s;transform-origin:260px 60px}@keyframes floatNote{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(4deg)}}.particle{animation:floatParticle 6s ease-in-out infinite alternate}.p-1{animation-delay:0s;animation-duration:5s}.p-2{animation-delay:1s;animation-duration:7s}.p-3{animation-delay:2s;animation-duration:6s}.p-4{animation-delay:3s;animation-duration:8s}.p-5{animation-delay:4s;animation-duration:5.5s}@keyframes floatParticle{0%{transform:translate(0) scale(1);opacity:.3}50%{transform:translate(-10px,-20px) scale(1.5);opacity:.8}to{transform:translate(15px,-35px) scale(.8);opacity:.1}}.tempotap-large-title{font-size:2.8rem;font-weight:900;letter-spacing:-.04em;color:var(--gray-900);text-shadow:0 4px 20px rgba(255,255,255,1),0 0 40px rgba(255,255,255,.5);z-index:10}.watermark-clef{animation:pulseClef 8s ease-in-out infinite alternate}@keyframes pulseClef{0%{transform:scale(1) translateY(0);opacity:.6}to{transform:scale(1.05) translateY(-5px);opacity:1}}@media (max-width: 600px){.extras-premium-hero{min-height:35vh;padding:60px 20px 30px}.extras-links-grid{padding:16px 16px 60px;grid-template-columns:1fr}.tempotap-large-title{font-size:2.2rem}}.page-contact{min-height:100vh;background-color:var(--off-white);padding-bottom:80px}.contact-hero{position:relative;padding:160px 20px 80px;display:flex;justify-content:center;align-items:center;text-align:center;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,1) 0%,var(--off-white) 100%);opacity:0;transform:translateY(20px);transition:all .8s cubic-bezier(.16,1,.3,1)}.contact-hero.visible{opacity:1;transform:translateY(0)}.contact-hero-orb{position:absolute;border-radius:50%;filter:blur(80px);z-index:0;pointer-events:none}.contact-hero-orb-1{width:300px;height:300px;background:#c7923e26;top:-50px;left:10%}.contact-hero-orb-2{width:400px;height:400px;background:#1e293b0d;bottom:-100px;right:5%}.contact-hero-content{position:relative;z-index:1;max-width:600px}.contact-hero-title{font-size:clamp(3rem,6vw,4.5rem);font-weight:900;letter-spacing:-.04em;line-height:1;margin-bottom:24px}.contact-hero-desc{font-size:1.25rem;color:var(--gray-600);line-height:1.6}.band-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#c7923e1a;color:var(--accent);border-radius:50px;font-size:.9rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:24px}.contact-form-section{max-width:800px;margin:0 auto;padding:0 24px;position:relative;z-index:2}.contact-form{background:var(--white);padding:48px;border-radius:24px;box-shadow:0 12px 48px #0000000a;border:1px solid rgba(0,0,0,.03);display:flex;flex-direction:column;gap:24px}.contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.contact-field{display:flex;flex-direction:column;gap:10px}.contact-field.full{grid-column:1 / -1}.contact-field label{font-size:.95rem;font-weight:600;color:var(--gray-700);display:flex;align-items:center;gap:8px}.contact-field .required{color:var(--accent)}.contact-field input,.contact-field select,.contact-field textarea{width:100%;padding:14px 18px;border-radius:12px;border:1px solid var(--gray-200);background:var(--off-white);font-family:Inter,sans-serif;font-size:1rem;color:var(--gray-900);transition:all .3s ease}.contact-field input:focus,.contact-field select:focus,.contact-field textarea:focus{outline:none;border-color:var(--accent);background:var(--white);box-shadow:0 0 0 4px #c7923e1a}.contact-field textarea{resize:vertical;min-height:120px}.contact-submit{margin-top:16px;background:linear-gradient(135deg,var(--gray-800) 0%,var(--gray-900) 100%);color:var(--white);border:none;padding:16px 32px;border-radius:12px;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 8px 24px #0000001a}.contact-submit:hover{transform:translateY(-2px);box-shadow:0 12px 32px #00000026;background:linear-gradient(135deg,var(--gray-900) 0%,#000 100%)}.contact-note{text-align:center;font-size:.9rem;color:var(--gray-500);margin-top:16px}.contact-note strong{color:var(--gray-800)}@media (max-width: 768px){.contact-form-row{grid-template-columns:1fr}.contact-form{padding:32px 20px}.contact-hero-title{font-size:2.5rem}}:root{--white: #ffffff;--off-white: #f7f7f5;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e8e8e8;--gray-300: #d4d4d4;--gray-400: #b0b0b0;--gray-500: #8a8a8a;--gray-600: #6a6a6a;--gray-700: #4a4a4a;--gray-800: #2a2a2a;--gray-900: #1a1a1a;--dark: #0e0e12;--dark-card: #16161e;--dark-border: #2a2a36;--accent: #c7923e;--accent-hover: #b5832f;--accent-light: #d9ab5e;--accent-bg: rgba(199, 146, 62, .06);--blue-600: #1a73e8;--blue-700: #1765cc;--blue-50: #e8f0fe;--red-500: #d93025;--red-50: #fce8e6;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius: 8px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .1);--nav-height: 64px;--severity-low: #1a73e8;--severity-medium: #c7923e;--severity-high: #d93025;--severity-low-bg: #e8f0fe;--severity-medium-bg: #fff8e1;--severity-high-bg: #fce8e6}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}::selection{background:#c7923e40;color:var(--gray-900)}::-moz-selection{background:#c7923e40;color:var(--gray-900)}html{scroll-behavior:smooth;cursor:none;scrollbar-width:none;-ms-overflow-style:none}::-webkit-scrollbar{display:none}body{font-family:var(--font);background:var(--off-white);color:var(--gray-900);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;cursor:none}.cursor-circle{width:20px;height:20px;background:#fff;border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:99999;mix-blend-mode:difference;transition:width .25s ease,height .25s ease}.cursor-circle.hovering{width:26px;height:26px}@media (hover: none) and (pointer: coarse){html,body{cursor:auto}.cursor-circle{display:none!important}}a,button,[role=button],input,select,textarea,label{cursor:none!important}h1,h2,h3,h4{font-weight:500;line-height:1.2;color:var(--gray-900)}a{text-decoration:none;color:inherit}ul{list-style:none}img{max-width:100%;display:block}button{font-family:var(--font);cursor:pointer;border:none;background:none}.container{max-width:1000px;margin:0 auto;padding:0 24px}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:var(--nav-height);padding-bottom:80px}.main-content.home-page{padding-top:0;padding-bottom:0}.page-content{padding:0;min-height:calc(100vh - var(--nav-height) - 200px)}.page-hero{background:var(--dark);padding:100px 24px 80px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.05)}.page-hero:before{content:"";position:absolute;top:-50%;left:50%;transform:translate(-50%);width:800px;height:800px;background:radial-gradient(circle,var(--page-accent, rgba(199, 146, 62, .12)),transparent 70%);pointer-events:none;animation:heroPulse 10s ease-in-out infinite alternate}@keyframes heroPulse{0%{transform:translate(-50%) scale(.9);opacity:.8}to{transform:translate(-50%) scale(1.1);opacity:1}}.page-hero .container{position:relative;z-index:1}.page-hero .page-tag{color:var(--page-accent-text, var(--accent-light));margin-bottom:16px;display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;background:#ffffff0d;padding:6px 16px;border-radius:50px;border:1px solid rgba(255,255,255,.1)}.page-hero h1{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;color:var(--white);letter-spacing:-.04em;margin-bottom:16px;line-height:1.1}.page-hero .page-desc{color:#ffffffb3;font-size:1.1rem;max-width:550px;margin:0 auto;line-height:1.7}.page-body{padding:60px 0 80px}.page-header{margin-bottom:48px}.page-tag{display:inline-block;font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--accent);letter-spacing:.12em;margin-bottom:8px}.page-desc{font-size:1.1rem;color:var(--gray-500);max-width:600px;margin-top:12px}.instrument-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.instrument-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent-bg);border:1px solid rgba(199,146,62,.15);border-radius:50px;font-size:.8rem;font-weight:500;color:var(--gray-700);transition:all .3s ease}.instrument-pill:hover{background:#c7923e1f;transform:translateY(-2px);box-shadow:0 4px 12px #c7923e1a}.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal:nth-child(2){transition-delay:.1s}.reveal:nth-child(3){transition-delay:.2s}.reveal:nth-child(4){transition-delay:.3s}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.navbar{position:fixed;top:12px;left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:900px;height:52px;background:#ffffff8c;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.35);border-radius:50px;z-index:1000;box-shadow:0 4px 24px #0000000f,0 1px 3px #0000000a;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s ease}@keyframes slideDown{0%{transform:translate(-50%) translateY(-120%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.navbar-hidden{transform:translate(-50%) translateY(-120%);opacity:0;pointer-events:none}.navbar-inner{max-width:100%;margin:0 auto;padding:0 20px;height:100%;display:flex;align-items:center;justify-content:space-between}.navbar-brand{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:500;color:var(--gray-900);z-index:1001;letter-spacing:-.01em}.brand-logo{width:28px;height:28px;object-fit:contain;border-radius:6px}.hamburger{display:none;padding:8px;color:var(--gray-700);z-index:1001}.nav-links{display:flex;align-items:center;gap:2px}.nav-link{padding:8px 14px;font-size:.8125rem;font-weight:500;color:var(--gray-500);border-radius:var(--radius);transition:color .2s;letter-spacing:.01em}.nav-link:hover{color:var(--gray-900)}.nav-dropdown{position:relative}.dropdown-toggle{display:flex;align-items:center;gap:4px}.chevron{transition:transform .2s}.chevron.rotate{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);min-width:220px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .2s}.dropdown-menu.show{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.dropdown-item{display:block;padding:12px 20px;font-size:.8125rem;color:var(--gray-600);transition:color .15s,padding-left .2s}.dropdown-item:hover{color:var(--gray-900);padding-left:24px}.nav-auth-mobile{display:none}.nav-auth-desktop{display:flex;align-items:center;gap:8px}.user-info{display:flex;align-items:center;gap:10px}.user-name{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--gray-500)}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;font-size:.8125rem;font-weight:500;border-radius:var(--radius);transition:all .2s ease;white-space:nowrap;cursor:pointer;border:none}.btn-sm{padding:8px 16px;font-size:.8125rem}.btn-primary:hover{background:var(--gray-800)}.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{border-color:var(--gray-900);color:var(--gray-900);background:var(--white)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:6px;color:var(--gray-500);border-radius:var(--radius);transition:all .15s}.btn-icon:hover{background:var(--gray-100);color:var(--gray-800)}.btn-icon-danger:hover{background:var(--red-50);color:var(--red-500)}@media (max-width: 768px){.hamburger{display:flex}.nav-links{position:fixed;top:72px;left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:900px;z-index:999;background:#ffffffd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.4);border-radius:20px;flex-direction:column;gap:4px;padding:16px;opacity:0;visibility:hidden;box-shadow:0 8px 32px #00000014;transition:opacity .3s ease,visibility .3s ease,transform .3s cubic-bezier(.16,1,.3,1);transform:translate(-50%) translateY(-12px)}.nav-links.open{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.nav-link{font-size:1rem;padding:14px 16px;color:var(--gray-700);border-radius:12px;transition:background .2s ease;text-align:center;justify-content:center}.nav-link:hover{background:#0000000a}.dropdown-menu{position:static;transform:none;box-shadow:none;border:none;background:#00000008;border-radius:12px;max-height:0;overflow:hidden;opacity:0;transition:max-height .3s,opacity .2s;text-align:center}.dropdown-menu.show{max-height:300px;opacity:1}.dropdown-item{padding:12px 24px;font-size:.9rem;border-radius:8px;justify-content:center}.nav-auth-desktop{display:none}.nav-auth-mobile{display:flex;margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.06)}}.hero{position:relative;height:calc(100vh + var(--nav-height));height:calc(100dvh + var(--nav-height));min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;margin-top:calc(-1 * var(--nav-height));margin-bottom:0;overflow:hidden}.hero-bg{position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;width:120%;height:120%;object-fit:cover;background-image:url(/background.webp);background-size:cover;background-position:center;will-change:transform;transform:scale(1.1)}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0a0a0e66,#0a0a0ea6 40%,#0a0a0ed9)}.hero-grain{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1;opacity:.5}.hero-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.4) 100%);pointer-events:none;z-index:1}.hero-content{position:relative;z-index:2;max-width:700px;padding:0 24px}.hero-eyebrow{font-size:.75rem;font-weight:500;color:var(--accent-light);letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px}.hero-title{display:flex;flex-direction:column;gap:0;margin-bottom:28px}.title-reveal{animation:titleReveal 1s cubic-bezier(.16,1,.3,1) forwards;opacity:0;transform:translateY(30px)}.title-reveal-delay{animation-delay:.3s}.title-reveal-delay-2{animation-delay:.6s}@keyframes titleReveal{to{opacity:1;transform:translateY(0)}}.title-line{display:block;font-size:clamp(3.5rem,12vw,7rem);font-weight:800;color:var(--white);letter-spacing:-.05em;line-height:.95}.title-line.accent{color:var(--accent)}.hero-subtitle{font-size:1.1rem;color:#ffffff80;margin-bottom:40px;line-height:1.7;font-weight:300;max-width:440px;margin-left:auto;margin-right:auto;letter-spacing:.02em}.hero-actions{display:flex;justify-content:center}.btn-hero-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:var(--accent);color:var(--white);font-size:.875rem;font-weight:500;font-family:var(--font);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;letter-spacing:.01em}.btn-hero-primary:hover{background:var(--accent-hover);box-shadow:0 8px 24px #c7923e4d;transform:translateY(-2px)}.btn-hero-primary svg{transition:transform .2s}.btn-hero-primary:hover svg{transform:translate(4px)}.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translate(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:6px;color:#ffffff59;font-size:.625rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;padding:8px;transition:color .3s;animation:float 3s ease-in-out infinite}.scroll-indicator:hover{color:#fff9}@keyframes float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.flow-section{padding:100px 24px;max-width:1000px;margin:0 auto}.statement{max-width:680px;margin:0 auto;text-align:center}.statement p{font-size:clamp(1.25rem,3vw,1.6rem);font-weight:300;line-height:1.7;color:var(--gray-700);letter-spacing:-.01em}.statement em{font-style:normal;color:var(--accent);font-weight:400}.section-eyebrow{display:inline-block;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);margin-bottom:16px}.typewriter-section{height:300vh;position:relative;background:var(--off-white)}.typewriter-progress-track{position:absolute;left:0;top:0;width:4px;height:100%;background:var(--gray-200)}.typewriter-progress-fill{width:100%;background:var(--accent);transition:height .2s ease;border-radius:0 0 2px 2px}.typewriter-content{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;max-width:900px;margin:0 auto;text-align:left}.typewriter-text{font-size:clamp(1.8rem,4vw,2.75rem);line-height:1.5;font-weight:400;color:var(--gray-400);text-align:left;margin:0;display:inline}.typewriter-text span{display:inline;transition:color .3s ease,opacity .3s ease}.typewriter-text .typed{color:var(--gray-900)}.typewriter-text .untyped{color:#0000000f}.typewriter-text .bold{font-weight:700}.typewriter-text .italic{font-style:italic}.cursor{display:inline-block!important;width:3px;height:1.25em;background:var(--accent);margin-left:4px;animation:blink 1s infinite;vertical-align:middle;border-radius:2px}.typewriter-hint{margin-top:24px;font-size:.6875rem;font-weight:500;color:var(--gray-400);text-transform:uppercase;letter-spacing:.12em;animation:fadeInHint 1s ease-out 1s both}@keyframes fadeInHint{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.ensembles-podiums{height:300vh;position:relative;background:var(--off-white)}.podiums-sticky{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;overflow:hidden}.podiums-title{font-size:clamp(1.75rem,5vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;color:var(--gray-900);text-align:center;margin-bottom:48px}.podiums-sticky .section-eyebrow{color:var(--accent);margin-bottom:12px}.podiums-row{display:flex;gap:24px;max-width:1100px;width:100%;justify-content:center}.podium{flex:1;max-width:360px;min-height:480px;background:transparent;padding:0;text-decoration:none;color:var(--white);display:flex;flex-direction:column;position:relative;will-change:transform,opacity;transition:transform .4s ease}.podium:hover{transform:translateY(-12px)!important}.podium-bg-gfx{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.podium-bg-gfx svg{width:100%;height:100%;display:block;filter:drop-shadow(0 15px 40px rgba(0,0,0,.6));transition:filter .4s ease}.podium:hover .podium-bg-gfx svg{filter:drop-shadow(0 20px 50px rgba(255,255,255,.15))}.podium-content{position:relative;z-index:1;padding:70px 32px 40px;display:flex;flex-direction:column;justify-content:flex-start;height:100%}.podium-number{font-size:3.5rem;font-weight:900;color:#ffffff26;letter-spacing:-.04em;line-height:1;margin-bottom:16px}.podium-grades{display:inline-block;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--ens-accent, var(--accent));margin-bottom:12px}.podium-name{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:12px;line-height:1.2;color:var(--white)}.podium-desc{font-size:.95rem;color:#fffc;line-height:1.6;flex:1}.podium-cta{display:flex;align-items:center;gap:6px;margin-top:24px;color:var(--ens-accent, var(--accent));font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;transition:gap .3s ease}.podium:hover .podium-cta{gap:10px}@media (max-width: 768px){.podiums-row{flex-direction:column;align-items:center;gap:16px}.podium{max-width:100%;padding:28px 20px}.podiums-title{margin-bottom:28px}}.cta-frame{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border:1px solid rgba(199,146,62,.15);border-radius:16px;pointer-events:none}.stats-section{padding:100px 24px 150px;background:var(--off-white);position:relative;z-index:10;overflow-x:clip}.stats-inner{max-width:1000px;margin:0 auto;text-align:center;position:relative;z-index:2}.stats-inner:before,.stats-inner:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);z-index:0;opacity:.5;pointer-events:none;animation:statsFloat 10s ease-in-out infinite alternate}.stats-inner:before{width:400px;height:400px;background:#c7923e14;top:-100px;left:-150px}.stats-inner:after{width:300px;height:300px;background:#c7923e0a;bottom:-50px;right:-100px;animation-delay:-5s}@keyframes statsFloat{0%{transform:translate(0) scale(1)}50%{transform:translate(30px,-40px) scale(1.1)}to{transform:translate(-20px,20px) scale(.9)}}.stats-grid{display:flex;flex-direction:column;align-items:center;gap:120px;margin-top:100px}.stat-card{background:transparent;padding:80px 40px;text-align:center;width:100%;max-width:600px;position:relative;z-index:1}.stat-icon-wrap{width:52px;height:52px;border-radius:14px;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.stat-number{font-size:clamp(4rem,10vw,8rem);font-weight:800;color:var(--gray-900);text-shadow:none;letter-spacing:-.04em;line-height:1;display:block;margin-bottom:8px;font-variant-numeric:tabular-nums;transition:color .4s ease,text-shadow .4s ease}.stat-plus{color:var(--accent)}.stat-label{font-size:1rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em}@media (max-width: 768px){.stats-section{padding:60px 16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px}.stat-card{padding:28px 16px}.stat-icon-wrap{width:44px;height:44px;margin-bottom:14px}}.reveal.slide-left{transform:translate(-60px) translateY(0)}.reveal.slide-left.revealed{transform:translate(0) translateY(0)}.reveal.slide-left:nth-child(1){transition-delay:0s}.reveal.slide-left:nth-child(2){transition-delay:.12s}.reveal.slide-left:nth-child(3){transition-delay:.24s}.reveal.slide-left:nth-child(4){transition-delay:.36s}.musician-svg{width:100%;max-width:440px;height:auto}.svg-floating-notes .svg-note{animation:noteFloat 4s ease-in-out infinite}.svg-note-1{animation-delay:0s!important}.svg-note-2{animation-delay:1s!important}.svg-note-3{animation-delay:2s!important}.svg-note-4{animation-delay:3s!important}@keyframes noteFloat{0%{transform:translateY(0) translate(0);opacity:0}20%{opacity:.7}80%{opacity:.3}to{transform:translateY(-30px) translate(10px);opacity:0}}.cta-section{position:relative;z-index:1;padding:120px 24px 60px;min-height:400px;display:flex;align-items:flex-end;justify-content:center;background:var(--off-white);overflow-x:clip}.cta-block{text-align:center;width:100%;max-width:1100px;position:relative;z-index:2}.cta-block:before{content:"";position:absolute;top:-200px;left:50%;transform:translate(-50%);width:100vw;height:600px;background:radial-gradient(ellipse at bottom,rgba(199,146,62,.1) 0%,rgba(199,146,62,.04) 40%,transparent 70%);pointer-events:none;z-index:-1}.cta-glow{position:absolute;bottom:0;left:50%;width:100vw;height:300px;background:linear-gradient(to top,rgba(199,146,62,.12) 0%,rgba(199,146,62,.04) 50%,transparent 100%);pointer-events:none;z-index:-1;transform:translate(-50%)}@keyframes ctaGlow{0%,to{opacity:.5;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.2)}}.cta-eyebrow{color:var(--accent-light);display:block;margin-bottom:24px}.cta-block h2{font-size:clamp(2rem,5vw,4rem);font-weight:800;color:var(--gray-900);margin-bottom:24px;letter-spacing:-.04em;position:relative}.cta-block p{font-size:1.1rem;color:var(--gray-500);margin-bottom:48px;position:relative;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.btn-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:var(--accent);color:var(--white);font-size:.9rem;font-weight:600;font-family:var(--font);border:none;border-radius:50px;cursor:pointer;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;letter-spacing:.01em;margin-bottom:40px;pointer-events:auto}.btn-cta:hover{background:var(--accent-hover);box-shadow:0 8px 30px #c7923e66;transform:translateY(-3px)}.btn-cta svg{transition:transform .3s}.btn-cta:hover svg{transform:translate(5px)}@media (max-width: 768px){.cta-section{padding:80px 16px 40px}}.stat-card{border-radius:16px;padding:24px 16px}.page-content{padding:48px 0 80px}.page-header{margin-bottom:36px}.page-header h1{font-size:1.75rem;font-weight:500;margin-bottom:6px;letter-spacing:-.02em}.page-desc{font-size:.9rem;color:var(--gray-500);max-width:460px}.page-tag{font-size:.6875rem;font-weight:600;color:var(--accent);margin-bottom:8px;letter-spacing:.08em;text-transform:uppercase}.content-section{display:flex;flex-direction:column;gap:24px}.detail-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}.detail-list li{padding:10px 16px;font-size:.8125rem;color:var(--gray-700)}.section{padding:80px 0}.section-header{text-align:center;margin-bottom:48px}.section-title{font-size:1.75rem;font-weight:500;margin-bottom:8px;letter-spacing:-.01em}.section-subtitle{font-size:.875rem;color:var(--gray-500)}.card-featured h2{font-size:1.15rem;font-weight:500;margin-bottom:12px}.card-featured p{font-size:.9rem;color:var(--gray-600);line-height:1.7}.page-calendar-premium{padding:0}.cal-hero{position:relative;min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--off-white);overflow:hidden;padding:80px 24px 60px}.cal-hero-glow{position:absolute;top:50%;left:50%;width:500px;height:500px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(199,146,62,.08) 0%,transparent 70%);pointer-events:none;animation:calGlowPulse 6s ease-in-out infinite alternate}@keyframes calGlowPulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:.5}to{transform:translate(-50%,-50%) scale(1.3);opacity:1}}.cal-hero-content{position:relative;z-index:1;opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.cal-hero.visible .cal-hero-content{opacity:1;transform:translateY(0)}.cal-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);margin-bottom:20px;padding:8px 16px;border:1px solid rgba(199,146,62,.25);border-radius:50px;background:#c7923e14}.cal-hero-title{display:flex;flex-direction:column;gap:0;margin-bottom:16px}.cal-title-line{display:block;font-size:clamp(2.5rem,8vw,5rem);font-weight:800;color:var(--gray-900);letter-spacing:-.04em;line-height:1}.cal-title-line.accent{color:var(--accent)}.cal-hero-desc{font-size:1.05rem;color:var(--gray-500);max-width:440px;margin:0 auto 24px;line-height:1.6;font-weight:300}.cal-hero-stat{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--gray-600);padding:10px 20px;background:#c7923e0f;border-radius:50px;border:1px solid rgba(199,146,62,.12);margin-bottom:20px}.cal-hero-stat strong{color:var(--accent);font-weight:700}.cal-hero-actions{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px}.cal-hero-add-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--accent);color:var(--white);font-size:.875rem;font-weight:600;border:none;border-radius:50px;transition:all .3s ease}.cal-hero-add-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px #c7923e4d}.cal-hero-add-btn.secondary{background:var(--white);color:var(--gray-800);border:1px solid var(--gray-300)}.cal-hero-add-btn.secondary:hover{background:var(--gray-50);border-color:var(--gray-400);box-shadow:0 4px 12px #0000000d}.cal-body{padding:48px 0 80px;background:var(--off-white)}.cal-wrapper{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000000d;padding:32px;overflow:hidden;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s ease}.cal-wrapper.slide-left{animation:calSlideLeft .25s ease-out forwards}.cal-wrapper.slide-right{animation:calSlideRight .25s ease-out forwards}@keyframes calSlideLeft{0%{transform:translate(0);opacity:1}50%{transform:translate(-20px);opacity:.5}to{transform:translate(0);opacity:1}}@keyframes calSlideRight{0%{transform:translate(0);opacity:1}50%{transform:translate(20px);opacity:.5}to{transform:translate(0);opacity:1}}.cal-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.cal-month-display{text-align:center}.cal-month-display h2{font-size:1.6rem;font-weight:800;letter-spacing:-.03em;margin:0;color:var(--gray-900)}.cal-year{font-size:.8rem;font-weight:500;color:var(--accent);letter-spacing:.08em}.cal-nav-btn{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200);transition:all .2s ease}.cal-nav-btn:hover{background:var(--gray-900);color:var(--white);border-color:var(--gray-900);transform:scale(1.05)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden}.cal-day-header{background:var(--white);padding:16px 0;text-align:center;font-size:.75rem;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em}.cal-cell{background:var(--white);min-height:120px;padding:10px;transition:all .3s cubic-bezier(.25,1,.3,1);display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden;animation:calCellIn .4s cubic-bezier(.16,1,.3,1) both}@keyframes calCellIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cal-cell:hover{background:var(--gray-50)}@media (hover: hover) and (pointer: fine){.cal-cell:hover{transform:scale(1.35);z-index:100;box-shadow:0 20px 40px #00000026;border-radius:var(--radius);background:var(--white);overflow:visible}.cal-cell.other-month:hover{opacity:1}.cal-cell:hover .event-title{white-space:normal}}.cal-cell.other-month{background:var(--gray-50);opacity:.4}.cal-cell.today{background:var(--accent-bg)}.cal-day-num{font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:4px;position:relative;display:inline-flex;align-items:center;justify-content:center}.cal-today-badge{background:var(--accent);color:var(--white)!important;width:28px;height:28px;border-radius:50%;font-weight:700}.cal-today-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--accent);opacity:0;animation:todayPulse 2s ease-in-out infinite}@keyframes todayPulse{0%{transform:scale(.8);opacity:.6}50%{transform:scale(1.2);opacity:0}to{transform:scale(.8);opacity:0}}.cal-event-dots{display:flex;gap:4px;margin-top:auto;padding-top:4px;flex-wrap:wrap}.cal-dot{width:6px;height:6px;border-radius:50%;animation:dotPulse 2s ease-in-out infinite}.cal-dot.rehearsal{background:#22c55e}.cal-dot.event{background:#ef4444}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.event-tag{font-size:.7rem;padding:4px 8px;border-radius:4px;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:transform .15s,box-shadow .15s;border-left:3px solid transparent;line-height:1.2}.event-tag:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.event-tag.rehearsal{background:#f0fdf4;color:#166534;border-left-color:#22c55e}.event-tag.performance{background:#fef2f2;color:#991b1b;border-left-color:#ef4444}.event-tag.other{background:#eff6ff;color:#1e40af;border-left-color:#3b82f6}.event-tag .event-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-tag .event-time{opacity:.8;font-size:.65rem}.admin-cell-overlap{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;background:#c7923e0d;display:flex;align-items:center;justify-content:center;cursor:copy;transition:opacity .2s;z-index:5}.cal-cell:hover .admin-cell-overlap{opacity:1}.cal-cell.is-past{background:var(--gray-50)}.cal-cell.is-past .cal-day-num,.cal-cell.is-past .event-tag{opacity:.5}.past-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#ef444426;pointer-events:none;z-index:2}.past-overlay svg{width:80%;height:80%}.cal-footer-hint{text-align:center;margin-top:24px;color:var(--gray-500);font-size:.9rem}.cal-footer-link{display:inline-flex;align-items:center;gap:6px;margin-top:10px;color:var(--accent);font-size:.95rem;text-decoration:none;font-weight:600;transition:gap .2s ease}.cal-footer-link:hover{gap:10px}@media (max-width: 768px){.cal-hero{min-height:40vh;padding:60px 20px 40px}.cal-wrapper{padding:12px}.cal-day-header{padding:10px 0;font-size:.65rem}.cal-cell{min-height:70px;padding:4px;gap:2px}.event-tag .event-time{display:none}.event-tag{padding:2px 4px;font-size:.6rem}}@media (max-width: 480px){.cal-grid{gap:1px}.cal-day-header{font-size:.55rem;padding:6px 0}.cal-day-num{font-size:.75rem}.cal-cell{min-height:55px;padding:2px}.cal-today-badge{width:20px;height:20px;font-size:.7rem}.past-overlay svg{width:60%;height:60%}}.page-band-premium{padding:0}.band-page-hero{position:relative;min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--off-white);overflow:hidden;padding:80px 24px 60px}.band-hero-glow{position:absolute;top:50%;left:50%;width:500px;height:500px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(199,146,62,.08) 0%,transparent 70%);pointer-events:none;animation:calGlowPulse 6s ease-in-out infinite alternate}.band-hero-content{position:relative;z-index:1;opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.band-page-hero.visible .band-hero-content{opacity:1;transform:translateY(0)}.band-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);margin-bottom:20px;padding:8px 16px;border:1px solid rgba(199,146,62,.2);border-radius:50px;background:#c7923e0f}.band-hero-title{display:flex;flex-direction:column;margin-bottom:16px}.band-title-line{display:block;font-size:clamp(2.5rem,8vw,5rem);font-weight:800;color:var(--gray-900);letter-spacing:-.04em;line-height:1}.band-title-line.accent{color:var(--accent)}.band-hero-desc{font-size:1.05rem;color:var(--gray-500);max-width:500px;margin:0 auto 20px;line-height:1.6;font-weight:300}.band-hero-grades{display:inline-block;font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.1em;padding:6px 16px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:50px}.band-highlights-section{padding:60px 24px;background:var(--white)}.band-highlights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;max-width:900px;margin:0 auto}.band-highlight-card{text-align:center;padding:32px 20px;border-radius:var(--radius-lg);border:1px solid var(--gray-200);background:var(--white);transition:transform .3s ease,box-shadow .3s ease}.band-highlight-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000000f}.band-highlight-icon{width:48px;height:48px;border-radius:14px;background:#c7923e14;color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.band-highlight-card h3{font-size:.95rem;font-weight:700;color:var(--gray-900);margin-bottom:6px}.band-highlight-card p{font-size:.8rem;color:var(--gray-500);line-height:1.4}.band-about-section{padding:60px 24px;background:var(--off-white)}.band-about-block{max-width:700px;margin:0 auto}.band-about-block h2{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;color:var(--gray-900);letter-spacing:-.03em;margin-bottom:20px}.band-about-block p{font-size:1rem;color:var(--gray-600);line-height:1.8;margin-bottom:16px}.band-program-section{padding:60px 24px;background:var(--white)}.band-program-section .section-eyebrow{display:block;text-align:center;margin-bottom:28px}.band-program-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;max-width:900px;margin:0 auto}.band-program-card{padding:24px;background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-200);transition:transform .2s ease,box-shadow .2s ease}.band-program-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000000d}.band-program-label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:8px}.band-program-value{font-size:.95rem;font-weight:500;color:var(--gray-900);line-height:1.5}.band-cta-section{padding:60px 24px 80px;background:var(--off-white)}.band-cta-section h2{font-size:clamp(1.5rem,4vw,2rem);font-weight:800;color:var(--gray-900);margin-bottom:12px}.band-cta-section p{font-size:1rem;color:var(--gray-500);margin-bottom:24px}.band-cta-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.band-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;font-size:.875rem;font-weight:600;border-radius:50px;text-decoration:none;transition:all .3s ease}.band-cta-btn.primary{background:var(--accent);color:var(--white)}.band-cta-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #c7923e4d}.band-cta-btn.secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.band-cta-btn.secondary:hover{background:var(--gray-200);transform:translateY(-1px)}.band-contact-btn{display:inline-flex;align-items:center;gap:8px;margin-top:24px;padding:14px 32px;font-size:1rem;font-weight:700;color:var(--white);background:linear-gradient(135deg,var(--gray-800),var(--gray-900));border-radius:50px;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #0000001a}.band-contact-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 24px #0003;background:linear-gradient(135deg,var(--gray-900),#000)}@media (max-width: 768px){.band-page-hero{min-height:40vh;padding:60px 20px 40px}.band-highlights-section{padding:40px 16px}.band-highlights-grid{grid-template-columns:repeat(2,1fr);gap:12px}.band-highlight-card{padding:20px 12px}.band-about-section,.band-program-section{padding:40px 16px}.band-cta-section{padding:40px 16px 60px}.band-cta-links{flex-direction:column;align-items:center;gap:8px}}.page-music-classes-premium{padding:0}.mc-hero{position:relative;min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--off-white);overflow:hidden;padding:80px 24px 60px}.mc-hero-glow{position:absolute;top:50%;left:50%;width:500px;height:500px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(16,185,129,.08) 0%,transparent 70%);pointer-events:none;animation:calGlowPulse 6s ease-in-out infinite alternate}.mc-hero-content{position:relative;z-index:1;opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.mc-hero.visible .mc-hero-content{opacity:1;transform:translateY(0)}.mc-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:#059669;margin-bottom:20px;padding:8px 16px;border:1px solid rgba(16,185,129,.2);border-radius:50px;background:#10b9810f}.mc-hero-title{display:flex;flex-direction:column;margin-bottom:16px}.mc-title-line{display:block;font-size:clamp(2.5rem,8vw,5rem);font-weight:800;color:var(--gray-900);letter-spacing:-.04em;line-height:1}.mc-title-line.accent{color:#059669}.mc-hero-desc{font-size:1.05rem;color:var(--gray-500);max-width:460px;margin:0 auto;line-height:1.6;font-weight:300}.mc-grades-section{padding:80px 24px 60px;background:var(--off-white)}.mc-grades-section .section-eyebrow{display:block;text-align:center;margin-bottom:32px}.mc-grades-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:700px;margin:0 auto}.mc-grade-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:36px 28px;position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.mc-grade-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.mc-grade-icon{width:48px;height:48px;border-radius:14px;background:#c7923e14;color:var(--card-accent, var(--accent));display:flex;align-items:center;justify-content:center;margin-bottom:20px}.mc-grade-title{font-size:1.15rem;font-weight:700;color:var(--gray-900);margin-bottom:12px;letter-spacing:-.01em}.mc-grade-desc{font-size:.9rem;color:var(--gray-600);line-height:1.7}.mc-grade-accent-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--card-accent, var(--accent));opacity:0;transition:opacity .3s ease}.mc-grade-card:hover .mc-grade-accent-bar{opacity:1}.mc-instruments-section{position:relative;padding:80px 24px;background:var(--white);overflow:hidden}.mc-instruments-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(199,146,62,.04) 0%,transparent 60%);pointer-events:none}.mc-instruments-header{text-align:center;margin-bottom:48px}.mc-instruments-header h2{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;color:var(--gray-900);letter-spacing:-.03em;margin-bottom:12px}.mc-instruments-header p{font-size:1rem;color:var(--gray-500);max-width:500px;margin:0 auto;line-height:1.6}.mc-instruments-orbit{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:800px;margin:0 auto}.mc-inst-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:50px;font-size:.8rem;font-weight:500;color:var(--gray-600);transition:all .3s cubic-bezier(.16,1,.3,1);cursor:default}.mc-inst-pill:hover,.mc-inst-pill.active{background:#c7923e26;border-color:#c7923e66;color:var(--gray-900);transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #c7923e26}.mc-stats-section{padding:60px 24px;background:var(--off-white)}.mc-stats-row{display:flex;align-items:center;justify-content:center;gap:32px;max-width:700px;margin:0 auto}.mc-stat{text-align:center;flex:1}.mc-stat-number{display:block;font-size:clamp(2rem,5vw,3rem);font-weight:800;color:var(--gray-900);letter-spacing:-.03em;line-height:1;margin-bottom:6px}.mc-stat-plus{color:var(--accent)}.mc-stat-label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em}.mc-stat-divider{width:1px;height:40px;background:var(--gray-300)}.mc-cta-section{position:relative;padding:100px 24px 80px;background:var(--off-white);text-align:center;overflow:hidden}.mc-cta-glow{position:absolute;top:-100px;left:50%;transform:translate(-50%);width:600px;height:400px;background:radial-gradient(circle,rgba(16,185,129,.08) 0%,transparent 70%);pointer-events:none}.mc-cta-block{position:relative;z-index:1;max-width:600px;margin:0 auto}.mc-cta-block h2{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;color:var(--gray-900);letter-spacing:-.03em;margin-bottom:16px;line-height:1.2}.mc-cta-block p{font-size:1.05rem;color:var(--gray-500);line-height:1.6;margin-bottom:32px}.mc-cta-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:#10b981;color:var(--white);font-size:.9rem;font-weight:600;border-radius:50px;text-decoration:none;transition:all .3s ease}.mc-cta-btn:hover{background:#059669;transform:translateY(-2px);box-shadow:0 8px 24px #10b9814d}@media (max-width: 768px){.mc-hero{min-height:40vh;padding:60px 20px 40px}.mc-grades-section{padding:48px 16px 40px}.mc-instruments-section{padding:48px 16px}.mc-stats-row{gap:16px}.mc-cta-section{padding:60px 20px}}.schedule-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:0;overflow:hidden;margin-bottom:32px;box-shadow:0 4px 20px #00000008;transition:transform .3s ease,box-shadow .3s ease}.schedule-card:hover{box-shadow:0 12px 30px #0000000f;transform:translateY(-2px)}.schedule-card-header{padding:20px 24px;background:linear-gradient(to right,var(--gray-50),var(--white));border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}.schedule-card-header h3{font-size:1.15rem;color:var(--gray-900);font-weight:700;letter-spacing:-.01em}.schedule-item{display:grid;grid-template-columns:140px 1fr 1fr 140px;padding:20px 24px;border-bottom:1px solid var(--gray-100);align-items:center;transition:background .15s}.schedule-item.is-paused{background:repeating-linear-gradient(45deg,var(--gray-50),var(--gray-50) 10px,var(--white) 10px,var(--white) 20px);opacity:.8}.schedule-item:last-child{border-bottom:none}.schedule-item:hover{background:var(--gray-50)}.item-day{font-weight:600;color:var(--gray-900)}.item-time{display:flex;align-items:center;gap:8px;color:var(--gray-600)}.item-location{display:flex;align-items:center;gap:8px;color:var(--gray-500)}.icon-badge{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--gray-100);color:var(--gray-600)}.item-actions{display:flex;justify-content:flex-end;gap:8px}.status-paused{font-size:.7rem;background:#fee2e2;color:#991b1b;padding:2px 8px;border-radius:10px;font-weight:600}@media (max-width: 850px){.schedule-item{grid-template-columns:100px 1fr 1fr auto;gap:12px;padding:16px}}@media (max-width: 640px){.schedule-item{grid-template-columns:1fr;gap:8px}.item-actions{justify-content:flex-start;margin-top:8px;padding-top:8px;border-top:1px solid var(--gray-100)}}.admin-input-group{display:flex;flex-direction:column;gap:4px}.admin-input-group label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase}.admin-input{padding:10px 16px;border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--gray-50);transition:all .2s}.admin-input:focus{border-color:var(--accent);background:var(--white);box-shadow:0 0 0 4px var(--accent-bg)}.footer{background:var(--dark);padding:60px 0 40px;margin-top:auto;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:-50%;left:50%;transform:translate(-50%);width:600px;height:400px;background:radial-gradient(circle,rgba(199,146,62,.06),transparent 70%);pointer-events:none}.footer-inner{max-width:1000px;margin:0 auto;padding:0 24px;display:flex;flex-direction:column;align-items:center;gap:32px;text-align:center;position:relative}.footer-brand{display:flex;align-items:center;gap:12px;font-size:1.1rem;font-weight:500;color:var(--white)}.footer-links{display:flex;gap:24px}.social-link{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#fff6;transition:color .3s}.social-link:hover{color:var(--accent)}.footer-copy{font-size:.75rem;color:#ffffff40;letter-spacing:.02em}@media (max-width: 640px){.footer{padding:40px 0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .4s ease}.modal{background:var(--white);width:100%;max-width:440px;border-radius:24px;border:1px solid rgba(0,0,0,.06);padding:48px;position:relative;box-shadow:0 24px 48px #00000014;animation:slideUp .5s cubic-bezier(.16,1,.3,1)}.modal-close{position:absolute;top:24px;right:24px;color:var(--gray-400);background:var(--gray-50);width:36px;height:36px;border:none;border-radius:50%;transition:all .3s ease;display:flex;align-items:center;justify-content:center;cursor:pointer}.modal-close:hover{background:var(--gray-100);color:var(--gray-900);transform:scale(1.05)}.modal-header{margin-bottom:32px;text-align:center}.modal-header h2{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;margin-bottom:8px;color:var(--gray-900)}.modal-header p{font-size:.95rem;color:var(--gray-500)}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:.8rem;font-weight:700;color:var(--gray-600)}.form-group input{padding:14px 16px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:12px;font-size:.95rem;transition:all .2s ease;width:100%;color:var(--gray-900)}.form-group input:focus{background:var(--white);border-color:var(--accent);box-shadow:0 0 0 4px #c7923e1a;outline:none}.form-error{padding:12px 16px;background:#fff0f2;color:#d90429;border:1px solid #ffccd5;border-radius:12px;font-size:.85rem;font-weight:500}.btn-submit{padding:16px;background:linear-gradient(135deg,var(--gray-800),var(--gray-900));color:var(--white);border-radius:12px;font-weight:700;font-size:1rem;transition:all .3s cubic-bezier(.16,1,.3,1);margin-top:8px;cursor:pointer;border:none;box-shadow:0 4px 12px #0000001a}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #00000026;background:linear-gradient(135deg,var(--gray-900),#000)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.link-btn{color:var(--accent);font-weight:600;font-size:.9rem;transition:color .2s;border:none;background:none;cursor:pointer;padding:0;margin-left:4px}.link-btn:hover{color:var(--accent-hover);text-decoration:underline}.modal-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--gray-100);text-align:center;font-size:.9rem;color:var(--gray-500)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 24px;border-radius:var(--radius);font-size:.95rem;font-weight:500;transition:all .2s cubic-bezier(.16,1,.3,1);cursor:pointer;white-space:nowrap;border:none;font-family:var(--font)}.btn-primary{background:var(--gray-900);color:var(--white)}.btn-primary:hover{background:var(--gray-800);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200);color:var(--gray-900)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:8px;border-radius:50%;color:var(--gray-400);transition:all .2s;background:none;border:none;cursor:pointer}.btn-icon:hover{background:var(--gray-100)!important;color:var(--gray-900)!important}.btn-icon-active{color:var(--accent)}.admin-form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:32px;margin-bottom:40px;position:relative;z-index:10}.admin-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--gray-100)}.admin-form-header h3{font-size:1.25rem;font-weight:600;margin:0}.admin-form{display:flex;flex-direction:column;gap:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.admin-form input,.admin-form select,.admin-form textarea{padding:12px 16px;border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--gray-50);font-size:.95rem;font-family:var(--font);transition:all .2s cubic-bezier(.16,1,.3,1);width:100%;outline:none}.admin-form input:focus,.admin-form select:focus,.admin-form textarea:focus{border-color:var(--accent);background:var(--white);box-shadow:0 0 0 4px var(--accent-bg)}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px;padding-top:24px;border-top:1px solid var(--gray-100)}@media (max-width: 640px){.form-row{grid-template-columns:1fr;gap:20px}.admin-form-card{padding:24px}}.instrument-list-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 600px){.instrument-list-grid{grid-template-columns:1fr}}.schedule-item.is-paused{background:var(--gray-50)}.schedule-item.is-paused .item-day,.schedule-item.is-paused .item-time,.schedule-item.is-paused .item-location{opacity:.5}.item-day{display:flex!important;align-items:center}.rehearsal-pause-tag{display:inline-flex;align-items:center;gap:4px;background:#fee2e2;color:#991b1b;padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:700;margin-left:8px;text-transform:uppercase}.pause-date-info{grid-column:1 / -1;margin-top:6px;font-size:.75rem;color:#991b1b;font-weight:600}.ai-fab{position:fixed;bottom:2rem;right:2rem;width:64px;height:64px;border-radius:50%;background:var(--white);color:var(--gray-900);border:1px solid rgba(0,0,0,.04);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .4s cubic-bezier(.16,1,.3,1);overflow:hidden;box-shadow:0 16px 32px #00000014,0 4px 8px #00000008}.ai-fab:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 24px 48px #0000001f,0 8px 16px #0000000a;color:var(--accent)}.ai-fab-gradient{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(199,146,62,.15) 0%,transparent 70%);animation:rotate-gradient 10s linear infinite;pointer-events:none}@keyframes rotate-gradient{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.ai-widget{position:fixed;bottom:2rem;right:2rem;width:420px;height:650px;max-height:calc(100vh - 4rem);background:#fffffff2;backdrop-filter:blur(24px) saturate(150%);-webkit-backdrop-filter:blur(24px) saturate(150%);border:1px solid rgba(0,0,0,.05);border-radius:28px;display:flex;flex-direction:column;z-index:1001;overflow:hidden;animation:slide-up-fade .5s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 48px #0000001f,0 12px 24px #0000000f;color:var(--gray-900)}.ai-widget.minimized{height:74px}@keyframes slide-up-fade{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ai-header{padding:1.25rem 1.5rem;background:#ffffffe6;border-bottom:1px solid rgba(0,0,0,.04);display:flex;align-items:center;justify-content:space-between}.ai-header-info{display:flex;align-items:center;gap:14px}.ai-avatar{width:40px;height:40px;border-radius:12px;background:var(--off-white);border:1px solid rgba(0,0,0,.04);display:flex;align-items:center;justify-content:center;color:var(--gray-900);box-shadow:0 2px 8px #00000005}.ai-header-info h3{margin:0;font-size:1.05rem;font-weight:700;color:var(--gray-900);letter-spacing:-.01em}.status-dot{font-size:.75rem;color:#10b981;display:flex;align-items:center;gap:4px;font-weight:500;margin-top:2px}.status-dot:before{content:"";width:6px;height:6px;background:currentColor;border-radius:50%}.ai-header-actions{display:flex;gap:6px}.ai-header-actions button{background:transparent;border:none;color:var(--gray-400);cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.ai-header-actions button:hover{background:var(--gray-50);color:var(--gray-900)}.ai-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;scroll-behavior:smooth;background:#fdfdfd}.ai-welcome{text-align:center;padding:2.5rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.welcome-icon{color:var(--gray-900);margin-bottom:.5rem}.ai-welcome h4{margin:0;font-size:1.35rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em}.ai-welcome p{margin:0;font-size:.95rem;color:var(--gray-500);line-height:1.5}.ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:1rem}.ai-suggestions button{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-700);padding:10px 18px;border-radius:50px;font-size:.85rem;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 4px 12px #00000005}.ai-suggestions button:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px);box-shadow:0 6px 16px #c7923e1a}.message-wrapper{display:flex;gap:12px;max-width:88%}.message-wrapper.user{align-self:flex-end;flex-direction:row-reverse}.message-avatar{width:32px;height:32px;border-radius:10px;background:var(--off-white);border:1px solid rgba(0,0,0,.03);display:flex;align-items:center;justify-content:center;color:var(--gray-500);flex-shrink:0}.message-wrapper.assistant .message-avatar{background:var(--gray-900);color:var(--white)}.message-content{background:var(--white);padding:16px 20px;border-radius:4px 20px 20px;font-size:.95rem;line-height:1.6;color:var(--gray-800);border:1px solid rgba(0,0,0,.03);box-shadow:0 8px 16px #00000005}.message-wrapper.user .message-content{background:linear-gradient(135deg,var(--gray-800),var(--gray-900));color:var(--white);border-radius:20px 4px 20px 20px;border:none;font-weight:400;box-shadow:0 8px 24px #00000014}.message-content.typing{display:flex;align-items:center;gap:8px;color:var(--gray-500);background:transparent;border:none;box-shadow:none;padding:8px 0}.markdown-body{font-size:.95rem;line-height:1.6;color:inherit;word-wrap:break-word}.markdown-body p,.markdown-body ul,.markdown-body ol{margin-bottom:.75rem}.markdown-body *:last-child{margin-bottom:0}.markdown-body ul,.markdown-body ol{margin-left:1.5rem}.markdown-body li{margin-bottom:.35rem}.markdown-body strong{font-weight:700}.markdown-body table{width:100%;border-collapse:collapse;margin-bottom:.75rem;font-size:.9rem;border-radius:8px;overflow:hidden}.markdown-body th,.markdown-body td{padding:10px 14px;border:1px solid var(--gray-100);text-align:left}.markdown-body th{background:var(--off-white);font-weight:600;color:var(--gray-900)}.markdown-body tr:nth-child(2n){background:#00000003}.ai-input-area{padding:1.25rem 1.5rem;background:#fffffff2;border-top:1px solid rgba(0,0,0,.04);display:flex;gap:12px}.ai-input-area input{flex:1;background:var(--gray-50);border:1px solid transparent;color:var(--gray-900);padding:14px 20px;border-radius:50px;outline:none;transition:all .3s ease;font-size:.95rem}.ai-input-area input:focus{background:var(--white);border-color:var(--gray-200);box-shadow:0 4px 12px #00000008}.ai-input-area button{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gray-800),var(--gray-900));color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #0000001a;flex-shrink:0}.ai-input-area button:hover:not(:disabled){transform:scale(1.05) translateY(-2px);box-shadow:0 8px 24px #00000026;background:linear-gradient(135deg,var(--gray-900),#000)}.ai-input-area button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 600px){.ai-fab{bottom:1.5rem;right:1.5rem;width:50px;height:50px}.ai-widget{bottom:0;right:0;width:100%;height:100%;max-height:100%;border-radius:0;border:none}.ai-widget.minimized{height:70px;bottom:0}}.page-content{min-height:100vh;padding-top:80px;display:flex;flex-direction:column;background:var(--off-white);color:var(--gray-900);position:relative}.page-hero,.page-body{position:relative;z-index:1}.page-hero{padding:6rem 2rem 4rem;text-align:center;border-bottom:1px solid var(--gray-200);background:linear-gradient(to bottom,rgba(199,146,62,.05),transparent)}.page-hero .page-tag{color:var(--accent);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1rem;font-size:.85rem}.page-hero h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:1rem;color:var(--gray-900)}.page-hero .page-desc{font-size:1.25rem;color:var(--gray-600);max-width:600px;margin:0 auto}.page-body{padding:4rem 2rem;flex:1}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;width:100%}.card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;padding:2.5rem;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--gray-300)}.card-featured{grid-column:1 / -1;background:linear-gradient(145deg,var(--white),var(--gray-50));border-left:4px solid var(--accent)}.card-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--accent-bg);color:var(--accent);margin-bottom:1.5rem}.card h2{font-size:2rem;margin-bottom:1rem;color:var(--gray-900)}.card h3{font-size:1.5rem;margin-bottom:1rem;color:var(--gray-900)}.card p{color:var(--gray-600);line-height:1.7}.instrument-tags{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.instrument-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--white);border:1px solid var(--gray-200);border-radius:2rem;font-size:.9rem;color:var(--gray-700);transition:background .2s,transform .2s,box-shadow .2s}.instrument-pill:hover{background:var(--gray-50);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.detail-list{list-style-type:none;padding:0;margin-top:1rem}.detail-list li{position:relative;padding-left:1.5rem;margin-bottom:.5rem;color:var(--gray-700);background:transparent}.detail-list li:before{content:"•";color:var(--accent);position:absolute;left:0;font-size:1.2rem;line-height:1}.announcement-container{position:fixed;top:calc(var(--nav-height) + 12px);left:0;right:0;z-index:10000;display:flex;flex-direction:column;align-items:center;pointer-events:none;gap:8px;transition:top .3s ease}body:has(.navbar-hidden) .announcement-container{top:12px}.announcement-banner{pointer-events:auto;width:90%;max-width:700px;padding:12px 20px;border-radius:12px;box-shadow:0 8px 32px #00000014;font-size:.9rem;font-weight:500;display:flex;flex-direction:column;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:slideDownToast .4s cubic-bezier(.16,1,.3,1) forwards;border:1px solid rgba(255,255,255,.2);transition:transform .2s,box-shadow .2s;cursor:pointer}.announcement-banner:hover{transform:translateY(-2px);box-shadow:0 12px 48px #0000001f}@keyframes slideDownToast{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.announcement-banner.severity-low{background:#fffffff2;color:var(--blue-700);border-left:4px solid var(--blue-600)}.announcement-banner.severity-medium{background:#fffffff2;color:#92400e;border-left:4px solid #f59e0b}.announcement-banner.severity-high{background:#fffffff2;color:var(--red-500);border-left:4px solid var(--red-500)}.announcement-inner{display:flex;justify-content:space-between;align-items:center;width:100%}.announcement-content{display:flex;align-items:center;gap:12px}.announcement-close{background:#0000000d;border:none;color:inherit;cursor:pointer;padding:6px;opacity:.7;display:flex;align-items:center;border-radius:50%;transition:all .2s}.announcement-close:hover{opacity:1;background:#0000001a}.announcement-manager{margin-top:60px;border-top:1px solid var(--gray-200);padding-top:40px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.admin-form-card{background:var(--white);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-lg);margin-bottom:32px;border:1px solid var(--gray-200)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{font-size:.75rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select,.form-group textarea{padding:12px 16px;border:1px solid var(--gray-300);border-radius:var(--radius);font-family:inherit;font-size:.95rem;background:var(--gray-50);color:var(--gray-900);transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--gray-900);box-shadow:0 0 0 3px #0000000d;background:var(--white)}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.announcement-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.announcement-admin-card{padding:24px;background:var(--white);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-md);border:1px solid var(--gray-200);transition:transform .2s ease}.announcement-admin-card:hover{transform:translateY(-2px)}.ann-header{display:flex;justify-content:space-between;align-items:center}.ann-text{font-size:1rem;color:var(--gray-800);line-height:1.5}.ann-footer{display:flex;gap:16px;font-size:.8rem;color:var(--gray-500);margin-top:auto;padding-top:16px;border-top:1px solid var(--gray-100)}.badge{padding:4px 10px;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:.05em}.badge-low{background:var(--blue-50);color:var(--blue-700)}.badge-medium{background:var(--severity-medium-bg);color:#92400e}.badge-high{background:var(--red-50);color:var(--red-500)}.calendar-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:2000;animation:fadeIn .4s cubic-bezier(.16,1,.3,1) forwards}.calendar-expanding-square{position:fixed;z-index:2001;background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);--start-top: 50%;--start-left: 50%;--start-width: 0px;--start-height: 0px;animation:expandSquare .5s cubic-bezier(.25,1,.3,1) forwards;top:var(--start-top);left:var(--start-left);width:var(--start-width);height:var(--start-height);opacity:0}@keyframes expandSquare{0%{top:var(--start-top);left:var(--start-left);width:var(--start-width);height:var(--start-height);opacity:.8;border-radius:var(--radius)}to{top:50%;left:50%;transform:translate(-50%,-50%);width:90vw;max-width:600px;height:80vh;max-height:800px;opacity:1;border-radius:var(--radius-lg)}}.calendar-expanding-square .expanded-content{padding:32px;opacity:0;height:100%;overflow-y:auto;animation:fadeInContent .3s ease-out .3s forwards}@keyframes fadeInContent{to{opacity:1}}.calendar-cell.expanded-origin{opacity:0}@media (max-width: 768px){@keyframes expandSquare{0%{top:var(--start-top);left:var(--start-left);width:var(--start-width);height:var(--start-height);opacity:.8;border-radius:var(--radius)}to{top:auto;bottom:0;left:0;transform:none;width:100vw;height:85vh;max-width:none;max-height:none;border-radius:24px 24px 0 0;opacity:1}}}
