@font-face{font-family:SF Pro Rounded;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/sf-pro-rounded-400.woff2)format("woff2")}@font-face{font-family:SF Pro Rounded;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/sf-pro-rounded-500.woff2)format("woff2")}@font-face{font-family:SF Pro Rounded;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/sf-pro-rounded-600.woff2)format("woff2")}@font-face{font-family:SF Pro Rounded;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/sf-pro-rounded-700.woff2)format("woff2")}@font-face{font-family:SF Pro Rounded;font-style:normal;font-weight:800;font-display:swap;src:url(/fonts/sf-pro-rounded-800.woff2)format("woff2")}@font-face{font-family:Montserrat Alternates;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/montserrat-alternates-400.woff2)format("woff2")}@font-face{font-family:Montserrat Alternates;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/montserrat-alternates-500.woff2)format("woff2")}@font-face{font-family:Montserrat Alternates;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/montserrat-alternates-600.woff2)format("woff2")}@font-face{font-family:Montserrat Alternates;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/montserrat-alternates-700.woff2)format("woff2")}@font-face{font-family:Montserrat Alternates;font-style:normal;font-weight:800;font-display:swap;src:url(/fonts/montserrat-alternates-800.woff2)format("woff2")}*{box-sizing:border-box}body{color:#222;background:#fff;margin:0;font-family:SF Pro Rounded,system-ui,-apple-system,sans-serif}.capp{--bg:#fff;--bg-soft:#f3fbfb;--panel:#fff;--mist:#d6f1f4;--mist-soft:#ecf8f9;--teal:#30b8c8;--teal-bright:#2ccad8;--teal-btn:#25b6bf;--teal-d:#16808c;--teal-deep:#0d626c;--ink:#392c1b;--ink-soft:#6e604f;--ink-faint:#9c8f7e;--line:#e7e3da;--line-2:#d8d1c4;--green:#2aa6a0;--green-bg:#e0f3f1;--green-line:#a9ddd9;--yellow:#fff200;--amber:#e6c200;--amber-bg:#fbf4a6;--amber-ink:#6b5a08;--coral:#d8503a;--coral-bg:#fbe7e2;--coral-line:#f0c2b6;--shadow-s:0 2px 8px -4px #392c1b29;--shadow-m:0 12px 28px -16px #392c1b42;--shadow-l:0 26px 56px -28px #392c1b52;--disp:"Montserrat Alternates", system-ui, sans-serif;--sans:"SF Pro Rounded", system-ui, -apple-system, sans-serif;--ease:cubic-bezier(.2, .8, .2, 1);background:var(--bg);min-height:100vh;color:var(--ink);font-family:var(--sans);isolation:isolate;font-size:14px;line-height:1.5;position:relative}.capp:before{content:"";z-index:-1;background:radial-gradient(60% 45% at 85% -8%,#30b8c81f,#0000 70%),radial-gradient(55% 40% at 0 105%,#d6f1f480,#0000 72%);position:fixed;inset:0}.dash-divider{background:linear-gradient(90deg, var(--teal) 0 40px, var(--yellow) 40px 52px, var(--line) 52px);border-radius:2px;height:2px;display:block}.topnav{z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);background:#ffffffe6;align-items:center;gap:4px;padding:13px 30px;display:flex;position:sticky;top:0}.brand{flex-direction:column;margin-right:30px;line-height:1.04;display:flex}.brand-logo{width:auto;height:30px;display:block}.brand-sub{letter-spacing:1.6px;text-transform:uppercase;color:var(--ink-faint);margin-top:2px;font-size:10px;font-weight:600}.navbtn{font:inherit;cursor:pointer;color:var(--ink-soft);transition:all .16s var(--ease);background:0 0;border:0;border-radius:9px;padding:8px 15px;font-size:14px;font-weight:600}.navbtn:hover{background:var(--mist-soft);color:var(--ink)}.navbtn.active{background:var(--mist);color:var(--teal-deep)}.langsw{border:1px solid var(--line-2);background:var(--panel);border-radius:999px;margin-left:auto;display:inline-flex;overflow:hidden}.langsw button{font:inherit;letter-spacing:.5px;color:var(--ink-soft);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;align-items:center;gap:6px;padding:7px 13px;font-size:12px;font-weight:700;display:inline-flex}.langsw button.active{background:var(--teal);color:#fff}.flag{flex:none;display:block}.persona-sw{border:1px solid var(--line-2);background:var(--panel);border-radius:999px;margin-left:10px;display:inline-flex;overflow:hidden}.persona-sw button{font:inherit;color:var(--ink-soft);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;padding:7px 14px;font-size:12px;font-weight:700}.persona-sw button.active{background:var(--ink);color:#fff}.page{max-width:1180px;animation:pageIn .45s var(--ease) both;margin:0 auto;padding:32px 30px 64px}.page.wide{max-width:none}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.pagehead{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:14px;margin-bottom:8px;display:flex}.pagehead h2{font-family:var(--disp);letter-spacing:-.5px;color:var(--ink);margin:0;font-size:32px;font-weight:700}.pagehead .sub{color:var(--ink-soft);margin:5px 0 0;font-size:13px}.page>.dash-divider{margin:14px 0 22px}.tbl{border-collapse:separate;border-spacing:0;background:var(--panel);border:1px solid var(--line);width:100%;box-shadow:var(--shadow-m);border-radius:16px;overflow:hidden}.tbl th,.tbl td{text-align:left;border-bottom:1px solid var(--line);vertical-align:middle;padding:14px 16px}.tbl thead th{letter-spacing:1px;text-transform:uppercase;color:var(--ink-faint);background:var(--bg-soft);font-size:11px;font-weight:700}.tbl tbody tr{transition:background .14s var(--ease)}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover{background:var(--mist-soft)}.tbl .ttl{font-family:var(--disp);font-size:16px;font-weight:600}.btn{min-height:40px;font:inherit;border:1px solid var(--line-2);background:var(--panel);color:var(--ink);cursor:pointer;transition:all .15s var(--ease);border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:10px 18px;font-size:13.5px;font-weight:600;display:inline-flex}.btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal-deep);background:var(--mist-soft)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.btn.primary{background:var(--teal-btn);border-color:var(--teal-btn);color:#fff;box-shadow:var(--shadow-s)}.btn.primary:hover:not(:disabled){background:var(--teal-d);border-color:var(--teal-d);color:#fff}.btn.danger{color:var(--coral);background:var(--panel);border-color:#f0c2b6}.btn.danger:hover:not(:disabled){background:var(--coral-bg);border-color:var(--coral);color:var(--coral)}.btn.sm{border-radius:8px;min-height:32px;padding:6px 12px;font-size:12.5px}.iconbtn{border:1px solid var(--line-2);background:var(--panel);width:30px;height:30px;color:var(--ink-soft);cursor:pointer;transition:all .15s var(--ease);border-radius:8px;place-items:center;font-size:13px;display:grid}.iconbtn:hover{background:var(--coral-bg);color:var(--coral);border-color:var(--coral)}.badge{border:1px solid var(--line-2);background:var(--bg-soft);color:var(--ink-soft);white-space:nowrap;border-radius:999px;align-items:center;padding:2px 10px;font-size:11.5px;font-weight:600;line-height:1.4;display:inline-flex}.badge.pistachio,.badge.green{background:var(--green-bg);color:#0e6670;border-color:#a9ddd9}.badge.honey,.badge.orange{background:var(--amber-bg);color:#6b5a08;border-color:#ecd84f}.badge.berry,.badge.red{background:var(--coral-bg);color:#b53d28;border-color:#f0c2b6}.badge.bark{border-color:var(--line-2);color:var(--ink);background:#efe9df}.badge.neutral,.badge.gray{background:var(--bg-soft);border-color:var(--line-2);color:var(--ink-soft)}.badge.blue{background:var(--mist-soft);color:var(--teal-deep);border-color:#a9ddd9}.badge.kk{padding:1px 8px;font-size:10.5px}.kkdot{background:var(--amber);border:1px solid #6b5a08;border-radius:50%;flex:none;width:8px;height:8px}.field{margin-bottom:13px}.field label{color:var(--ink-soft);margin-bottom:5px;font-size:12.5px;font-weight:600;display:block}.capp input[type=text],.capp input[type=password],.capp input[type=tel],.capp input[type=email],.capp input[type=search],.capp input[type=number],.capp input[type=date],.capp input[type=url],.capp textarea,.capp select{box-sizing:border-box;width:100%;font:inherit;color:var(--ink);border:1px solid var(--line-2);background:var(--panel);transition:border-color .15s var(--ease), box-shadow .15s var(--ease);border-radius:10px;padding:9px 12px}.capp textarea{resize:vertical;min-height:70px;line-height:1.55}.capp input:focus,.capp textarea:focus,.capp select:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--mist);outline:none}.capp input::placeholder,.capp textarea::placeholder{color:var(--ink-faint)}.capp input[type=checkbox],.capp input[type=radio]{width:auto;accent-color:var(--teal)}.row{align-items:center;gap:8px;display:flex}.row .grow,.grow{flex:1}.cols2{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=640px){.cols2{grid-template-columns:1fr}}.edgrid{grid-template-columns:372px 1fr;align-items:start;gap:20px;display:grid}@media (width<=940px){.edgrid{grid-template-columns:1fr}}.treepane{border:1px solid var(--line);background:var(--bg-soft);box-shadow:var(--shadow-m);border-radius:16px;padding:12px}.editpane{border:1px solid var(--line);background:var(--panel);min-height:360px;box-shadow:var(--shadow-m);border-radius:16px;padding:22px}.editpane>p:first-child>strong,.pane-title{font-family:var(--disp);font-size:19px;font-weight:700}.toolbar{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:11px;margin-bottom:18px;padding-bottom:14px;display:flex}.toolbar h2{font-family:var(--disp);letter-spacing:-.4px;color:var(--ink);margin:0;font-size:24px;font-weight:700}.toolbar .spacer{flex:1}.ver-chip{color:var(--teal-deep);background:var(--mist);border:1px solid #a9ddd9;border-radius:999px;padding:2px 9px;font-size:11.5px;font-weight:700}.dirty{color:var(--amber-ink);white-space:nowrap;font-size:12.5px;font-weight:700}.tree-row{cursor:pointer;transition:background .14s var(--ease);border-radius:10px;align-items:center;gap:7px;padding:8px 9px;display:flex}.tree-row:hover{background:var(--mist-soft)}.tree-row.sel{background:var(--panel);box-shadow:inset 0 0 0 1.5px var(--teal)}.tree-row.lvl1{margin-left:20px}.tree-row .t-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.tree-add{flex-wrap:wrap;gap:6px;margin:5px 0 12px 20px;display:flex}.rowctl{gap:3px;display:inline-flex}.rowctl button{border:1px solid var(--line-2);background:var(--panel);width:24px;height:24px;color:var(--ink-soft);cursor:pointer;transition:all .14s var(--ease);border-radius:7px;padding:0;font-size:12px;line-height:1}.rowctl button:hover:not(:disabled){background:var(--mist-soft);color:var(--teal-deep);border-color:var(--teal)}.rowctl button:disabled{opacity:.3;cursor:default}.rowctl button.danger{color:var(--coral);border-color:#f0c2b6}.rowctl button.danger:hover:not(:disabled){background:var(--coral-bg);border-color:var(--coral)}.card{border:1px solid var(--line);background:var(--bg-soft);box-shadow:var(--shadow-s);border-radius:13px;margin-bottom:12px;padding:14px}.cardhead{align-items:center;gap:8px;margin-bottom:10px;display:flex}.cardhead .grow{flex:1}.opt-row{align-items:center;gap:9px;margin-bottom:8px;display:flex}.opt-row .field{flex:1;margin-bottom:0}.modal-back{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#392c1b57;justify-content:center;align-items:center;padding:20px;animation:.16s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--panel);border:1px solid var(--line);width:580px;max-width:100%;max-height:86vh;box-shadow:var(--shadow-l);animation:popIn .2s var(--ease);border-radius:18px;flex-direction:column;display:flex}@keyframes popIn{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:none}}.modal.wide{width:900px}.modal-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:16px 20px;display:flex}.modal-head strong{font-family:var(--disp);font-size:19px;font-weight:700}.modal-body{padding:20px;overflow:auto}.modal-foot{border-top:1px solid var(--line);justify-content:flex-end;gap:9px;padding:14px 20px;display:flex}.hint{color:var(--ink-soft);font-size:13px}.errlist,.warnlist{border-radius:12px;margin:0;padding:12px 16px 12px 32px;list-style:none}.errlist{background:var(--coral-bg);color:#b53d28;border:1px solid #f0c2b6}.warnlist{background:var(--amber-bg);color:#6b5a08;border:1px solid #ecd84f}.errlist li,.warnlist li{margin:5px 0;position:relative}.errlist li:before{content:"✕";position:absolute;left:-18px}.warnlist li:before{content:"!";font-weight:800;position:absolute;left:-16px}.imgprev{border:1px solid var(--line);border-radius:10px;max-width:340px;max-height:190px;margin-top:8px;display:block}.preview-sec{margin-bottom:28px}.preview-sec h3{font-family:var(--disp);color:var(--ink);margin:0 0 8px;font-size:22px;font-weight:700}.preview-sec h3+.dash-divider{margin-bottom:14px}.preview-sec h4{font-family:var(--disp);margin:16px 0 8px;font-size:17px;font-weight:600}.preview-sec p{white-space:pre-wrap;margin:7px 0}.correct-mark{color:var(--green);font-weight:700}.track-grid{grid-template-columns:1fr 330px;align-items:start;gap:20px;display:grid}@media (width<=940px){.track-grid{grid-template-columns:1fr}}.bead-canvas{border:1px solid var(--line);background:var(--bg-soft);box-shadow:var(--shadow-m);border-radius:16px;padding:26px 16px}.bead-chain{flex-direction:column;align-items:center;display:flex}.bead-cap{font-family:var(--disp);color:var(--ink-faint);font-size:13px;font-weight:600}.bead-slot{justify-content:center;align-items:center;width:150px;height:36px;display:flex;position:relative}.bead-slot:before{content:"";background:var(--line-2);width:3px;margin-left:-1.5px;position:absolute;top:0;bottom:0;left:50%}.bead-knot{border:2px solid var(--line-2);width:13px;height:13px;transition:all .15s var(--ease);background:#fff;border-radius:50%;position:relative}.bead-slot.active .bead-knot{border-color:var(--teal);width:15px;height:15px}.bead-slot.over:before{background:var(--teal)}.bead-slot.over .bead-knot{background:var(--teal);border-color:var(--teal-d);width:20px;height:20px;box-shadow:0 0 0 5px var(--mist)}.bead-row{position:relative}.bead{text-align:center;box-sizing:border-box;cursor:grab;-webkit-user-select:none;user-select:none;width:138px;height:138px;box-shadow:var(--shadow-m), inset 0 6px 14px #ffffffb3, inset 0 -8px 16px #392c1b14;transition:transform .16s var(--ease), box-shadow .16s var(--ease);border:3px solid;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;padding:16px;display:flex;position:relative}.bead:after{content:"";background:radial-gradient(circle,#ffffffe6,#0000 70%);border-radius:50%;width:34px;height:22px;position:absolute;top:16px;left:26px}.bead:hover{transform:translateY(-2px)scale(1.02)}.bead:active{cursor:grabbing}.bead.dragging{opacity:.4}.bead.drop{box-shadow:0 0 0 4px var(--mist), var(--shadow-m)}.bead-title{font-family:var(--disp);color:var(--ink);-webkit-line-clamp:3;z-index:1;-webkit-box-orient:vertical;font-size:14px;font-weight:600;line-height:1.2;display:-webkit-box;position:relative;overflow:hidden}.bead-status{color:var(--ink-soft);z-index:1;margin-top:4px;font-size:10px;position:relative}.bead-del{background:var(--panel);width:22px;height:22px;color:var(--coral);cursor:pointer;opacity:0;transition:opacity .15s var(--ease);z-index:2;border:1px solid #f0c2b6;border-radius:50%;padding:0;font-size:11px;line-height:1;position:absolute;top:8px;right:18px}.bead:hover>.bead-del,.bead-mini:hover>.bead-del{opacity:1}.bead-del:hover{background:var(--coral-bg)}.bead>.kkdot{z-index:2;position:absolute;top:12px;left:20px}.bead-side{align-items:center;display:flex;position:absolute;top:50%;left:100%;transform:translateY(-50%)}.bead-side:before{content:"";background:var(--line-2);width:26px;height:3px}.bead-mini{text-align:center;box-sizing:border-box;width:82px;height:82px;box-shadow:var(--shadow-s), inset 0 4px 10px #ffffffb3;border:2px solid;border-radius:50%;justify-content:center;align-items:center;margin-right:7px;padding:9px;display:flex;position:relative}.bead-mini .bead-del{top:2px;right:6px}.bead-mini-title{font-family:var(--disp);color:var(--ink);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:11px;font-weight:600;line-height:1.15;display:-webkit-box;overflow:hidden}.picker{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow-m);border-radius:16px;padding:16px;position:sticky;top:84px}.picker>strong{font-family:var(--disp);font-size:18px;font-weight:700}.picker-item{border:1px solid var(--line);background:var(--bg-soft);cursor:grab;transition:all .15s var(--ease);border-radius:11px;align-items:center;gap:9px;margin-top:9px;padding:9px 11px;display:flex}.picker-item:hover{box-shadow:var(--shadow-s);border-color:var(--teal);transform:translate(2px)}.picker-item:active{cursor:grabbing}.picker-dot{border:1px solid #392c1b26;border-radius:50%;flex:none;width:14px;height:14px;box-shadow:inset 0 2px 3px #ffffffb3}.drag-handle{width:22px;height:26px;color:var(--ink-faint);cursor:grab;-webkit-user-select:none;user-select:none;transition:all .14s var(--ease);border-radius:6px;flex:none;place-items:center;font-size:15px;line-height:1;display:inline-grid}.drag-handle:hover{background:var(--mist-soft);color:var(--teal-deep)}.drag-handle:active{cursor:grabbing}.srow.dragging{opacity:.45}.srow.over{background:var(--mist-soft);box-shadow:inset 0 0 0 2px var(--teal);border-radius:10px}.menu-wrap{display:inline-flex;position:relative}.menu-trigger{border:1px solid var(--line-2);background:var(--panel);width:28px;height:28px;color:var(--ink-soft);cursor:pointer;transition:all .15s var(--ease);border-radius:8px;place-items:center;font-size:17px;line-height:1;display:grid}.menu-trigger:hover{border-color:var(--teal);color:var(--teal-deep);background:var(--mist-soft)}.menu{background:var(--panel);border:1px solid var(--line);min-width:186px;box-shadow:var(--shadow-l);z-index:60;animation:popIn .14s var(--ease);border-radius:12px;flex-direction:column;padding:6px;display:flex;position:absolute;top:calc(100% + 5px)}.menu-right{right:0}.menu-left{left:0}.menu-item{text-align:left;font:inherit;color:var(--ink);cursor:pointer;white-space:nowrap;transition:background .12s var(--ease);background:0 0;border:0;border-radius:8px;padding:8px 11px;font-size:13.5px;font-weight:500}.menu-item:hover:not(:disabled){background:var(--mist-soft);color:var(--teal-deep)}.menu-item:disabled{opacity:.4;cursor:not-allowed}.menu-item.danger{color:var(--coral)}.menu-item.danger:hover:not(:disabled){background:var(--coral-bg);color:var(--coral)}.bifield .bi-cols{grid-template-columns:1fr 1fr;gap:10px;display:grid}@media (width<=720px){.bifield .bi-cols{grid-template-columns:1fr}}.bi-col{flex-direction:column;gap:4px;display:flex}.bi-tag{letter-spacing:.4px;text-transform:uppercase;color:var(--ink-faint);font-size:10.5px;font-weight:700}.bi-tag.warn{color:var(--amber-ink)}.seg{border:1px solid var(--line-2);background:var(--panel);border-radius:999px;align-self:center;display:inline-flex;overflow:hidden}.seg-btn{font:inherit;color:var(--ink-soft);cursor:pointer;transition:all .15s var(--ease);background:0 0;border:0;padding:6px 14px;font-size:12.5px;font-weight:600}.seg-btn.active{background:var(--teal);color:#fff}.seg-btn:not(.active):hover{background:var(--mist-soft);color:var(--teal-deep)}@media (prefers-reduced-motion:reduce){.capp *,.capp :before,.capp :after{transition-duration:.1s!important;animation-duration:.001ms!important}}.t-greeting{font-family:var(--disp);letter-spacing:-.5px;margin:0 0 2px;font-size:32px;font-weight:700}.t-greeting+.sub{color:var(--ink-soft);margin:0 0 18px}.t-section{margin-bottom:34px}.t-track-head{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:6px;display:flex}.t-track-head h3{font-family:var(--disp);letter-spacing:-.3px;margin:0;font-size:23px;font-weight:700}.t-pos{color:var(--teal-deep);background:var(--mist);border:1px solid #a9ddd9;border-radius:999px;padding:3px 11px;font-size:12.5px}.admit{align-items:center;gap:10px;max-width:520px;margin:12px 0 18px;display:flex}.admit-track{background:var(--mist-soft);border:1px solid var(--line-2);border-radius:999px;flex:1;height:10px;overflow:hidden}.admit-fill{background:linear-gradient(90deg, var(--teal), #2ccad8);height:100%;transition:width .5s var(--ease)}.admit-label{color:var(--ink-soft);white-space:nowrap;font-size:12.5px;font-weight:700}.route{position:relative}.r-item{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow-s);transition:all .16s var(--ease);border-radius:14px;align-items:center;gap:14px;margin:10px 0;padding:14px 16px;display:flex;position:relative}.r-item.clickable{cursor:pointer}.r-item.clickable:hover{box-shadow:var(--shadow-m);border-color:var(--teal);transform:translate(3px)}.r-item.optional{background:var(--bg-soft);border-style:dashed}.r-item.locked{opacity:.62}.r-item.done{border-color:#a9ddd9}.r-info{flex:1;min-width:0}.r-title{font-family:var(--disp);font-size:17px;font-weight:600}.r-meta{color:var(--ink-soft);flex-wrap:wrap;align-items:center;gap:8px;margin-top:3px;font-size:12.5px;display:flex}.r-cta{white-space:nowrap}.ring{background:conic-gradient(var(--teal) calc(var(--p,0) * 1%), var(--mist-soft) 0);border-radius:50%;flex:none;width:50px;height:50px;position:relative}.ring.done{background:conic-gradient(var(--green) calc(var(--p,0) * 1%), var(--mist-soft) 0)}.ring.muted{background:conic-gradient(var(--ink-faint) calc(var(--p,0) * 1%), var(--mist-soft) 0)}.ring:after{content:"";background:var(--panel);border-radius:50%;position:absolute;inset:5px}.ring span{color:var(--ink);z-index:1;place-items:center;font-size:12px;font-weight:800;display:grid;position:absolute;inset:0}.ring.done span{color:var(--green)}.admission-card{background:linear-gradient(135deg, var(--mist-soft), var(--green-bg));box-shadow:var(--shadow-m);border:1px solid #a9ddd9;border-radius:16px;align-items:center;gap:16px;margin:14px 0;padding:18px 22px;display:flex}.admission-card .ac-emoji{font-size:34px}.admission-card h4{font-family:var(--disp);margin:0;font-size:19px;font-weight:700}.admission-card p{color:var(--ink-soft);margin:3px 0 0;font-size:13px}.cmap-head{margin-bottom:18px}.cmap-head h2{font-family:var(--disp);letter-spacing:-.5px;margin:0 0 4px;font-size:28px;font-weight:700}.progressbar{background:var(--mist-soft);border:1px solid var(--line-2);border-radius:999px;max-width:520px;height:10px;margin:12px 0;overflow:hidden}.progressbar-fill{background:linear-gradient(90deg, var(--teal), #2ccad8);height:100%;transition:width .5s var(--ease)}.cmod{margin-bottom:22px}.cmod-title{font-family:var(--disp);margin:0 0 4px;font-size:18px;font-weight:600}.cmod-title+.dash-divider{margin-bottom:10px}.cnode{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow-s);transition:all .15s var(--ease);border-radius:12px;align-items:center;gap:12px;margin:8px 0;padding:13px 16px;display:flex}.cnode.available{cursor:pointer}.cnode.available:hover{box-shadow:var(--shadow-m);border-color:var(--teal);transform:translate(3px)}.cnode.locked{opacity:.55}.cnode.done{background:var(--green-bg);border-color:#a9ddd9}.cnode .cn-title{flex:1;font-weight:600}.cnode .cn-arrow{color:var(--ink-faint);font-size:18px}.statusdot{border:1.5px solid var(--line-2);background:var(--bg-soft);width:26px;height:26px;color:var(--ink-soft);border-radius:50%;flex:none;place-items:center;font-size:13px;font-weight:800;display:grid}.statusdot.done{background:var(--green);color:#fff;border-color:#15808c}.statusdot.locked{color:var(--ink-faint)}.statusdot.available{border-color:var(--teal);color:var(--teal)}.reader{max-width:760px}.reader h2{font-family:var(--disp);letter-spacing:-.5px;margin:0 0 4px;font-size:26px;font-weight:700}.reader-body p{white-space:pre-wrap;margin:12px 0;font-size:15px;line-height:1.7}.reader-body img,.reader-body video{border:1px solid var(--line);border-radius:12px;max-width:100%;margin:14px 0;display:block}.reader-empty{color:var(--ink-soft);font-style:italic}.quiz{max-width:760px}.quiz-meta{color:var(--ink-soft);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;font-size:13px;display:flex}.q-card{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow-s);border-radius:14px;margin-bottom:14px;padding:16px 18px}.q-num{color:var(--ink-faint);letter-spacing:.5px;font-size:12px;font-weight:700}.q-stem{font-family:var(--disp);margin:4px 0 12px;font-size:17px;font-weight:600}.q-opt{border:1.5px solid var(--line-2);background:var(--bg-soft);cursor:pointer;transition:all .14s var(--ease);border-radius:11px;align-items:center;gap:10px;margin:7px 0;padding:10px 13px;display:flex}.q-opt:hover{border-color:var(--teal)}.q-opt.sel{border-color:var(--teal);background:var(--mist-soft)}.q-opt input{pointer-events:none}.q-opt.locked{cursor:default}.q-opt.locked:hover{border-color:var(--line-2)}.q-opt.correct{background:var(--green-bg);border-color:#15808c}.q-opt.wrong{border-color:var(--coral);background:var(--coral-bg)}.q-opt.missed{border-style:dashed;border-color:#15808c}.q-mark{margin-left:auto;font-weight:800}.q-mark.ok{color:var(--green)}.q-mark.no{color:var(--coral)}.q-verdict{margin-top:10px}.q-explain{color:var(--ink-soft);background:var(--bg-soft);border-radius:9px;margin-top:8px;padding:8px 11px;font-size:13px}.q-match-row{align-items:center;gap:9px;margin:7px 0;display:flex}.q-match-row .ql{flex:1}.q-order-row{border:1px solid var(--line-2);background:var(--bg-soft);border-radius:10px;align-items:center;gap:9px;margin:7px 0;padding:9px 12px;display:flex}.q-order-row .qn{color:var(--ink-faint);min-width:18px;font-weight:800}.q-order-row .grow{flex:1}.result{box-shadow:var(--shadow-m);border-radius:16px;align-items:center;gap:18px;margin-bottom:18px;padding:20px 24px;display:flex}.result.pass{background:var(--green-bg);border:1px solid #a9ddd9}.result.fail{background:var(--coral-bg);border:1px solid #f0c2b6}.result.pending{background:var(--amber-bg);border:1px solid #ecd84f}.result.pending .score{font-size:30px}.result .score{font-family:var(--disp);font-size:38px;font-weight:700;line-height:1}.result.pass .score{color:#0e6670}.result.fail .score{color:#b53d28}.result h3{font-family:var(--disp);margin:0;font-size:21px;font-weight:700}.result p{color:var(--ink-soft);margin:4px 0 0;font-size:13px}.run-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.offline-run{max-width:700px}.offline-run .descr{white-space:pre-wrap;margin:8px 0 18px;line-height:1.6}.run-check{border:1px solid var(--line);background:var(--panel);border-radius:11px;align-items:flex-start;gap:11px;margin:8px 0;padding:12px 14px;display:flex}.run-check input{margin-top:3px}.run-check .rc-text{flex:1}.run-check .rc-tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.submitted-banner{background:var(--mist-soft);color:var(--teal-deep);border:1px solid #a9ddd9;border-radius:14px;align-items:center;gap:12px;margin-bottom:16px;padding:16px 20px;display:flex}.runner-head{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;display:flex}.runner-head .kind-badge{margin-left:auto}.locked-note{color:var(--ink-faint);align-items:center;gap:6px;font-size:12.5px;display:inline-flex}.cstruct{flex-direction:column;gap:4px;display:flex}.cstruct-mod{margin-bottom:14px}.cstruct-mod-title{letter-spacing:.6px;text-transform:uppercase;color:var(--ink-faint);padding:4px 8px 8px;font-size:11px;font-weight:700}.cstruct-node{transition:background .14s var(--ease);border-radius:10px;align-items:center;gap:10px;padding:9px 10px;display:flex}.cstruct-node .statusdot{width:22px;height:22px;font-size:11px}.cstruct-node .cn-title{flex:1;font-size:13.5px;font-weight:500}.cstruct-node.available{cursor:pointer}.cstruct-node.available:hover{background:var(--mist-soft)}.cstruct-node.locked{opacity:.5}.cstruct-node.sel{background:var(--mist);box-shadow:inset 0 0 0 1.5px var(--teal)}.cstruct-node.sel .cn-title{color:var(--teal-deep);font-weight:600}.cintro{max-width:760px;padding:30px 30px 64px}.cintro h2{font-family:var(--disp);letter-spacing:-.5px;margin:0 0 6px;font-size:28px;font-weight:700}.cintro .progressbar{max-width:100%}.cintro-meta{align-items:center;gap:10px;margin:10px 0 18px;display:flex}.t-simple{font-size:16px}.t-simple .btn{border-radius:14px;min-height:52px;padding:14px 22px;font-size:16px}.t-simple .btn.sm{min-height:46px;padding:11px 18px;font-size:15px}.t-simple .r-item{border-radius:18px;gap:16px;padding:18px}.t-simple .r-title{font-size:21px}.t-simple .r-meta{gap:10px;font-size:14.5px}.t-simple .ring{width:58px;height:58px}.t-simple .ring span{font-size:14px}.t-simple .q-stem{font-size:21px}.t-simple .q-opt{border-radius:14px;gap:12px;margin:10px 0;padding:16px;font-size:17px}.t-simple .reader h2{font-size:28px}.t-simple .reader-body p{font-size:18px;line-height:1.85}.t-simple .run-check{border-radius:14px;padding:16px;font-size:16px}.t-simple .submitted-banner{padding:18px 20px;font-size:16px}.t-simple .cintro h2{font-size:30px}.t-simple .cstruct-node{border-radius:12px;padding:14px 12px}.t-simple .cstruct-node .cn-title{font-size:16px;font-weight:600}.t-simple .cstruct-node .statusdot{width:30px;height:30px;font-size:15px}.t-simple .result .score{font-size:44px}.t-simple .result h3{font-size:24px}.t-simple .result p{font-size:15px}.shell{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.shell-main{flex:1;min-height:0;overflow-y:auto}.topbar{z-index:30;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);background:#ffffffeb;align-items:center;gap:12px;padding:10px 22px;display:flex;position:sticky;top:0}.topbar .brand-logo{flex:none;height:28px}.topbar .spacer{flex:1}.ws-nav{align-items:center;gap:4px;display:flex;overflow-x:auto}.ws-btn{white-space:nowrap;min-height:38px;font:inherit;color:var(--ink-soft);cursor:pointer;transition:all .16s var(--ease);background:0 0;border:0;border-radius:9px;justify-content:center;align-items:center;gap:7px;padding:8px 14px;font-size:13.5px;font-weight:600;display:inline-flex}.ws-btn:hover{background:var(--mist-soft);color:var(--ink)}.ws-btn.active{background:var(--mist);color:var(--teal-deep)}.ws-ico{font-size:15px}.topbar-end{align-items:center;gap:10px;display:flex}.topbar-end .langsw{margin-left:0}.langsw button{min-height:40px;padding:6px 12px}.usermenu{position:relative}.usermenu-btn{font:inherit;border:1px solid var(--line-2);background:var(--panel);color:var(--ink);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:5px 12px 5px 6px;font-size:13px;font-weight:600;display:inline-flex}.usermenu-btn:hover{border-color:var(--teal)}.um-avatar{background:var(--teal);color:#fff;border-radius:50%;place-items:center;width:26px;height:26px;font-size:13px;font-weight:800;display:grid}.menu-back{z-index:40;position:fixed;inset:0}.usermenu-pop{z-index:41;background:var(--panel);border:1px solid var(--line);min-width:220px;box-shadow:var(--shadow-l);border-radius:12px;padding:12px 14px;position:absolute;top:calc(100% + 8px);right:0}.um-name{font-family:var(--disp);font-size:15px;font-weight:700}.um-roles{color:var(--ink-soft);margin:3px 0 10px;font-size:12px;line-height:1.4}.ws-burger{border:1px solid var(--line-2);background:var(--panel);width:38px;height:38px;color:var(--ink);cursor:pointer;border-radius:10px;font-size:18px;display:none}.drawer-back{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#10323757;justify-content:flex-end;animation:.16s fadeIn;display:flex;position:fixed;inset:0}.drawer{background:var(--panel);width:290px;max-width:86vw;height:100%;box-shadow:var(--shadow-l);animation:drawerIn .22s var(--ease);flex-direction:column;padding:14px;display:flex}@keyframes drawerIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.drawer-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.drawer-head .brand-logo{height:26px}.drawer-nav{flex-direction:column;gap:4px;display:flex}.drawer-btn{font:inherit;color:var(--ink-soft);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:10px;align-items:center;gap:10px;padding:12px 14px;font-size:15px;font-weight:600;display:flex}.drawer-btn.active{background:var(--mist);color:var(--teal-deep)}.drawer-foot{border-top:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:8px;margin-top:auto;padding-top:14px;display:flex}.drawer-foot .langsw{margin:0 0 4px}.subnav{flex-wrap:wrap;gap:4px;max-width:1180px;margin:0 auto;padding:8px 22px 0;display:flex}.subnav-btn{font:inherit;color:var(--ink-soft);cursor:pointer;transition:all .15s var(--ease);background:0 0;border:0;border-bottom:2px solid #0000;border-radius:8px 8px 0 0;padding:8px 16px;font-size:14px;font-weight:600}.subnav-btn:hover{color:var(--ink);background:var(--mist-soft)}.subnav-btn.active{color:var(--teal-deep);border-bottom-color:var(--teal)}.bell{position:relative}.bell-btn{border:1px solid var(--line-2);background:var(--panel);cursor:pointer;border-radius:10px;width:38px;height:38px;font-size:17px;position:relative}.bell-btn:hover{border-color:var(--teal)}.bell-badge{background:var(--coral);color:#fff;border:2px solid var(--panel);border-radius:999px;place-items:center;min-width:18px;height:18px;padding:0 4px;font-size:11px;font-weight:800;display:grid;position:absolute;top:-5px;right:-5px}.bell-panel{z-index:41;background:var(--panel);border:1px solid var(--line);width:360px;max-width:92vw;box-shadow:var(--shadow-l);border-radius:14px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.bell-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.bell-head strong{font-family:var(--disp);font-size:16px}.bell-mark{color:var(--teal-deep);font:inherit;cursor:pointer;background:0 0;border:0;font-size:12.5px;font-weight:600}.bell-list{max-height:60vh;overflow-y:auto}.bell-item{border-bottom:1px solid var(--line);gap:10px;padding:12px 16px;display:flex}.bell-item.unread{background:var(--mist-soft)}.bell-dot{border-radius:50%;flex:none;place-items:center;width:24px;height:24px;font-size:12px;font-weight:800;display:grid}.bell-dot.info{background:var(--mist);color:var(--teal-deep)}.bell-dot.warn{background:var(--amber-bg);color:var(--amber-ink)}.bell-dot.success{background:var(--green-bg);color:#117a57}.bell-title{font-size:13.5px;font-weight:700}.bell-body{color:var(--ink-soft);margin-top:2px;font-size:12.5px;line-height:1.4}.bell-time{color:var(--ink-faint);margin-top:4px;font-size:11px}.splash,.ws-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;display:flex}.splash{min-height:100vh}.splash-logo{opacity:.95;height:36px}.splash-spinner{border:3px solid var(--mist);border-top-color:var(--teal);border-radius:50%;width:34px;height:34px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{background:radial-gradient(120% 90% at 50% -10%,#f1fbfc 0%,#fff 45%),linear-gradient(#fff 0%,#eaf8fa 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-screen:before{content:"";z-index:-2;pointer-events:none;background:radial-gradient(circle,#30b8c857,#0000 62%);border-radius:50%;width:70vmax;height:70vmax;position:fixed;top:-28vmax;left:-24vmax}.login-screen:after{content:"";z-index:-2;pointer-events:none;background:radial-gradient(circle,#2ccad842,#0000 62%);border-radius:50%;width:58vmax;height:58vmax;position:fixed;bottom:-26vmax;right:-22vmax}.login-screen .bg-grid{z-index:-1;background-image:radial-gradient(38vmax 38vmax at 88% 6%, #fff20029, transparent 60%), radial-gradient(var(--line-2) 1px, transparent 1px);opacity:.8;pointer-events:none;background-size:auto,24px 24px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(90% 80% at 50% 35%,#000,#0000 85%);mask-image:radial-gradient(90% 80% at 50% 35%,#000,#0000 85%)}.login-backdrop{z-index:0;pointer-events:none;opacity:.6;position:fixed;inset:0;-webkit-mask-image:radial-gradient(75% 75% at 50% 45%,#000 55%,#0000 92%);mask-image:radial-gradient(75% 75% at 50% 45%,#000 55%,#0000 92%)}.login-backdrop model-viewer{width:100%;height:100%}.login-backdrop-img{object-fit:contain;width:100%;height:100%;display:block}.login-photo{z-index:-3;pointer-events:none;position:fixed;inset:0;overflow:hidden}.login-photo-img{object-fit:cover;width:100%;height:100%;filter:blur(var(--login-blur,18px));transform:scale(1.1)}.login-photo:after{content:"";background:linear-gradient(0deg, rgba(0, 0, 0, var(--login-dim,.36)), rgba(0, 0, 0, var(--login-dim,.36))), linear-gradient(0deg, rgba(48, 184, 200, var(--login-tint,.22)), rgba(48, 184, 200, var(--login-tint,.22)));position:absolute;inset:0}.login-caption{z-index:1;text-align:center;pointer-events:none;font-family:var(--disp);filter:drop-shadow(0 6px 22px #0006);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:0 5vw;display:none;position:fixed;inset:0 50% 0 0}.login-caption-title{font-size:calc(clamp(40px, 6vw, 88px) * var(--cap-size,1));letter-spacing:-1px;color:var(--cap-color,#fff);font-weight:700;line-height:1.02}.login-caption-sub{font-size:calc(clamp(15px, 1.7vw, 23px) * var(--cap-size,1));letter-spacing:.2px;color:var(--cap-color,#fff);opacity:.92;font-weight:600}.cap-solid .login-caption-title{color:var(--cap-color,#fff)}.cap-gradient .login-caption-title{background:linear-gradient(100deg, var(--cap-color,#fff), var(--cap-accent,#2ccad8));color:#0000;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.cap-outline .login-caption-title{color:#0000;-webkit-text-stroke:2px var(--cap-color,#fff)}.cap-anim-fade{animation:capFade .8s var(--ease) both}.cap-anim-rise,.cap-anim-shine{animation:capRise .8s var(--ease) both}.cap-anim-shine .login-caption-title{background:linear-gradient(100deg, var(--cap-color,#fff) 0%, var(--cap-accent,#2ccad8) 35%, var(--cap-color,#fff) 70%);color:#0000;-webkit-text-fill-color:transparent;background-size:220%;-webkit-background-clip:text;background-clip:text;animation:4.5s linear infinite capShine}@keyframes capFade{0%{opacity:0}to{opacity:1}}@keyframes capRise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}@keyframes capShine{to{background-position:220%}}@media (prefers-reduced-motion:reduce){.login-caption,.login-caption-title{animation:none!important}}@media (width>=1000px){.login-screen{justify-content:flex-end;padding:0}.login-card{border:0;border-left:1px solid var(--line);border-radius:0;width:840px;max-width:60vw;height:100dvh;padding:0;animation:none;overflow-y:auto}.login-backdrop{opacity:.95;right:50%;-webkit-mask-image:radial-gradient(68% 70%,#000 60%,#0000 92%);mask-image:radial-gradient(68% 70%,#000 60%,#0000 92%)}.login-caption{display:flex}}.login-card{z-index:1;position:relative}@media (width<=520px){.login-screen{padding:16px}.login-card{border-radius:18px}.login-inner{padding:26px 22px}}.login-card{border:1px solid var(--line);width:460px;max-width:100%;box-shadow:var(--shadow-l);animation:popIn .25s var(--ease);background:linear-gradient(#fff 0%,#fbfeff 100%);border-radius:22px;flex-direction:column;display:flex;overflow:hidden}.login-inner{box-sizing:border-box;flex-direction:column;flex:1;justify-content:center;width:100%;max-width:460px;min-height:0;margin:0 auto;padding:38px 42px;display:flex}.login-inner>*{animation:loginIn .5s var(--ease) both}.login-head{animation-delay:40ms}.login-inner>form{animation-delay:.14s}.login-demo{animation-delay:.24s}@keyframes loginIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.login-head{text-align:center;margin-bottom:24px}.login-logo{width:auto;height:40px;margin:0 auto 16px;display:block}.login-title{font-family:var(--disp);letter-spacing:-.5px;color:var(--ink);margin:0;font-size:27px;font-weight:700}.login-foot{background:#cdf3f5;border-top:1px solid #a9ddd9;justify-content:center;align-items:center;gap:12px;padding:14px 20px;display:flex}.login-foot-label{color:var(--teal-deep);font-size:12.5px;font-weight:600}.login-foot .langsw{margin:0}.login-cake{width:100%;height:168px;margin:6px auto 14px}.login-cake model-viewer,.login-cake-img{width:100%;height:100%;display:block}.login-cake-img{object-fit:contain}.login-decor{z-index:0;pointer-events:none;position:fixed;inset:0}.sprinkle{opacity:.7;will-change:transform;width:17px;height:6px;animation:floaty 7s var(--ease) infinite;border-radius:6px;position:absolute}.decor-star{opacity:.5;color:var(--teal);will-change:transform;animation:floaty 9s var(--ease) infinite;font-size:20px;position:absolute}.sprinkle.s1{--r:24deg;background:var(--teal);top:22%;left:12%}.sprinkle.s2{--r:-18deg;background:var(--amber);animation-duration:8s;animation-delay:.6s;top:13%;left:31%}.sprinkle.s3{--r:40deg;background:var(--coral);animation-delay:1.2s;top:55%;left:7%}.sprinkle.s4{--r:-30deg;background:var(--teal-bright);animation-duration:9s;animation-delay:.3s;top:66%;left:39%}.sprinkle.s5{--r:12deg;background:var(--amber);animation-delay:1.6s;top:82%;left:20%}.sprinkle.s6{--r:-44deg;background:var(--coral);animation-duration:8.5s;animation-delay:.9s;top:38%;left:45%}.sprinkle.s7{--r:8deg;background:var(--teal);animation-delay:2s;top:34%;left:5%}.sprinkle.s8{--r:-12deg;background:var(--teal-bright);animation-duration:7.5s;animation-delay:1.1s;top:49%;left:26%}.decor-star.ds1{animation-delay:.4s;top:42%;left:17%}.decor-star.ds2{color:var(--amber);font-size:15px;animation-delay:1.4s;top:25%;left:41%}@keyframes floaty{0%,to{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-15px) rotate(var(--r,0deg))}}.login-error{color:var(--coral);margin:0 0 10px;font-size:13px}.login-submit{justify-content:center;width:100%;margin-top:4px}.login-demo{border-top:1px dashed var(--line-2);margin-top:22px;padding-top:18px}.login-demo-title{letter-spacing:.5px;text-transform:uppercase;color:var(--ink-faint);font-size:12px;font-weight:700}.login-demo-grid{grid-template-columns:1fr 1fr;gap:7px;margin-top:10px;display:grid}.login-demo-grid .btn{justify-content:center}.ph-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=680px){.ph-grid{grid-template-columns:1fr}}.ph-card{border:1px solid var(--line);background:var(--bg-soft);border-radius:12px;align-items:flex-start;gap:11px;padding:14px 16px;display:flex}.ph-dot{background:var(--teal);border-radius:50%;flex:none;width:9px;height:9px;margin-top:5px}@media (width<=760px){.topbar{gap:8px;padding:9px 14px}.ws-nav,.topbar-end{display:none}.ws-burger{display:block}.subnav{padding:8px 14px 0;overflow-x:auto}}@media (width<=680px){.page{padding-left:16px;padding-right:16px}.tbl{-webkit-overflow-scrolling:touch;white-space:nowrap;display:block;overflow-x:auto}.pagehead h2{font-size:26px}}.filterbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.filter-sel,.filter-search{font:inherit;border:1px solid var(--line-2);background:var(--panel);color:var(--ink);border-radius:9px;padding:8px 11px;font-size:13px}.filter-search{flex:200px;min-width:200px}.filter-sel{max-width:210px}.filter-sel:focus,.filter-search:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--mist);outline:none}.emp-id{color:var(--ink-faint);font-size:11.5px}.emp-roles{flex-wrap:wrap;gap:4px;display:inline-flex}.clickrow{cursor:pointer}.emp-head{align-items:center;gap:14px;display:flex}.emp-avatar{background:var(--mist);width:50px;height:50px;color:var(--teal-deep);font-family:var(--disp);border-radius:50%;flex:none;place-items:center;font-size:20px;font-weight:700;display:grid}.emp-meta{color:var(--ink-soft);flex-wrap:wrap;gap:8px 16px;margin:12px 0 4px;font-size:13px;display:flex}.emp-meta b{color:var(--ink);font-weight:600}.emp-section{margin-top:20px}.emp-section h4{font-family:var(--disp);margin:0 0 10px;font-size:15px;font-weight:700}.emp-actions{flex-wrap:wrap;gap:8px;display:flex}.timeline{padding-left:20px;position:relative}.timeline:before{content:"";background:var(--line-2);width:2px;position:absolute;top:5px;bottom:5px;left:5px}.tl-item{padding:0 0 14px;position:relative}.tl-item:last-child{padding-bottom:0}.tl-dot{background:var(--teal);border:2px solid var(--panel);width:10px;height:10px;box-shadow:0 0 0 1px var(--line-2);border-radius:50%;position:absolute;top:3px;left:-18px}.tl-text{font-size:13.5px}.tl-date{color:var(--ink-faint);margin-top:2px;font-size:11.5px}.reports-layout{grid-template-columns:256px 1fr;align-items:start;gap:18px;display:grid}@media (width<=880px){.reports-layout{grid-template-columns:1fr}}.rep-list{border:1px solid var(--line);background:var(--bg-soft);box-shadow:var(--shadow-s);border-radius:14px;flex-direction:column;gap:4px;padding:8px;display:flex}.rep-btn{text-align:left;cursor:pointer;font:inherit;color:var(--ink-soft);background:0 0;border:0;border-radius:10px;padding:10px 12px}.rep-btn:hover{background:var(--mist-soft)}.rep-btn.active{background:var(--mist);color:var(--teal-deep)}.rep-btn b{color:var(--ink);font-size:13.5px;font-weight:700;display:block}.rep-btn.active b{color:var(--teal-deep)}.rep-btn small{color:var(--ink-faint);margin-top:2px;font-size:11.5px;line-height:1.3;display:block}.rep-main{min-width:0}.rep-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.rep-count{color:var(--ink-soft);font-size:13px}.rep-empty{text-align:center;color:var(--ink-soft);padding:48px 20px}.studio{background:var(--bg);grid-template-columns:300px 1fr;height:100%;min-height:0;display:grid}.studio.collapsed{grid-template-columns:50px 1fr}.studio-rail{border-right:1px solid var(--line);background:var(--bg-soft);flex-direction:column;min-height:0;display:flex;overflow:hidden}.studio-rail-head{border-bottom:1px solid var(--line);align-items:center;gap:8px;min-height:0;padding:12px;display:flex}.studio-rail-head .grow{flex:1;min-width:0}.studio.collapsed .studio-rail-head{justify-content:center;padding:12px 0}.studio-rail-body{flex:1;min-height:0;padding:12px 10px 28px;overflow-y:auto}.studio-collapse{border:1px solid var(--line-2);background:var(--panel);width:28px;height:28px;color:var(--ink-soft);cursor:pointer;transition:all .15s var(--ease);border-radius:8px;flex:none;place-items:center;font-size:15px;line-height:1;display:grid}.studio-collapse:hover{border-color:var(--teal);color:var(--teal-deep);background:var(--mist-soft)}.studio-main{flex-direction:column;min-width:0;min-height:0;display:flex;overflow-y:auto}.studio-main-head{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);background:#ffffffeb;flex-wrap:wrap;align-items:center;gap:11px;padding:13px 26px;display:flex;position:sticky;top:0}.studio-main-head .sm-title{font-family:var(--disp);letter-spacing:-.3px;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;max-width:46vw;margin:0;font-size:21px;font-weight:700;overflow:hidden}.studio-main-head .spacer{flex:1}.studio-main-body{max-width:1080px;padding:22px 26px 64px}.studio-main .page{max-width:none;margin:0;padding:22px 26px 64px;animation:none}@media (width<=860px){.studio{grid-template-columns:1fr;height:auto}.studio.collapsed{grid-template-columns:1fr}.studio-rail{border-right:0;border-bottom:1px solid var(--line)}.studio-rail-body{max-height:44vh}.studio.collapsed .studio-rail-body{display:none}.studio-main{overflow:visible}.studio-main-body,.studio-main .page{padding-left:16px;padding-right:16px}}
