*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f8f2;--bg2:#eff0ea;--bg3:#e3e4dc;--paper:#fff;--ink:#0d0d0d;--ink2:#3a3a30;--muted:#888878;--green:#2d8a3e;--greenl:#4caf62;--greenbg:#e8f5ea;--red:#b83030;--redbg:#fae8e8;--amber:#9a6c00;--pixel:"StardewValley", "DM Mono", monospace}body{background:var(--bg);color:var(--ink);flex-direction:column;min-height:100vh;font-family:DM Sans,sans-serif;font-size:18px;display:flex}.App{flex-direction:column;min-height:100vh;display:flex}.body{flex:1;display:flex}.header{background:var(--bg2);z-index:100;flex-shrink:0;align-items:stretch;height:68px;display:flex;position:sticky;top:0}.header-brand{cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;width:183px;margin-right:-30px;display:flex}.header-brand img{width:110px}.header-mid{flex:1;align-items:center;gap:28px;padding:0 34px;display:flex}.h-date{letter-spacing:.06em;color:var(--muted);font-family:DM Mono,monospace;font-size:14px}.h-live{color:var(--green);align-items:center;gap:8px;font-family:DM Mono,monospace;font-size:14px;display:flex}.h-join-btn{letter-spacing:.08em;text-transform:uppercase;color:var(--green);background:var(--paper);border:1.5px solid var(--green);cursor:pointer;margin-left:auto;padding:8px 16px;font-family:DM Mono,monospace;font-size:13px;transition:background .12s,color .12s}.h-join-btn:hover{background:var(--green);color:#fff}.live-sq{background:var(--greenl);width:8px;height:8px;animation:2s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.15}}.sidebar{background:var(--bg2);z-index:50;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;width:90px;height:calc(100vh - 68px);padding:20px 0;display:flex;position:sticky;top:68px}.nav-item{cursor:pointer;width:76px;height:76px;color:var(--muted);justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex;position:relative}.nav-item:hover{background:var(--bg3);color:var(--ink2)}.nav-item.active{background:var(--greenbg);color:var(--green)}.nav-item:after{content:attr(data-label);background:var(--ink);color:#fff;letter-spacing:.06em;white-space:nowrap;opacity:0;pointer-events:none;z-index:9999;padding:7px 14px;font-family:DM Mono,monospace;font-size:15px;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 14px);transform:translateY(-50%)}.nav-item:hover:after{opacity:1}.sb-sp{flex:1}.main{flex:1;justify-content:center;display:flex;overflow-y:auto}.main-inner{width:100%;max-width:1200px;padding:34px 39px 101px}.cards-loading{grid-column:1/-1;justify-content:center;align-items:center;min-height:360px;display:flex}.cards-loading--fill{align-items:flex-start;min-height:calc(100vh - 200px);padding-top:120px}.sec-head{margin-bottom:17px}.sec-title{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;font-size:14px;font-weight:500}.filter-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:22px;display:flex}.chip{letter-spacing:.05em;cursor:pointer;color:var(--muted);background:var(--bg2);border:none;padding:7px 20px;font-family:DM Mono,monospace;font-size:14px;transition:all .12s}.chip:hover{background:var(--bg3);color:var(--ink)}.chip.on{background:var(--greenbg);color:var(--green)}.chip.warn{background:var(--redbg);color:var(--red)}.grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:11px;margin-bottom:45px;display:grid}.card{background:var(--paper);cursor:pointer;transition:background .15s,transform .18s;position:relative}.card:hover{transform:translateY(-3px)}.card.active{background:#f9fff8}.card.active:before{content:"";background:var(--greenl);z-index:1;width:3px;position:absolute;top:0;bottom:0;left:0}.card.wide{grid-column:span 2}.card-promo{background:var(--greenbg);text-align:center;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:28px;display:flex}.card-promo:hover{background:#daf0de;transform:translateY(-3px)}.promo-title{color:var(--green);font-size:20px;font-weight:600;line-height:1.4}.promo-sub{color:var(--green);opacity:.7;letter-spacing:.07em;font-family:DM Mono,monospace;font-size:14px}.card-img{justify-content:center;align-items:flex-end;height:151px;display:flex;position:relative;overflow:hidden}.card.wide .card-img{justify-content:space-around;height:165px}.ci-1{background:#cfe0cc}.ci-2{background:#dedad0}.ci-3{background:#c5d4e0}.ci-4{background:#ddd0da}.ci-5{background:#ccdacf}.ci-6{background:#dbd8c2}.ci-7{background:#c5d9d9}.ci-8{background:#d8cede}.ci-9{background:#d2dcc8}.ci-a{background:#dcd4c0}.ci-b{background:#c8d4dc}.ci-c{background:#d4ccd8}.img-tag{letter-spacing:.07em;z-index:2;padding:4px 8px;font-family:DM Mono,monospace;font-size:13px;font-weight:500;position:absolute;top:13px;left:13px}.t-ait{color:#8aeee0;background:#12463cd1}.t-se{color:#f5b0b0;background:#520e0ed1}.t-wd{color:#c5b8f5;background:#241054d1}.t-bd{color:#f0d888;background:#543204d1}.t-li{color:#f5b0d5;background:#520e32d1}.img-dot{z-index:2;width:10px;height:10px;position:absolute;top:14px;right:14px}.d-on{background:var(--greenl);animation:2s infinite blink}.d-re{background:var(--green);opacity:.65}.d-off{background:#82826e4d}.card-body{padding:18px 20px 20px}.card-who{align-items:center;gap:10px;margin-bottom:8px;display:flex}.av{width:28px;height:28px;color:var(--muted);background:var(--bg2);flex-shrink:0;justify-content:center;align-items:center;font-family:DM Mono,monospace;font-size:11px;font-weight:500;display:flex}.av-g{background:var(--greenbg);color:var(--green)}.who-name{letter-spacing:-.01em;font-size:17px;font-weight:600}.who-dept{color:var(--muted);margin-left:3px;font-family:DM Mono,monospace;font-size:13px}.card-task{margin-bottom:12px;font-size:17px;font-weight:500;line-height:1.3}.prog-bar{background:var(--bg2);height:3px;margin-bottom:6px}.prog-fill{height:100%}.pf-g{background:var(--green)}.pf-y{background:var(--amber)}.pf-r{background:var(--red)}.prog-meta{color:var(--muted);justify-content:space-between;font-family:DM Mono,monospace;font-size:13px;display:flex}.card-ddl{margin-top:6px;font-family:DM Mono,monospace;font-size:13px}.ddl-u{color:var(--red)}.ddl-s{color:var(--amber)}.ddl-o{color:var(--green)}.pixel-box{--pixel-border-color:var(--ink);position:relative}.pixel-corner{background:var(--pixel-border-color);pointer-events:none;z-index:1;width:3px;height:3px;position:absolute}.pixel-corner-tl{top:-5px;left:-5px}.pixel-corner-tr{top:-5px;right:-5px}.pixel-corner-bl{bottom:-5px;left:-5px}.pixel-corner-br{bottom:-5px;right:-5px}.pixel-box-retro{--pixel-base:var(--paper);--pixel-highlight:#eff0ea;--pixel-shadow:#0000001a;box-shadow:0 3px 0 var(--pixel-highlight), 0 -3px 0 var(--pixel-base), 3px 0 0 var(--pixel-base), -3px 0 0 var(--pixel-base), 0 -6px 0 var(--pixel-border-color), 0 6px 0 var(--pixel-border-color), 6px 0 0 var(--pixel-border-color), -6px 0 0 var(--pixel-border-color), 9px 0 0 var(--pixel-shadow), 0 9px 0 var(--pixel-shadow)}.pixel-pt{pointer-events:none;width:calc(100% + 12px);height:0;position:absolute;top:-3px;left:-6px}.pixel-pt:before,.pixel-pt:after{content:"";background:var(--pixel-border-color);width:3px;height:3px;position:absolute;top:0}.pixel-pt:before{left:3px}.pixel-pt:after{right:3px}.pixel-pb{pointer-events:none;width:calc(100% + 12px);height:0;position:absolute;bottom:0;left:-6px}.pixel-pb:before,.pixel-pb:after{content:"";background:var(--pixel-highlight);width:3px;height:3px;position:absolute;top:-3px}.pixel-pb:before{box-shadow:0 3px 0 var(--pixel-border-color), 0 6px 0 var(--pixel-shadow), -3px 3px 0 var(--pixel-shadow);left:3px}.pixel-pb:after{box-shadow:0 3px 0 var(--pixel-border-color), 0 6px 0 var(--pixel-shadow), 3px 3px 0 var(--pixel-shadow);right:3px}.gate-layout{flex-direction:column;min-height:100dvh;display:flex;position:relative;overflow-x:hidden}.gate-bg{object-fit:cover;object-position:bottom center;z-index:-1;pointer-events:none;width:100vw;height:70vh;image-rendering:pixelated;position:fixed;bottom:0;left:0;-webkit-mask-image:linear-gradient(#0000 0%,#000 100%);mask-image:linear-gradient(#0000 0%,#000 100%)}.gate-header{z-index:10;background:0 0;justify-content:space-between;align-items:center;height:88px;padding:0 32px;display:flex;position:relative}.gate-brand{cursor:pointer;align-items:center;display:flex}.gate-brand img{height:32px;display:block}.gate-header-mid{letter-spacing:.06em;color:var(--ink,#1a1a1a);align-items:center;gap:18px;font-family:DM Mono,monospace;font-size:12px;display:flex}.gate-date{opacity:.75}.gate-online{color:var(--green,#2d8a3e);text-transform:uppercase;align-items:center;gap:6px;display:inline-flex}.gate-online-dot{background:var(--greenl,#4caf62);width:6px;height:6px;animation:2s infinite gate-blink}@keyframes gate-blink{0%,to{opacity:1}50%{opacity:.4}}.gate-content{flex-direction:column;flex:1;width:100%;display:flex}.create-room-page{flex:1;justify-content:center;align-items:flex-start;min-height:100%;padding:48px 24px;display:flex}.create-room-card{--pixel-base:#f5f4ee;--pixel-highlight:#fff;--pixel-border-color:#2d2d2a;--pixel-shadow:#2d2d2a2e;background:var(--pixel-base);width:100%;max-width:560px;padding:32px 36px}.create-room-title{letter-spacing:.04em;color:var(--ink,#1a1a1a);margin:0 0 6px;font-family:StardewValley,DM Mono,monospace;font-size:22px}.create-room-sub{color:var(--muted,#777);margin:0 0 24px;font-family:DM Sans,sans-serif;font-size:13px;line-height:1.5}.create-room-form{flex-direction:column;gap:20px;display:flex}.create-room-field{flex-direction:column;gap:8px;display:flex}.create-room-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted,#777);font-family:DM Mono,monospace;font-size:11px}.create-room-input{background:#fff;border:1.5px solid #2d2d2a;border-radius:0;outline:none;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:15px}.create-room-input:focus{border-color:var(--green,#2d8a3e)}.create-room-bg-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.create-room-bg-option{cursor:pointer;background:#fff;border:2px solid #0000;flex-direction:column;align-items:center;gap:6px;padding:0 0 8px;transition:border-color .15s;display:flex}.create-room-bg-option.active{border-color:var(--green,#2d8a3e)}.create-room-bg-thumb{aspect-ratio:16/9;object-fit:cover;width:100%;image-rendering:pixelated;display:block}.create-room-bg-caption{color:var(--ink,#1a1a1a);font-family:DM Mono,monospace;font-size:11px}.create-room-error{color:#a33;background:#fdecec;border:1px solid #e3a;padding:8px 10px;font-family:DM Mono,monospace;font-size:12px}.create-room-info{color:#a33;font-family:DM Mono,monospace;font-size:12px;line-height:1.5}.create-room-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.create-room-btn{cursor:pointer;border:1.5px solid #2d2d2a;padding:10px 20px;font-family:DM Mono,monospace;font-size:13px;transition:transform 80ms}.create-room-btn:disabled{opacity:.5;cursor:not-allowed}.create-room-btn:not(:disabled):active{transform:translateY(1px)}.create-room-btn.cancel{color:var(--ink,#1a1a1a);background:#fff}.create-room-btn.primary{background:var(--green,#2d8a3e);color:#fff;border-color:#1f5e2a}.create-room-card-rejected{--pixel-border-color:#c44;--pixel-shadow:#c4444438}.create-room-title-rejected{color:#c44}.join-modal-backdrop{z-index:200;background:#00000059;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.join-modal-card{width:100%;max-width:480px;max-height:calc(100vh - 60px);overflow-y:auto}.auth-page{background:var(--bg,#f5f4ee);min-height:100dvh;position:relative;overflow:hidden}.auth-bg{object-fit:cover;filter:blur(4px);z-index:1;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0;transform:scale(1.03)}.auth-card-wrap{z-index:3;width:min(440px,100vw - 48px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.auth-card{--pixel-base:#fff;--pixel-highlight:#eff0ea;--pixel-border-color:#2d2d2a;--pixel-shadow:#2d2d2a2e;background:var(--pixel-base);padding:34px 38px 30px}.auth-title{letter-spacing:.04em;color:var(--ink,#1a1a1a);margin:0 0 6px;font-family:StardewValley,DM Mono,monospace;font-size:22px}.auth-sub{color:var(--muted,#777);margin:0 0 22px;font-family:DM Sans,sans-serif;font-size:13px;line-height:1.5}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted,#777);font-family:DM Mono,monospace;font-size:11px}.auth-input{background:#fff;border:1.5px solid #2d2d2a;border-radius:0;outline:none;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:15px}.auth-input:focus{border-color:var(--green,#2d8a3e)}.auth-btn{letter-spacing:.1em;text-transform:uppercase;background:var(--green,#2d8a3e);color:#fff;cursor:pointer;border:1.5px solid #1f5e2a;margin-top:8px;padding:11px 22px;font-family:DM Mono,monospace;font-size:13px;transition:transform 80ms}.auth-btn:active{transform:translateY(1px)}.auth-msg{padding:8px 10px;font-family:DM Mono,monospace;font-size:12px;line-height:1.5}.auth-msg.error{color:#a33;background:#fdecec;border:1px solid #e3a}.auth-msg.success{color:var(--green,#2d8a3e);background:#eef7ef;border:1px solid #b5d8bc}.auth-swap{color:var(--muted,#777);text-align:center;margin:20px 0 0;font-family:DM Mono,monospace;font-size:12px}.auth-swap-link{color:var(--green,#2d8a3e);cursor:pointer;font:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.auth-swap-link:hover{opacity:.7}.rooms-page .rooms-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:8px;display:grid}.rooms-page .rcard{background:var(--paper);cursor:pointer;transition:background .15s,transform .18s;position:relative;overflow:hidden}.rooms-page .rcard:hover{transform:translateY(-2px)}.rooms-page .rcard.live:before{content:"";background:var(--greenl);z-index:1;width:2px;position:absolute;top:0;bottom:0;left:0}.rooms-page .rcard.live{background:#f9fff8}.rooms-page .rcard.w2{grid-column:span 2}.rooms-page .rcard.w3{grid-column:span 3}.rooms-page .rcard.w4{grid-column:span 4}.rooms-page .rcard-header{justify-content:space-between;align-items:center;padding:10px 16px 8px;display:flex}.rooms-page .rh-left{align-items:center;gap:8px;display:flex}.rooms-page .rh-course{letter-spacing:.08em;padding:3px 7px;font-family:DM Mono,monospace;font-size:9px;font-weight:500}.rooms-page .rhc-ait{color:#1a6b63;background:#12463c2e}.rooms-page .rhc-se{color:#8b2020;background:#520e0e2e}.rooms-page .rhc-bd{color:#7a5008;background:#5432042e}.rooms-page .rhc-wd{color:#4a3380;background:#2410542e}.rooms-page .rh-name{letter-spacing:.09em;text-transform:uppercase;color:var(--ink2);font-family:DM Mono,monospace;font-size:11px}.rooms-page .rh-right{color:var(--green);align-items:center;gap:5px;font-family:DM Mono,monospace;font-size:10px;display:flex}.rooms-page .rh-dot{background:var(--greenl);width:7px;height:7px;animation:2s ease-in-out infinite blink}.rooms-page .rcard-stage{background-repeat:no-repeat;background-size:1120px;justify-content:space-evenly;align-items:flex-end;padding:0 16px 12px;display:flex;position:relative;overflow:hidden}.rooms-page .rcard.w1 .rcard-stage{height:151px;padding:0 10px 12px}.rooms-page .rcard.w2 .rcard-stage{height:160px;padding:0 16px 12px}.rooms-page .rcard.w3 .rcard-stage{height:170px;padding:0 24px 14px}.rooms-page .rcard.w4 .rcard-stage{height:220px;padding:0 40px 16px}.rooms-page .rfull-member{flex-direction:column;align-items:center;gap:6px;display:flex}.rooms-page .rfm-name{letter-spacing:.06em;text-transform:uppercase;color:#fff;text-shadow:0 1px 2px #0009;text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-family:DM Mono,monospace;font-size:11px;overflow:hidden}.rooms-page .rcard-body{border-top:1.5px solid var(--bg2);padding:13px 16px 16px}.rooms-page .rcard-title{color:var(--ink);letter-spacing:-.01em;font-size:17px;font-weight:600;line-height:1.3}.rooms-page .rcard-title-row{align-items:center;gap:10px;margin-bottom:5px;display:flex}.rooms-page .rcard-room-icon{color:var(--muted);flex-shrink:0}.rooms-page .rcard.w4 .rcard-title{font-size:20px}.rooms-page .rcard.w4 .rcard-title-row{margin-bottom:4px}.rooms-page .rcard-subtitle{color:var(--green);align-items:center;gap:6px;margin-bottom:14px;font-size:14px;font-weight:500;display:flex}.rooms-page .rcard-subtitle-dot{background:var(--greenl);width:8px;height:8px;animation:2s ease-in-out infinite blink}.rooms-page .rcard-stats{color:var(--muted);justify-content:space-between;margin-bottom:7px;font-family:DM Mono,monospace;font-size:13px;display:flex}.rooms-page .rcard-prog-bar{background:var(--bg2);height:3px;margin-bottom:6px}.rooms-page .rcard-prog-fill{background:var(--green);height:100%}.rooms-page .rcard-prog-fill.warn{background:var(--amber)}.rooms-page .rcard-prog-fill.urgent{background:var(--red)}.rooms-page .rcard-footer{color:var(--muted);justify-content:space-between;font-family:DM Mono,monospace;font-size:13px;display:flex}.rooms-page .rcard-footer .ddl-u{color:var(--red)}.rooms-page .rcard-footer .ddl-s{color:var(--amber)}.rooms-page .rcard-footer .ddl-o{color:var(--green)}.rooms-page .rcard-create{background:var(--bg2);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:120px;transition:background .12s;display:flex}.rooms-page .rcard-create:hover{background:var(--bg3)}.rooms-page .rcard-create-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;font-size:11px}.rooms-page .rcard-create-sub{color:var(--muted);font-size:13px}.push-out-wrap{--push-out-color:var(--ink,#1a1a1a);display:inline-block;position:relative}.push-out{--duration:.85;width:100px;height:100px;position:relative;overflow:hidden}.push-out>div:first-of-type{width:20px;height:20px;animation:push-out-slide calc(var(--duration) * 1s) infinite alternate ease-in-out;position:absolute;top:100%;left:0;transform:translateY(-100%)}.push-out>div:first-of-type:after{animation:push-out-flip calc(var(--duration) * 1s) infinite alternate ease-in-out;background:var(--push-out-color);content:"";width:100%;height:100%;position:absolute}.push-out>div:nth-of-type(2){background:var(--push-out-color);width:20px;height:30px;position:absolute;top:100%;left:50%;transform:translate(-50%,-100%)}.push-out:after,.push-out:before{animation-timing-function:ease;animation-iteration-count:infinite;animation-duration:calc(var(--duration) * 4s);background:var(--push-out-color);content:"";width:20px;height:40px;position:absolute;bottom:0}.push-out:after{animation-name:push-out-pushed-1;right:0}.push-out:before{animation-name:push-out-pushed-2;left:0}@keyframes push-out-pushed-1{0%,18.125%,50%,68.125%,to{transform:translate(0)}25%,43.125%,75%,93.125%{transform:translateY(100%)}}@keyframes push-out-pushed-2{0%,18.125%,50%,68.125%,to{transform:translateY(100%)}25%,43.125%,75%,93.125%{transform:translate(0)}}@keyframes push-out-flip{0%{transform:translate(0)rotate(0)}50%{transform:translateY(-80px)rotate(90deg)}to{transform:translate(0)rotate(180deg)}}@keyframes push-out-slide{to{transform:translateY(-100%)translate(80px)}}.confirm-modal-backdrop{z-index:500;background:#00000038;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.confirm-modal-card{--pixel-base:#f5f4ee;--pixel-highlight:#fff;--pixel-border-color:#2d2d2a;--pixel-shadow:#2d2d2a2e;background:var(--pixel-base);width:100%;max-width:420px;padding:28px 32px 26px}.confirm-modal-title{letter-spacing:.04em;color:var(--ink,#1a1a1a);margin:0 0 8px;font-family:StardewValley,DM Mono,monospace;font-size:22px}.confirm-modal-message{color:var(--muted,#777);margin:0 0 24px;font-family:DM Sans,sans-serif;font-size:13px;line-height:1.5}.confirm-modal-actions{justify-content:flex-end;gap:10px;display:flex}.confirm-modal-btn{color:var(--ink,#1a1a1a);cursor:pointer;background:#fff;border:1.5px solid #2d2d2a;padding:10px 20px;font-family:DM Mono,monospace;font-size:13px;transition:transform 80ms,background .12s}.confirm-modal-btn:active{transform:translateY(1px)}.confirm-modal-btn.cancel:hover{background:var(--bg2,#f2f0ea)}.confirm-modal-btn.primary{background:var(--green,#2d8a3e);color:#fff;border-color:#1f5e2a}.confirm-modal-btn.primary:hover{background:#246b32}.confirm-modal-btn.danger{color:var(--red,#b83030);border-color:var(--red,#b83030);background:#f5f4ee}.confirm-modal-btn.danger:hover{background:#b8303014}.live-loading{background:var(--bg);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:22px;height:calc(100vh - 68px);padding-bottom:18vh;display:flex}.live-loading-text{letter-spacing:.06em;color:var(--green);font-family:DM Mono,monospace;font-size:14px}.live-page{background:var(--bg);flex:1;justify-content:center;height:calc(100vh - 68px);display:flex;overflow:hidden}.live-main{flex-direction:column;width:100%;min-width:0;max-width:calc(222.222vh - 714.222px);padding:28px 34px 24px;transition:max-width .2s;display:flex;overflow:hidden}.live-page.panel-hidden .live-main{max-width:100vw}.live-header{background:var(--paper);--pixel-base:var(--paper);--pixel-border-color:#9b9b9b;--pixel-highlight:var(--bg2);--pixel-shadow:#0000001a;flex-shrink:0;justify-content:space-between;align-items:center;width:100%;max-width:calc(222.222vh - 782.222px);margin:0 auto 22px;padding:13px 20px;display:flex}.live-room-name{font-family:var(--pixel);letter-spacing:.04em;color:var(--ink);font-smooth:never;font-size:20px;font-weight:400}.live-meta{color:var(--muted);letter-spacing:.04em;align-items:center;gap:18px;font-family:DM Mono,monospace;font-size:12px;display:flex}.live-meta-badge{color:var(--green);align-items:center;gap:7px;display:flex}.live-dot{background:var(--greenl);flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite blink;display:inline-block}.live-stage{flex-direction:column;gap:22px;min-height:0;display:flex}.live-canvas{aspect-ratio:4/3;--pixel-border-color:#9b9b9b;--pixel-base:#ddeadb;--pixel-highlight:#c5d6c2;--pixel-shadow:#0000001a;background:#ddeadb;flex-shrink:0;justify-content:center;align-items:center;width:100%;max-width:calc(222.222vh - 782.222px);max-height:calc(100vh - 352px);margin:0 auto;display:flex;position:relative}.live-canvas:after{content:"";pointer-events:none;background:linear-gradient(#0000,#1e3c230f);height:56px;position:absolute;bottom:0;left:0;right:0}.live-members-row{flex-shrink:0;align-items:flex-start;gap:16px;width:100%;max-width:calc(222.222vh - 782.222px);margin:0 auto;display:flex}.live-members{scrollbar-width:thin;flex:1;gap:16px;min-width:0;margin-left:-6px;padding:10px 0 14px 6px;display:flex;overflow-x:auto}.live-members::-webkit-scrollbar{height:4px}.live-members::-webkit-scrollbar-track{background:0 0}.live-members::-webkit-scrollbar-thumb{background:var(--bg3)}.live-member-card{background:var(--paper);cursor:pointer;--pixel-border-color:#9b9b9b;--pixel-base:var(--paper);--pixel-highlight:var(--bg2);--pixel-shadow:#0000001a;border:none;flex-shrink:0;align-items:center;gap:11px;min-width:172px;padding:12px 16px 12px 14px;transition:transform .18s;display:flex;position:relative}.live-member-card:hover{transform:translateY(-2px)}.live-member-card.active{background:var(--greenbg);--pixel-border-color:var(--green);--pixel-base:var(--greenbg);--pixel-highlight:#d8ecd8;--pixel-shadow:#2d8a3e33}.live-member-card.is-self{--pixel-border-color:var(--greenl);--pixel-base:#f9fff8;--pixel-highlight:var(--greenbg);--pixel-shadow:#4caf622e;background:#f9fff8}.live-av{width:28px;height:28px;color:var(--muted);background:var(--bg2);flex-shrink:0;justify-content:center;align-items:center;font-family:DM Mono,monospace;font-size:10px;font-weight:600;display:flex}.live-av-img{object-fit:cover;flex-shrink:0;width:28px;height:28px;display:block}.live-av.av-g{background:var(--greenbg);color:var(--green)}.live-member-name{color:var(--ink);white-space:nowrap;letter-spacing:-.01em;font-size:15px;font-weight:500}.live-member-pct{color:var(--muted);margin-left:auto;font-family:DM Mono,monospace;font-size:12px;font-weight:500}.live-member-pct.done{color:var(--green)}.live-member-pct.warn{color:var(--amber)}.live-member-pct.urgent{color:var(--red)}.live-member-overall-btn{letter-spacing:.1em;text-transform:uppercase;min-height:52px;color:var(--muted);background:var(--paper);cursor:pointer;--pixel-border-color:#9b9b9b;--pixel-base:var(--paper);--pixel-highlight:var(--bg2);--pixel-shadow:#0000001a;border:none;flex-shrink:0;justify-content:center;align-items:center;margin:10px 0 14px;padding:0 24px;font-family:DM Mono,monospace;font-size:11px;transition:color .15s,background .15s;display:inline-flex}.live-member-overall-btn:hover{color:var(--ink);background:var(--bg2);--pixel-base:var(--bg2);--pixel-highlight:var(--bg3)}.live-member-overall-btn.active{color:var(--green);background:var(--greenbg);--pixel-border-color:var(--green);--pixel-base:var(--greenbg);--pixel-highlight:#d8ecd8;--pixel-shadow:#2d8a3e33}.live-member-leave-btn{width:52px;min-height:52px;color:var(--red);cursor:pointer;--pixel-border-color:var(--red);--pixel-base:#fff;--pixel-highlight:#ffeceb;--pixel-shadow:#c83c3c33;background:#fff;border:none;flex-shrink:0;justify-content:center;align-items:center;margin:10px 0 14px;padding:0;transition:background .15s;display:inline-flex}.live-member-leave-btn:hover{--pixel-base:#fff5f5;background:#fff5f5}.live-panel{--pixel-base:#fff;--pixel-border-color:#9b9b9b;--pixel-highlight:#e7e7e7;--pixel-shadow:#0000001a;background:#fff;flex-direction:column;flex-shrink:0;width:280px;max-height:calc(100vh - 194px);margin:28px 28px 28px 0;transition:width .2s,margin-right .2s;display:flex;overflow:visible}.live-panel-badge{background:var(--greenbg);width:35px;height:35px;color:var(--green);letter-spacing:0;z-index:2;--pixel-base:var(--greenbg);--pixel-border-color:#1a1a1a;--pixel-highlight:#d8ecd8;--pixel-shadow:#2d8a3e33;justify-content:center;align-items:center;padding-top:3px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;display:flex;position:absolute;top:-16px;left:-16px}.live-panel-badge-img{object-fit:cover;z-index:-99;width:41px;height:41px;display:block;position:absolute;top:-3px;bottom:-3px}.live-panel.hidden .live-panel-close{opacity:0;pointer-events:none}.live-panel-close{cursor:pointer;opacity:.75;z-index:3;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:opacity .2s;display:flex;position:absolute;top:14px;right:14px}.live-panel-close:hover{opacity:1}.live-panel-close img{image-rendering:pixelated;display:block}.live-panel.hidden{width:0;box-shadow:none;margin-right:0;overflow:hidden}.live-panel.hidden:before,.live-panel.hidden .live-panel-badge{display:none}.live-panel-header{border-bottom:1.5px solid var(--bg2);flex-shrink:0;padding:42px 22px 32px}.live-panel-who{align-items:center;gap:10px;margin-bottom:6px;display:flex}.live-panel-name{color:var(--ink);letter-spacing:-.01em;font-size:17px;font-weight:600}.live-panel-mode{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;font-size:10px}.live-panel-body{flex-direction:column;flex:1;gap:28px;padding:32px 22px 30px;display:flex;overflow-y:auto}.live-task-section-title{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-family:DM Mono,monospace;font-size:10px}.live-task-row{margin-bottom:18px}.live-task-row:last-child{margin-bottom:0}.live-task-label{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.live-task-name{color:var(--ink);letter-spacing:-.01em;font-size:14px;font-weight:500}.live-task-pct{color:var(--muted);font-family:DM Mono,monospace;font-size:12px}.live-task-pct-wrap{align-items:center;gap:6px;display:inline-flex;position:relative}.live-task-menu-btn{cursor:pointer;width:20px;height:20px;color:var(--muted);opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:opacity .12s,color .12s;display:flex}.live-task-menu-btn:hover{opacity:1;color:var(--ink)}.live-task-menu{-webkit-backdrop-filter:blur(6px);z-index:50;--pixel-base:#eff0eaeb;--pixel-border-color:#d8d8d0;--pixel-highlight:#e3e4dceb;--pixel-shadow:#0000001a;background:#eff0eaeb;min-width:160px;padding:4px;position:absolute;top:calc(100% + 8px);right:0}.live-task-menu-item{text-align:left;width:100%;color:var(--ink2);cursor:pointer;background:0 0;border:none;padding:8px 12px;font-family:DM Mono,monospace;font-size:12px;transition:background .12s,color .12s}.live-task-menu-item:hover{background:var(--bg3);color:var(--ink)}.live-task-pct.done{color:var(--green)}.live-task-pct.warn{color:var(--amber)}.live-task-pct.urgent{color:var(--red)}.live-task-slider{appearance:none;background:var(--bg2);cursor:pointer;outline:none;width:100%;height:3px;margin:0;padding:0}.live-task-slider::-webkit-slider-runnable-track{background:var(--bg2);height:3px}.live-task-slider::-webkit-slider-thumb{appearance:none;background:var(--green);cursor:pointer;border:none;border-radius:0;width:12px;height:12px;margin-top:-5px}.live-task-slider::-moz-range-thumb{background:var(--green);cursor:pointer;border:none;border-radius:0;width:12px;height:12px}.live-task-bar{background:var(--bg2);height:3px}.live-task-bar-fill{background:var(--green);height:100%;transition:width .3s}.live-task-bar-fill.warn{background:var(--amber)}.live-task-bar-fill.urgent{background:var(--red)}.live-panel-kick{letter-spacing:.12em;text-transform:uppercase;color:var(--red);cursor:pointer;opacity:.75;background:0 0;border:none;margin-top:6px;padding:0;font-family:DM Mono,monospace;font-size:10px;transition:opacity .12s;display:inline-block}.live-panel-kick:hover{opacity:1;text-decoration:underline}.live-add-task-btn{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:7px;margin-top:12px;padding:8px 0;font-family:DM Mono,monospace;font-size:11px;transition:color .15s;display:flex}.live-add-task-btn:hover{color:var(--green)}.live-modal-backdrop{z-index:100;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.live-modal{background:var(--paper);--pixel-base:var(--paper);--pixel-border-color:#9b9b9b;--pixel-highlight:var(--bg2);--pixel-shadow:#0003;flex-direction:column;width:420px;max-width:calc(100vw - 80px);max-height:calc(100vh - 160px);display:flex}.live-modal-header{border-bottom:1.5px solid var(--bg2);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.live-modal-title{letter-spacing:.12em;text-transform:uppercase;color:var(--ink);font-family:DM Mono,monospace;font-size:13px;font-weight:500}.live-modal-close{cursor:pointer;opacity:.75;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:opacity .15s;display:flex}.live-modal-close:hover{opacity:1}.live-modal-close img{image-rendering:pixelated;display:block}.live-modal-body{flex-direction:column;flex:1;gap:4px;padding:10px 12px 18px;display:flex;overflow-y:auto}.live-modal-empty{text-align:center;color:var(--muted);padding:24px 8px;font-family:DM Mono,monospace;font-size:12px}.live-modal-task{cursor:pointer;text-align:left;background:0 0;border:none;flex-direction:column;gap:4px;padding:12px 14px;transition:background .12s;display:flex}.live-modal-task:hover{background:var(--bg2)}.live-modal-task-top{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.live-modal-task-name{color:var(--ink);letter-spacing:-.01em;font-size:14px;font-weight:500}.live-modal-task-frac{color:var(--muted);flex-shrink:0;font-family:DM Mono,monospace;font-size:12px}.live-modal-task-meta{color:var(--muted);align-items:center;gap:8px;font-family:DM Mono,monospace;font-size:12px;display:flex}.live-modal-task-dot{opacity:.5}.live-task-section{flex-shrink:0;min-height:220px}.live-history-section{flex-direction:column;flex:1;min-height:0;display:flex}.live-history-list{scrollbar-width:none;flex:1;min-height:0;overflow-y:auto}.live-history-list::-webkit-scrollbar{display:none}.live-history-item{flex-direction:column;align-items:flex-start;gap:2px;padding:8px 0;display:flex}.live-history-text{color:var(--muted);letter-spacing:.01em;font-family:DM Mono,monospace;font-size:11px;line-height:1.55}.live-history-text strong{color:var(--ink2);font-weight:500}.live-history-time{color:var(--muted);opacity:.7;letter-spacing:.03em;font-family:DM Mono,monospace;font-size:9px}.live-history-actions{gap:6px;margin-top:6px;display:flex}.live-history-approve,.live-history-reject{letter-spacing:.08em;text-transform:uppercase;border:1.5px solid var(--bg3);cursor:pointer;background:0 0;padding:5px 10px;font-family:DM Mono,monospace;font-size:10px;transition:background .12s,color .12s,border-color .12s}.live-history-approve{color:var(--green);border-color:var(--green)}.live-history-approve:hover{background:var(--greenbg)}.live-history-reject{color:var(--muted)}.live-history-reject:hover{color:var(--red);border-color:var(--red)}.mt-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.mt-title{color:var(--ink);letter-spacing:-.01em;font-size:22px;font-weight:600}.mt-add-btn{letter-spacing:.07em;color:var(--green);border:1.5px solid var(--green);cursor:pointer;background:0 0;align-items:center;gap:7px;padding:10px 20px;font-family:DM Mono,monospace;font-size:13px;transition:background .15s,color .15s;display:flex}.mt-add-btn:hover{background:var(--greenbg)}.mt-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.mt-card{background:var(--paper);cursor:pointer;padding:20px 24px;transition:transform .18s;position:relative}.mt-card:hover{transform:translateY(-2px)}.mt-card-top{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:10px;display:flex}.mt-card-name{color:var(--ink);letter-spacing:-.01em;font-size:17px;font-weight:500;line-height:1.3}.mt-card-pct{color:var(--muted);flex-shrink:0;font-family:DM Mono,monospace;font-size:15px;font-weight:500}.mt-card-pct.urgent{color:var(--red)}.mt-card-pct.warn{color:var(--amber)}.mt-card-pct.done{color:var(--green)}.mt-prog-bar{background:var(--bg2);height:2px;margin-bottom:10px}.mt-prog-fill{background:var(--green);height:100%;transition:width .3s}.mt-prog-fill.urgent{background:var(--red)}.mt-prog-fill.warn{background:var(--amber)}.mt-card-meta{align-items:baseline;gap:10px;margin-bottom:8px;font-family:DM Mono,monospace;font-size:13px;display:flex}.mt-card-ddl{color:var(--green)}.mt-card-ddl.urgent{background:#2d8a3e;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.mt-card-ddl.urgent>svg{margin-top:-3px}.mt-card-ddl.warn{color:var(--amber)}.mt-card-dot{color:var(--muted);font-size:11px}.mt-card-course{color:var(--muted)}.mt-card-progress{color:var(--green);margin-left:auto}.mt-card-footer{justify-content:space-between;align-items:center;margin-top:20px;display:flex}.mt-card-footer-left{align-items:center;display:flex}.mt-card-footer-right{align-items:center;gap:6px;margin-left:auto;display:flex}.mt-card-edit{letter-spacing:.05em;color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:5px;padding:4px 0 4px 10px;font-family:DM Mono,monospace;font-size:11px;transition:color .15s;display:inline-flex}.mt-card-edit:hover{color:var(--ink)}.mt-card-complete{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:6px;padding:0;display:inline-flex}.mt-card-complete-box{border:1.5px solid var(--bg3);width:18px;height:18px;color:var(--bg3);flex-shrink:0;justify-content:center;align-items:center;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.mt-card-complete:hover .mt-card-complete-box{border-color:var(--green);color:var(--green)}.mt-card-complete-done .mt-card-complete-box{border-color:var(--green);background:var(--greenbg);color:var(--green)}.mt-card-complete-label{letter-spacing:.05em;color:var(--muted);font-family:DM Mono,monospace;font-size:11px;transition:color .15s}.mt-card-complete:hover .mt-card-complete-label,.mt-card-complete-done .mt-card-complete-label{color:var(--green)}.mt-card-date-badge{letter-spacing:.04em;color:var(--muted);white-space:nowrap;background:#eff0ea80;align-items:center;margin-left:10px;padding:3px 8px;font-family:DM Mono,monospace;font-size:10px;display:inline-flex}@keyframes rainbow-shift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes urgent-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes urgent-pulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.5;transform:scaleY(.7)}}.mt-card-urgent{background:linear-gradient(270deg,#ffd6d6,#ffe8c0,#fffbd6,#d6ffd6,#d6f0ff,#e8d6ff,#ffd6f0,#ffd6d6) 0 0/400% 400%;animation:5s infinite rainbow-shift,2s ease-in-out infinite urgent-bounce}.mt-card-urgent:hover{transform:none}.mt-card-urgent:before{content:"";background:var(--greenl);z-index:1;width:3px;animation:1.2s ease-in-out infinite urgent-pulse;position:absolute;top:0;bottom:0;left:0}.mt-card.mt-card-done{opacity:.45;filter:grayscale();background:var(--paper)!important;animation:none!important;transform:none!important}.mt-card.mt-card-done:before{display:none}.profile-hero{align-items:center;gap:24px;padding:24px 0 32px;display:flex}.profile-avatar{background:var(--bg3);object-fit:cover;width:80px;height:80px;color:var(--muted);border:1.5px solid var(--bg3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:DM Mono,monospace;font-size:22px;font-weight:500;display:flex;overflow:hidden}.profile-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.profile-hero-info{flex-direction:column;gap:5px;display:flex}.profile-name{color:var(--ink);letter-spacing:-.01em;font-size:22px;font-weight:600}.profile-school{color:var(--green);letter-spacing:.04em;font-family:DM Mono,monospace;font-size:14px}.profile-settings-link{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);cursor:pointer;border:1.5px solid var(--bg3);white-space:nowrap;margin-left:auto;padding:9px 18px;font-family:DM Mono,monospace;font-size:13px;text-decoration:none;transition:border-color .15s,color .15s}.profile-settings-link:hover{border-color:var(--ink2);color:var(--ink)}.profile-stats{grid-template-columns:repeat(3,auto);justify-content:start;gap:36px;margin:14px 0 44px;padding:0 10px;display:grid}.profile-stat{--pixel-base:var(--green);--pixel-highlight:var(--greenl);--pixel-border-color:var(--ink);--pixel-shadow:#00000026;background:var(--green);cursor:pointer;flex-direction:column;align-items:center;gap:4px;min-width:150px;padding:14px 24px;font-family:DM Mono,monospace;transition:transform .15s;display:flex}.profile-stat:hover{transform:translateY(-2px)}.profile-stat-value{color:#fff;letter-spacing:-.01em;white-space:nowrap;font-size:20px;font-weight:600}.profile-stat-label{color:#d6d6d6;letter-spacing:.08em;text-transform:uppercase;text-align:center;font-family:DM Mono,monospace;font-size:11px;line-height:1.5}.profile-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.profile-panel{background:var(--paper);padding:24px 28px}.profile-panel-title{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;font-family:DM Mono,monospace;font-size:11px}.profile-courses{flex-direction:column;gap:14px;display:flex}.profile-course-item{align-items:center;gap:12px;display:flex}.profile-course-dot{background:var(--muted);flex-shrink:0;width:5px;height:5px}.profile-course-name{color:var(--ink2);letter-spacing:.03em;font-family:DM Mono,monospace;font-size:15px}.profile-rooms{flex-direction:column;gap:14px;display:flex}.profile-room-item{justify-content:space-between;align-items:center;gap:12px;display:flex}.profile-room-name{color:var(--ink);cursor:pointer;font-size:16px;line-height:1.3;transition:color .12s}.profile-room-name:hover{color:var(--green)}.profile-room-delete{color:var(--muted);letter-spacing:.04em;cursor:pointer;flex-shrink:0;font-family:DM Mono,monospace;font-size:12px;text-decoration:underline;transition:color .12s}.profile-room-delete:hover{color:var(--red)}.profile-empty{color:var(--muted);letter-spacing:.06em;font-family:DM Mono,monospace;font-size:13px}.ps-title{color:var(--ink);letter-spacing:-.01em;margin-bottom:28px;font-size:17px;font-weight:600}.ps-section{background:var(--paper);margin-bottom:8px;padding:24px 28px}.ps-section-label{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-family:DM Mono,monospace;font-size:11px}.ps-avatar-row{align-items:center;gap:20px;display:flex}.ps-avatar-wrap{flex-shrink:0;width:80px;height:80px;position:relative}.ps-avatar-wrap img{object-fit:cover;background:var(--bg3);border-radius:50%;width:80px;height:80px;display:block}.ps-avatar-edit{background:var(--ink);color:#fff;border:2px solid var(--paper);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;transition:background .15s;display:flex;position:absolute;top:2px;right:2px}.ps-avatar-edit:hover{background:var(--green)}.ps-avatar-info{flex-direction:column;gap:4px;display:flex}.ps-username{color:var(--ink);letter-spacing:-.01em;font-size:17px;font-weight:600}.ps-username-sub{color:var(--muted);font-family:DM Mono,monospace;font-size:13px}.ps-field{flex-direction:column;gap:7px;margin-bottom:16px;display:flex}.ps-field:last-child{margin-bottom:0}.ps-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;font-size:13px}.ps-input,.ps-select{width:100%;color:var(--ink);background:var(--bg);border:1.5px solid var(--bg3);appearance:none;border-radius:0;outline:none;padding:11px 16px;font-family:DM Sans,sans-serif;font-size:17px;transition:border-color .15s}.ps-input:focus,.ps-select:focus{border-color:var(--green)}.ink.ps-input:focus{border-color:var(--ink2)!important}.ps-input::placeholder{color:var(--muted)}.ps-select-wrap{position:relative}.ps-select-wrap:after{content:"";border-left:4px solid #0000;border-right:4px solid #0000;border-top:5px solid var(--muted);pointer-events:none;width:0;height:0;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.ps-school-dropdown{background:var(--paper);border:1.5px solid var(--bg3);z-index:50;border-top:none;max-height:220px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.ps-school-dropdown li{color:var(--ink2);cursor:pointer;padding:11px 16px;font-size:17px;list-style:none;transition:background .1s}.ps-school-dropdown li:hover{background:var(--greenbg);color:var(--green)}.ps-school-wrap{position:relative}.ps-btn{letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:none;padding:11px 26px;font-family:DM Mono,monospace;font-size:14px;transition:background .15s,color .15s}.ps-btn-primary{background:var(--green);color:#fff}.ps-btn-primary:hover{background:var(--greenl)}.ps-btn-ghost{color:var(--muted);border:1.5px solid var(--bg3);background:0 0}.ps-btn-ghost:hover{border-color:var(--ink2);color:var(--ink)}.ps-message{color:var(--green);letter-spacing:.05em;margin-top:12px;font-family:DM Mono,monospace;font-size:13px}.ps-message.error{color:var(--red)}.ps-save-row{align-items:center;gap:16px;margin-top:24px;display:flex}.mt-form-title{color:var(--ink);letter-spacing:-.01em;margin-bottom:28px;font-size:22px;font-weight:600}.mt-form-layout{grid-template-columns:1fr 1fr;align-items:start;gap:0 48px;display:grid}@media (width<=800px){.mt-form-layout{grid-template-columns:1fr}}.mt-form-col{flex-direction:column;gap:12px;display:flex}.mt-field{flex-direction:column;gap:7px;display:flex}.mt-field-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;font-size:11px}.mt-field-hint{color:var(--muted);margin-top:-4px;font-family:DM Mono,monospace;font-size:11px}.mt-input,.mt-textarea,.mt-select{width:100%;color:var(--ink);background:var(--paper);border:1.5px solid var(--bg3);appearance:none;border-radius:0;outline:none;padding:11px 16px;font-family:DM Sans,sans-serif;font-size:17px;transition:border-color .15s}.mt-input:focus,.mt-textarea:focus,.mt-select:focus{border-color:var(--green)}.mt-input::placeholder,.mt-textarea::placeholder{color:var(--muted)}.mt-textarea{resize:vertical;min-height:110px;line-height:1.5}.mt-progress-row{align-items:center;gap:10px;display:flex}.mt-progress-row .mt-input{text-align:center;flex-shrink:0;width:88px}.mt-progress-sep{color:var(--muted);flex-shrink:0;font-family:DM Mono,monospace;font-size:17px}.mt-vis-group{flex-wrap:wrap;gap:6px;display:flex}.mt-vis-chip{letter-spacing:.05em;color:var(--muted);background:var(--bg2);cursor:pointer;border:1.5px solid #0000;padding:7px 18px;font-family:DM Mono,monospace;font-size:13px;transition:background .12s,color .12s,border-color .12s}.mt-vis-chip:hover{background:var(--bg3);color:var(--ink)}.mt-vis-chip.selected{background:var(--greenbg);color:var(--green);border-color:var(--greenl)}.mt-submit-btn{letter-spacing:.08em;text-transform:uppercase;color:var(--green);border:1.5px solid var(--green);cursor:pointer;background:0 0;margin-top:8px;padding:12px 32px;font-family:DM Mono,monospace;font-size:14px;transition:background .15s,color .15s;display:inline-block}.mt-submit-btn:hover{background:var(--greenbg)}.mt-delete-btn{letter-spacing:.08em;text-transform:uppercase;color:var(--red);border:1.5px solid var(--red);cursor:pointer;background:0 0;margin-top:8px;padding:12px 32px;font-family:DM Mono,monospace;font-size:14px;transition:background .15s,color .15s;display:inline-block}.mt-delete-btn:hover{background:var(--redbg)}.mt-school-readonly{width:100%;color:var(--muted);background:var(--bg2);border:1.5px solid var(--bg3);cursor:not-allowed;-webkit-user-select:none;user-select:none;padding:11px 16px;font-family:DM Sans,sans-serif;font-size:17px}.mt-back-btn{letter-spacing:.06em;color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:7px;font-family:DM Mono,monospace;font-size:12px;transition:color .15s;display:flex;position:absolute;top:34px;left:-140px}.mt-back-btn:hover{color:var(--ink)}.mt-prog-visual{align-items:center;gap:14px;margin-top:4px;display:flex}.mt-prog-slider{appearance:none;background:var(--bg3);cursor:pointer;height:3px;accent-color:var(--green);outline:none;flex:1}.mt-prog-slider::-webkit-slider-thumb{appearance:none;background:var(--green);cursor:pointer;border:none;border-radius:0;width:14px;height:14px}.mt-prog-slider::-moz-range-thumb{background:var(--green);cursor:pointer;border:none;border-radius:0;width:14px;height:14px}.mt-prog-visual-label{color:var(--muted);white-space:nowrap;text-align:right;flex-shrink:0;min-width:48px;font-family:DM Mono,monospace;font-size:13px}.mt-date-row{background:var(--paper);border:1.5px solid var(--bg3);align-items:center;transition:border-color .15s;display:flex}.mt-date-row:focus-within{border-color:var(--green)}.mt-date-label{color:var(--muted);white-space:nowrap;flex-shrink:0;padding:11px 16px;font-family:DM Sans,sans-serif;font-size:17px}.mt-date-input{color:var(--ink);background:0 0;flex:1;padding-left:0;border:none!important}.mt-date-input:focus{outline:none;border-color:#0000!important}.mt-school-badge{letter-spacing:.04em;color:var(--muted);background:var(--bg2);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:5px 12px;font-family:DM Mono,monospace;font-size:12px;transition:background .12s,color .12s;display:inline-flex}.mt-school-badge:hover{background:var(--greenbg);color:var(--green)}.mt-school-badge:before{content:"↩";opacity:.6;font-size:11px}.mt-error{color:var(--red);margin-top:4px;font-family:DM Mono,monospace;font-size:13px}.as-wrap{align-items:flex-start;gap:32px;display:flex}.as-left{flex-direction:column;flex:1;gap:20px;min-width:0;display:flex}.as-upload-zone{border:1.5px dashed var(--bg3);background:var(--paper);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:180px;padding:28px;transition:border-color .15s,background .15s;display:flex}.as-upload-zone:hover{border-color:var(--green);background:var(--greenbg)}.as-upload-zone img{object-fit:contain;max-width:100%;max-height:140px;image-rendering:pixelated}.as-upload-hint{color:var(--muted);letter-spacing:.06em;text-align:center;font-family:DM Mono,monospace;font-size:13px}.as-preview-row{align-items:flex-start;gap:20px;display:flex}.as-preview-box{background:var(--paper);flex-direction:column;flex:1;align-items:center;gap:8px;padding:14px;display:flex}.as-preview-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:DM Mono,monospace;font-size:11px}.as-preview-box canvas{image-rendering:pixelated;display:block}.as-actions{flex-wrap:wrap;gap:10px;display:flex}.as-name-row{align-items:center;gap:10px;display:flex}.as-name-input{border:1.5px solid var(--bg3);background:var(--paper);color:var(--ink);outline:none;flex:1;padding:9px 12px;font-family:DM Mono,monospace;font-size:14px;transition:border-color .15s}.as-name-input:focus{border-color:var(--green)}.as-btn{letter-spacing:.06em;cursor:pointer;border:none;padding:9px 20px;font-family:DM Mono,monospace;font-size:13px;transition:background .12s,color .12s}.as-btn:disabled{opacity:.4;cursor:not-allowed}.as-btn-primary{background:var(--green);color:#fff}.as-btn-primary:hover:not(:disabled){background:var(--greenl)}.as-btn-ghost{background:var(--bg2);color:var(--ink2)}.as-btn-ghost:hover:not(:disabled){background:var(--bg3)}.as-btn-danger{background:var(--redbg);color:var(--red)}.as-btn-danger:hover:not(:disabled){background:#f5d0d0}.as-msg{color:var(--green);padding:8px 0;font-family:DM Mono,monospace;font-size:13px}.as-msg.error{color:var(--red)}.as-right{flex-direction:column;flex-shrink:0;gap:12px;width:240px;display:flex}.as-list-title{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1.5px solid var(--bg3);padding-bottom:6px;font-family:DM Mono,monospace;font-size:11px}.as-avatar-item{background:var(--paper);border:1.5px solid #0000;flex-direction:column;gap:10px;padding:14px;transition:border-color .12s;display:flex;position:relative}.as-avatar-item.active{border-color:var(--green)}.as-avatar-active-tag{letter-spacing:.08em;background:var(--greenbg);color:var(--green);padding:2px 7px;font-family:DM Mono,monospace;font-size:10px;position:absolute;top:8px;right:8px}.as-avatar-default-tag{letter-spacing:.08em;background:var(--bg2);color:var(--muted);padding:2px 7px;font-family:DM Mono,monospace;font-size:10px;position:absolute;top:8px;right:8px}.as-avatar-name{color:var(--ink2);letter-spacing:.04em;font-family:DM Mono,monospace;font-size:13px}.as-avatar-meta{color:var(--muted);font-family:DM Mono,monospace;font-size:11px}.as-avatar-thumb{justify-content:center;display:flex}.as-avatar-thumb canvas{image-rendering:pixelated;display:block}.as-avatar-btns{gap:7px;display:flex}.as-avatar-btns .as-btn{flex:1;padding:6px 0;font-size:12px}.as-empty{color:var(--muted);text-align:center;padding:20px 0;font-family:DM Mono,monospace;font-size:13px}
