/* ASI Compass main styling */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#030712;--panel:rgba(7,13,30,.82);--panel2:rgba(10,18,43,.78);
  --line:rgba(144,169,255,.18);--text:#f8fbff;--muted:#a9b5cf;
  --blue:#118cff;--cyan:#00ddff;--purple:#8b35ff;--pink:#ff4edb;
  --red:#ff4767;--green:#2ce6a6;--yellow:#ffd25e;
}
html{scroll-behavior:smooth}
body{
  min-height:100vh;color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;overflow-x:hidden;
  background:radial-gradient(circle at 12% 18%,rgba(0,132,255,.18),transparent 30%),radial-gradient(circle at 82% 14%,rgba(143,47,255,.21),transparent 34%),radial-gradient(circle at 70% 86%,rgba(0,224,255,.08),transparent 34%),linear-gradient(135deg,#020611,#050819 48%,#03030b);
}
body:before{
  content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(115deg,transparent 0 34%,rgba(0,145,255,.13),transparent 48%),linear-gradient(145deg,transparent 0 56%,rgba(166,64,255,.19),transparent 70%);opacity:.6;animation:sweep 9s ease-in-out infinite alternate;
}
.bg-noise{position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(85,119,255,.56) 0 1px,transparent 1.8px),linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:88px 88px,56px 56px,56px 56px;mask-image:radial-gradient(circle at center,black,transparent 85%);opacity:.45}
@keyframes sweep{from{transform:translateX(-2%)}to{transform:translateX(2%) translateY(-1%)}}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.hidden{display:none!important}
main{position:relative;z-index:1;width:min(1200px,calc(100% - 28px));margin:0 auto 34px}
.top-nav{width:min(1200px,calc(100% - 28px));margin:16px auto 0;height:74px;border:1px solid rgba(160,180,255,.2);border-radius:18px;background:rgba(3,7,18,.75);display:flex;align-items:center;justify-content:space-between;padding:0 16px 0 18px;backdrop-filter:blur(18px);box-shadow:0 14px 50px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.05);position:sticky;top:12px;z-index:50}
.brand-button{border:0;background:transparent;color:#fff;display:flex;align-items:center;gap:12px;text-align:left;min-width:210px}
.brand-mark{width:44px;height:44px;border-radius:15px;background:radial-gradient(circle at 35% 30%,#fff 0 2px,transparent 3px),linear-gradient(135deg,var(--cyan),var(--purple));box-shadow:0 0 28px rgba(49,136,255,.55);position:relative;display:inline-block;flex:0 0 44px}
.brand-mark:before,.brand-mark:after{content:"";position:absolute;inset:7px;border:1.5px solid rgba(255,255,255,.8);border-radius:999px;transform:rotate(45deg)}
.brand-mark:after{inset:15px;background:rgba(3,7,18,.75)}
.brand-button strong{display:block;font-size:1.23rem;letter-spacing:-.04em}.brand-button small{display:block;color:var(--muted);font-size:.62rem;letter-spacing:.12em;margin-top:3px}
.nav-tabs{display:flex;align-items:center;gap:8px}.nav-tab{border:0;background:transparent;color:#d9e0f4;font-size:.94rem;padding:11px 13px;border-radius:14px;transition:.22s ease;position:relative}.nav-tab:hover{color:#fff;background:rgba(255,255,255,.06);text-shadow:0 0 16px rgba(100,186,255,.8)}.nav-tab.active{color:#fff;background:rgba(96,59,188,.18)}.nav-tab.active:after{content:"";position:absolute;left:16px;right:16px;bottom:2px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--purple));box-shadow:0 0 16px rgba(71,163,255,.95)}
.nav-actions{display:flex;align-items:center;gap:10px}.round-btn{width:42px;height:42px;border:1px solid rgba(160,180,255,.16);border-radius:999px;background:rgba(255,255,255,.055);color:#fff;font-size:1.08rem;position:relative}.bell-dot{position:absolute;right:8px;top:8px;width:8px;height:8px;background:var(--cyan);border-radius:99px;box-shadow:0 0 10px var(--cyan)}.profile-chip{width:42px;height:42px;border:0;border-radius:999px;background:linear-gradient(135deg,#128cff,#8232ff);color:#fff;display:grid;place-items:center;font-weight:950;box-shadow:0 0 22px rgba(85,94,255,.45)}.login-pill{border:1px solid rgba(186,144,255,.55);background:rgba(88,51,160,.14);color:#fff;border-radius:999px;padding:11px 16px;font-weight:800}
.landing-view,.auth-view,.app-view{display:none;animation:viewIn .38s ease both}.landing-view.active,.auth-view.active,.app-view.active{display:block}
@keyframes viewIn{from{opacity:0;transform:translateY(12px);filter:blur(7px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}
.landing-grid,.auth-grid{min-height:calc(100vh - 92px);display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center;padding:44px 0 64px}.eyebrow{display:inline-flex;color:#dceaff;background:rgba(17,140,255,.08);border:1px solid rgba(0,221,255,.18);border-radius:999px;padding:9px 13px;margin-bottom:20px;font-size:.88rem}.hero-copy h1,.auth-copy h2{font-size:clamp(3.1rem,6vw,5.65rem);line-height:.94;letter-spacing:-.08em;margin-bottom:22px}.gradient-text{background:linear-gradient(90deg,#fff,#a7c7ff,#a052ff,#00d5ff);background-size:260%;-webkit-background-clip:text;color:transparent;animation:gradientShift 5s linear infinite;filter:drop-shadow(0 0 18px rgba(133,77,255,.45))}@keyframes gradientShift{from{background-position:0}to{background-position:260%}}
.hero-copy p,.auth-copy p{color:#c7d0e8;font-size:1.12rem;line-height:1.72;max-width:560px;margin-bottom:28px}.hero-actions,.button-row,.modal-actions{display:flex;gap:12px;flex-wrap:wrap}.primary-btn,.ghost-btn,.submit-btn,.primary-small,.ghost-small,.danger-small,.green-small,.primary-mini,.ghost-mini{border:0;border-radius:15px;padding:14px 18px;font-weight:900;color:#fff;transition:.2s ease}.primary-btn,.submit-btn,.primary-small,.primary-mini{background:linear-gradient(135deg,#0d8cff,#9135ff);box-shadow:0 0 30px rgba(40,133,255,.38)}.primary-btn:hover,.submit-btn:hover,.primary-small:hover,.primary-mini:hover{transform:translateY(-2px);box-shadow:0 0 42px rgba(56,142,255,.65)}.ghost-btn,.ghost-small,.ghost-mini{background:rgba(5,10,26,.72);border:1px solid rgba(170,122,255,.45)}.danger-small{background:rgba(255,71,103,.1);border:1px solid rgba(255,71,103,.35);color:#ff8fa4}.green-small{background:linear-gradient(90deg,#16bf86,#2ce6a6);color:#031512}.primary-mini,.ghost-mini{padding:9px 11px;border-radius:11px;font-size:.78rem;margin-top:9px}.full{width:100%;margin:8px 0 14px}
.trust-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:650px}.trust-row div{background:rgba(7,13,30,.68);border:1px solid rgba(160,180,255,.14);border-radius:16px;padding:14px}.trust-row strong{display:block}.trust-row span{display:block;color:var(--muted);font-size:.84rem;margin-top:4px}
.preview-stage{perspective:1100px;position:relative}.orbit{position:absolute;width:94%;height:110px;left:3%;bottom:6px;border-radius:50%;border:2px solid rgba(88,99,255,.35);box-shadow:0 0 30px rgba(0,134,255,.25),inset 0 0 35px rgba(176,64,255,.2);transform:rotateX(68deg)}.angled-dashboard{position:relative;transform-style:preserve-3d;transform:rotateY(-14deg) rotateX(6deg);min-height:490px;border-radius:28px;background:linear-gradient(160deg,rgba(10,17,39,.96),rgba(3,7,18,.98));border:1px solid rgba(132,166,255,.32);box-shadow:0 38px 100px rgba(0,0,0,.62),0 0 60px rgba(48,139,255,.35),0 0 90px rgba(146,44,255,.28);overflow:hidden;animation:bounceBoard 5s ease-in-out infinite;display:grid;grid-template-columns:150px 1fr}.angled-dashboard.small{min-height:330px;margin-top:22px;max-width:560px;transform:rotate(-6deg);animation:none}@keyframes bounceBoard{0%,100%{transform:rotateY(-14deg) rotateX(6deg) translateY(0)}50%{transform:rotateY(-14deg) rotateX(6deg) translateY(-14px)}}
.fake-side{background:rgba(0,0,0,.2);border-right:1px solid rgba(255,255,255,.08);padding:20px 14px;display:flex;flex-direction:column;gap:8px}.fake-side b{font-size:.8rem;margin-bottom:8px}.fake-side span{color:#abb6d4;padding:10px;border-radius:12px;font-size:.72rem}.fake-side .fake-active{color:#fff;background:linear-gradient(90deg,rgba(35,104,255,.45),rgba(137,57,255,.18));box-shadow:inset 3px 0 0 var(--cyan)}.fake-main{padding:24px}.fake-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:18px}.fake-head h3{letter-spacing:-.04em}.fake-head p{color:var(--muted);font-size:.8rem}.fake-avatar{width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#0f8cff,#8232ff);display:grid;place-items:center;font-weight:900}.fake-cards{display:grid;grid-template-columns:1fr .86fr;gap:14px}.fake-cards>div,.mini-preview .fake-main{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:16px}.fake-row,.mini-stat{display:flex;justify-content:space-between;padding:9px;border-bottom:1px solid rgba(255,255,255,.06);color:#cbd5f0;font-size:.76rem}.fake-row.active{color:#fff;background:rgba(78,114,255,.22);border-radius:10px;border-bottom:0}
.teachers-strip{margin:0 0 42px;background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:22px}.teacher-note-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}.teacher-note-grid div{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:15px;padding:14px;font-weight:800;color:#dfe6ff}
.auth-card,.panel,.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:22px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 20px 55px rgba(0,0,0,.24);backdrop-filter:blur(16px)}.auth-card{padding:32px;max-width:520px;margin-left:auto}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:26px}.auth-tab{border:0;background:transparent;color:var(--muted);padding:14px;font-weight:900;position:relative}.auth-tab.active{color:#fff}.auth-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;border-radius:99px;background:linear-gradient(90deg,var(--pink),var(--blue));box-shadow:0 0 18px rgba(84,152,255,.8)}.auth-form{display:none}.auth-form.active{display:block;animation:viewIn .22s ease both}label{display:block;margin:13px 0 7px;font-weight:850;color:#f1f5ff}input,select,textarea{width:100%;border:1px solid rgba(151,169,221,.18);background:rgba(3,7,18,.68);color:#fff;border-radius:12px;padding:12px 13px;outline:none}textarea{min-height:96px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:rgba(0,221,255,.7);box-shadow:0 0 0 4px rgba(0,221,255,.08)}.optional,.muted{color:var(--muted)}.form-warning{color:#ccd5ec;font-size:.86rem;margin:12px 0 18px}.submit-btn{width:100%}.auth-small{text-align:center;color:var(--muted);margin-top:16px;font-size:.9rem}.auth-small button{border:0;background:transparent;color:#ba83ff;font-weight:900}
.app-view{padding:18px 0}.tab-panel{display:none;animation:viewIn .32s ease both}.tab-panel.active{display:block}.page-title{display:flex;align-items:center;gap:14px;margin:14px 0 18px}.page-title h2{font-size:2.3rem;letter-spacing:-.06em}.page-title p{color:var(--muted)}.title-icon{width:54px;height:54px;border-radius:16px;background:rgba(17,140,255,.12);display:grid;place-items:center;font-size:1.75rem;color:var(--cyan);border:1px solid rgba(0,221,255,.2)}
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.big-welcome,.quick-panel,.panel{padding:20px}.big-welcome h3{font-size:2.4rem;letter-spacing:-.05em;margin-bottom:10px}.big-welcome h3 span{color:var(--blue)}.big-welcome p{color:#cbd5f0;line-height:1.55;margin-bottom:18px}.quick-panel{display:grid;grid-template-columns:1fr 1fr;gap:12px}.quick-card{border:1px solid rgba(160,180,255,.15);background:rgba(255,255,255,.04);border-radius:16px;padding:17px;cursor:pointer;transition:.2s}.quick-card:hover{border-color:rgba(0,221,255,.45);transform:translateY(-2px)}.quick-card span{display:block;color:var(--muted);margin-top:6px;font-size:.9rem}
.stats-grid{display:grid;grid-template-columns:1.08fr .95fr .88fr 1fr;gap:16px;margin:18px 0}.stat-card{min-height:138px;padding:20px;display:flex;gap:16px;align-items:flex-start}.stat-card>span{width:48px;height:48px;border-radius:16px;background:rgba(17,140,255,.12);display:grid;place-items:center;font-size:1.7rem;color:var(--cyan);border:1px solid rgba(0,221,255,.2);flex:0 0 48px}.stat-card small{display:block;color:#dfe7ff;margin-bottom:8px}.stat-card b{display:block;font-size:2.1rem;letter-spacing:-.05em}.stat-card p{color:var(--muted);margin-top:4px;font-size:.86rem}.progress-bar{height:11px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;margin-top:14px}.progress-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,#a126ff,#0d8cff);border-radius:999px;transition:width .4s ease}
.schedule-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.schedule-list-panel{display:flex;min-height:450px;max-height:530px;overflow:hidden}.status-rail{width:98px;flex:0 0 98px;padding:28px 0;text-align:center;color:#d6def6;font-size:.72rem;font-weight:800;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:14px}.status-rail .cyan{color:var(--cyan)}.rail-line{width:2px;height:260px;background:linear-gradient(var(--pink),var(--cyan),var(--pink));border-radius:99px;position:relative}.rail-line i{position:absolute;left:50%;top:46%;width:11px;height:11px;background:var(--cyan);border-radius:99px;transform:translate(-50%,-50%);box-shadow:0 0 18px var(--cyan)}
.class-scroll{flex:1;overflow-y:auto;padding:20px 12px 20px 0;scrollbar-color:var(--purple) rgba(255,255,255,.06)}.class-card{min-height:112px;border:1px solid rgba(156,117,255,.2);background:rgba(7,13,30,.7);border-radius:18px;margin-bottom:12px;padding:18px;display:grid;grid-template-columns:96px 1fr auto;gap:20px;align-items:center;transition:.35s ease}.class-card.active{min-height:170px;border-color:rgba(178,72,255,.95);box-shadow:0 0 0 1px rgba(0,221,255,.6),0 0 42px rgba(139,53,255,.38);background:linear-gradient(135deg,rgba(10,23,56,.96),rgba(47,13,80,.48));animation:activePulse 2.8s ease-in-out infinite}@keyframes activePulse{0%,100%{box-shadow:0 0 0 1px rgba(0,221,255,.55),0 0 35px rgba(139,53,255,.26)}50%{box-shadow:0 0 0 1px rgba(0,221,255,.8),0 0 55px rgba(139,53,255,.45)}}.class-card.passed{opacity:.58}.class-art{width:84px;height:84px;border-radius:20px;background:linear-gradient(135deg,rgba(0,221,255,.14),rgba(139,53,255,.22));border:1px solid rgba(109,173,255,.24);display:grid;place-items:center;font-size:2.15rem;color:#8bdfff}.class-card.active .class-art{width:105px;height:105px;font-size:2.75rem;box-shadow:0 0 35px rgba(0,221,255,.18)}.period-label{color:var(--cyan);font-weight:950;font-size:.78rem;text-transform:uppercase}.class-name{font-size:1.65rem;font-weight:950;letter-spacing:-.04em;margin:4px 0}.class-time{color:#d7e0f8}.remaining{color:#cfd8f2;margin-top:9px}.badge{padding:9px 14px;border-radius:12px;background:rgba(139,53,255,.14);border:1px solid rgba(139,53,255,.24);color:#e1d1ff;font-weight:800}.badge.active{color:var(--cyan);background:rgba(0,221,255,.1);border-color:rgba(0,221,255,.25)}.open-class-card{margin-top:12px;max-width:360px}
.links-panel h2{margin-bottom:4px}.links-panel p{color:var(--muted);margin-bottom:14px}.class-links-list{max-height:470px;overflow-y:auto;scrollbar-color:var(--purple) rgba(255,255,255,.06)}.link-item{display:flex;align-items:center;justify-content:space-between;gap:14px;background:linear-gradient(90deg,rgba(0,112,214,.25),rgba(43,16,92,.22));border:1px solid rgba(91,157,255,.2);border-radius:15px;padding:14px 15px;margin-bottom:10px;color:#fff;text-decoration:none;transition:.2s}.link-item:hover{transform:translateX(3px);border-color:rgba(0,221,255,.5)}.link-left{display:flex;align-items:center;gap:12px;font-weight:850}.link-ico{width:26px;height:26px;border-radius:8px;object-fit:contain;background:rgba(255,255,255,.07);display:grid;place-items:center}
.half-day-btn{position:fixed;right:22px;bottom:22px;z-index:45;border:1px solid rgba(0,221,255,.28);background:rgba(7,13,30,.86);color:#dff8ff;border-radius:999px;padding:12px 15px;font-weight:850;box-shadow:0 0 26px rgba(0,221,255,.18)}
.period-picker{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:16px}.period-btn{background:rgba(255,255,255,.04);border:1px solid rgba(160,180,255,.16);border-radius:14px;padding:13px 8px;text-align:center;color:#fff}.period-btn.active{background:linear-gradient(135deg,#9230ff,#0d8cff);box-shadow:0 0 24px rgba(66,141,255,.33)}
.manager-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}.two-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.icon-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:9px;margin-bottom:12px}.icon-choice{height:48px;border:1px solid rgba(160,180,255,.14);background:rgba(255,255,255,.04);border-radius:13px;color:#fff;font-size:1.35rem}.icon-choice.active{border-color:var(--cyan);box-shadow:0 0 18px rgba(0,221,255,.28)}.advanced-options{margin:12px 0;color:#dce6ff}.advanced-options summary{cursor:pointer;font-weight:850}.manager-link-row,.missing-link-row{display:grid;grid-template-columns:1fr 1.15fr auto;gap:8px;margin-bottom:8px}.manager-link-row button,.missing-link-row button{border:1px solid rgba(255,71,103,.32);background:rgba(255,71,103,.08);color:#ff93a7;border-radius:10px;padding:0 10px}
.rotation-card,.info-box{display:flex;align-items:center;gap:16px;border:1px solid rgba(160,180,255,.14);background:rgba(255,255,255,.035);padding:15px;border-radius:16px;margin-bottom:12px}.day-code{width:58px;height:58px;border-radius:15px;display:grid;place-items:center;text-align:center;font-weight:950;background:rgba(17,140,255,.14);border:1px solid rgba(17,140,255,.25)}.rotation-card p,.info-box p{color:var(--muted);margin-top:3px}
.missing-head{display:flex;align-items:center;justify-content:space-between;margin:20px 0 18px}.missing-head h2{font-size:2.4rem;letter-spacing:-.06em}.missing-head h2 span{color:#8db5ff}.missing-head p{color:var(--muted)}.missing-board{display:grid;grid-template-columns:1fr 1fr;gap:18px}.missing-column{border-radius:20px;border:1px solid rgba(139,53,255,.38);background:rgba(7,13,30,.72);padding:14px}.missing-column.blue{border-color:rgba(17,140,255,.45)}.missing-column h3{display:flex;align-items:center;gap:10px;font-size:1.35rem;font-weight:950;margin-bottom:14px}.missing-column h3 span{background:rgba(255,255,255,.1);padding:4px 10px;border-radius:999px;font-size:.85rem}.task-card{position:relative;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px;margin-bottom:12px}.task-card h4{font-size:1.1rem;margin-bottom:7px}.task-card p{color:#cbd5f0;line-height:1.45;font-size:.9rem}.task-due{font-weight:900;margin:12px 0;color:#35aaff}.task-due.overdue{color:var(--red)}.task-chips{display:flex;gap:8px;flex-wrap:wrap}.task-chip{border:1px solid rgba(160,180,255,.18);border-radius:9px;padding:8px 10px;color:#fff;text-decoration:none;font-size:.82rem;background:rgba(255,255,255,.04)}.task-dots{position:absolute;right:12px;top:12px;border:0;background:transparent;color:#fff;font-size:1.2rem}.task-menu{display:none;position:absolute;right:38px;top:10px;background:#070d1e;border:1px solid rgba(160,180,255,.2);border-radius:12px;overflow:hidden;z-index:3}.task-menu button{display:block;width:130px;padding:10px;border:0;background:transparent;color:#fff;text-align:left}.task-menu button:hover{background:rgba(255,255,255,.08)}
.teacher-read-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:22px;align-items:start;margin-top:22px}.teacher-read-layout h2{font-size:3.5rem;letter-spacing:-.08em}.teacher-intro{color:#d7e0f8;line-height:1.65;font-size:1.08rem}.teacher-faq{display:grid;gap:12px}.teacher-faq div{border:1px solid rgba(160,180,255,.16);background:rgba(7,13,30,.75);border-radius:16px;padding:16px}.teacher-faq p{color:#cbd5f0;margin-top:6px}
.profile-menu{position:fixed;right:24px;top:92px;z-index:70;width:250px;background:#070d1e;border:1px solid rgba(160,180,255,.24);border-radius:18px;padding:16px;display:none;box-shadow:0 24px 80px rgba(0,0,0,.42)}.profile-menu.show{display:block}.profile-menu span{display:block;color:var(--muted);font-size:.86rem;margin:6px 0 12px}.profile-menu button{width:100%;border:1px solid rgba(255,71,103,.35);background:rgba(255,71,103,.08);color:#ff94a7;border-radius:12px;padding:11px;font-weight:850}
.toast{position:fixed;right:24px;top:96px;z-index:75;display:none;max-width:340px;background:rgba(7,13,30,.96);border:1px solid rgba(0,221,255,.32);border-radius:18px;padding:16px;box-shadow:0 24px 70px rgba(0,0,0,.45),0 0 30px rgba(0,221,255,.16)}.toast.show{display:block;animation:toastIn .35s ease both}@keyframes toastIn{from{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.toast h3{margin-bottom:6px}.toast p{color:#cbd5f0;line-height:1.45}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(8px);z-index:90;display:none;align-items:center;justify-content:center;padding:20px}.modal-bg.show{display:flex}.modal{width:min(490px,100%);max-height:92vh;overflow:auto;background:#070d1e;border:1px solid rgba(160,180,255,.24);border-radius:22px;padding:22px;box-shadow:0 30px 90px rgba(0,0,0,.55),0 0 50px rgba(139,53,255,.18);animation:modalIn .25s ease both}.wide-modal{width:min(720px,100%)}@keyframes modalIn{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal h3{font-size:1.45rem;margin-bottom:10px}.modal p{color:#cbd5f0;line-height:1.5;margin-bottom:14px}.modal-actions{justify-content:flex-end;margin-top:16px}.checklist{display:grid;gap:9px;margin-top:10px}.checklist-item{display:flex;gap:10px;align-items:center;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:11px}.checklist-item.done{border-color:rgba(44,230,166,.28);color:#b8ffe7}.announcement-list,.rotation-calendar-list{display:grid;gap:10px}.announcement-card,.rotation-day{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:13px}.announcement-card small,.rotation-day small{color:var(--muted)}
@media(max-width:1050px){.landing-grid,.auth-grid,.stats-grid,.schedule-layout,.manager-grid,.missing-board,.teacher-read-layout,.dashboard-grid{grid-template-columns:1fr}.top-nav{height:auto;flex-wrap:wrap;padding:14px}.brand-button{min-width:100%}.nav-tabs{overflow:auto;width:100%;padding-bottom:4px}.angled-dashboard{transform:none;animation:none}.trust-row,.teacher-note-grid,.quick-panel{grid-template-columns:1fr}.status-rail{display:none}.schedule-list-panel{max-height:none}.class-card{grid-template-columns:80px 1fr}.class-card .badge{grid-column:2}.class-art{width:70px;height:70px}.auth-card{margin:0;max-width:none}}
@media(max-width:650px){main,.top-nav{width:min(100% - 18px,1200px)}.hero-copy h1,.auth-copy h2{font-size:3.2rem}.page-title h2,.missing-head h2{font-size:1.8rem}.period-picker,.icon-grid{grid-template-columns:repeat(2,1fr)}.two-fields,.manager-link-row,.missing-link-row{grid-template-columns:1fr}.class-card{grid-template-columns:1fr}.missing-head{display:block}.missing-head .primary-small{width:100%;margin-top:12px}.brand-button small{display:none}.stat-card b{font-size:1.65rem}.half-day-btn{right:12px;bottom:12px}.auth-card{padding:22px}.teacher-read-layout h2{font-size:2.5rem}}
