.bell-wrap[data-v-7eb6a87c]{cursor:pointer;border-radius:8px;align-items:center;padding:.3rem .5rem;display:flex;position:relative}.bell-wrap[data-v-7eb6a87c]:hover{background:#ffffff26}.bell-icon[data-v-7eb6a87c]{font-size:1.3rem}.badge[data-v-7eb6a87c]{color:#fff;background:#f44336;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:0;right:0}.tooltip[data-v-7eb6a87c]{color:#fff;white-space:nowrap;z-index:200;background:#000c;border-radius:6px;padding:.4rem .7rem;font-size:.8rem;display:none;position:absolute;top:110%;right:0}.bell-wrap:hover .tooltip[data-v-7eb6a87c]{display:block}@keyframes blink-7eb6a87c{0%,to{opacity:1}50%{opacity:.3}}.blink[data-v-7eb6a87c]{animation:1.2s ease-in-out infinite blink-7eb6a87c}.sidebar[data-v-5e511170]{color:#fff;background:#1a73e8;flex-direction:column;flex-shrink:0;width:200px;min-height:100vh;display:flex}.logo[data-v-5e511170]{border-bottom:1px solid #fff3;padding:1.5rem 1.2rem;font-size:1.2rem;font-weight:700}nav[data-v-5e511170]{flex:1;padding:.5rem 0}.nav-item[data-v-5e511170]{color:#ffffffd9;align-items:center;gap:.5rem;padding:.75rem 1.2rem;font-size:.95rem;text-decoration:none;transition:background .15s;display:flex}.ni[data-v-5e511170]{text-align:center;flex-shrink:0;width:1.4em;font-size:1rem;line-height:1;display:inline-block}.nav-item[data-v-5e511170]:hover,.nav-item.router-link-active[data-v-5e511170]{color:#fff;background:#ffffff26}.nav-group[data-v-5e511170]{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between}.arrow[data-v-5e511170]{margin-left:auto;font-size:1rem;transition:transform .2s;display:inline-block}.arrow.open[data-v-5e511170]{transform:rotate(90deg)}.sub-menu[data-v-5e511170]{overflow:hidden}.sub-item[data-v-5e511170]{padding-left:2.4rem;font-size:.9rem}.bottom[data-v-5e511170]{border-top:1px solid #fff3;padding:1rem 1.2rem;font-size:.85rem}.user-row[data-v-5e511170]{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.user-name[data-v-5e511170]{opacity:.8;font-size:.85rem}button[data-v-5e511170]{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:4px;width:100%;padding:.4rem}button[data-v-5e511170]:hover{background:#ffffff4d}.sidebar-close[data-v-5e511170]{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:4px;width:auto;padding:.2rem .5rem;font-size:1rem;display:none;position:absolute;top:.6rem;right:.6rem}@media (width<=768px){.sidebar[data-v-5e511170]{z-index:200;width:220px;height:100vh;transition:left .25s;position:fixed;top:0;left:-220px;overflow-y:auto}.sidebar-open[data-v-5e511170]{left:0}.sidebar-close[data-v-5e511170]{display:block}.logo[data-v-5e511170]{padding-right:2.5rem}}.appearance[data-v-5e511170]{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.appearance-label[data-v-5e511170]{opacity:.75;white-space:nowrap;font-size:.78rem}.seg-ctrl[data-v-5e511170]{background:#00000040;border-radius:6px;flex:1;gap:2px;padding:2px;display:flex}.seg-ctrl button[data-v-5e511170]{color:#ffffff8c;cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:.3rem 0;font-size:.95rem;line-height:1;transition:background .15s,color .15s}.seg-ctrl button[data-v-5e511170]:hover{color:#fff;background:#ffffff26}.seg-ctrl button.active[data-v-5e511170]{color:#1a73e8;background:#ffffffe6}[data-theme=dark] .seg-ctrl button.active[data-v-5e511170]{color:#1c2333;background:#ffffffd9}[data-theme=dark] .sidebar[data-v-5e511170]{background:#1c2333}:root{--bg-page:#f0f4f8;--bg-card:#fff;--bg-input:#fff;--text-1:#1a1a2e;--text-2:#444;--text-3:#555;--text-4:#888;--border-1:#d0d0d0;--border-2:#e8e8e8;--border-3:#ccc;--shadow-card:0 2px 8px #0000001a}[data-theme=dark]{--bg-page:#0d1117;--bg-card:#161b22;--bg-input:#21262d;--text-1:#e6edf3;--text-2:#c9d1d9;--text-3:#9aa0b4;--text-4:#6e7681;--border-1:#3d444d;--border-2:#2d333b;--border-3:#444c56;--shadow-card:0 2px 8px #0006}[data-theme=dark] body{background:var(--bg-page);color:var(--text-1)}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--bg-input)!important;color:var(--text-1)!important;border-color:var(--border-3)!important}[data-theme=dark] button:not(.btn-primary):not(.btn-danger):not(.btn-accept):not(.btn-reject):not(.btn-accept-all):not(.btn-merge):not(.btn-reset):not(.hamburger):not(.sidebar-close):not(.seg-btn){background:var(--bg-input);color:var(--text-1);border-color:var(--border-3)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-page);font-family:system-ui,sans-serif}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;min-width:0;padding:2rem;overflow-y:auto}.hamburger{z-index:300;cursor:pointer;background:#1a73e8;border:none;border-radius:6px;flex-direction:column;gap:5px;padding:.45rem .5rem;display:none;position:fixed;top:.8rem;left:.8rem}.hamburger span{background:#fff;border-radius:2px;width:22px;height:2px;display:block}.sidebar-overlay{z-index:199;background:#0006;display:none;position:fixed;inset:0}@media (width<=768px){.hamburger{display:flex}.sidebar-overlay{display:block}.main-content{padding:3.5rem 1rem 1rem}}.login-wrap[data-v-1d7fa43e]{background:var(--bg-page);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box[data-v-1d7fa43e]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;width:360px;padding:2.5rem}h1[data-v-1d7fa43e]{color:#1a73e8;margin:0 0 .25rem;font-size:1.8rem}.subtitle[data-v-1d7fa43e]{color:#666;margin:0 0 1.5rem}.field[data-v-1d7fa43e]{margin-bottom:1rem}label[data-v-1d7fa43e]{color:#444;margin-bottom:.3rem;font-size:.85rem;display:block}input[data-v-1d7fa43e]{border:1px solid var(--border-3);box-sizing:border-box;border-radius:6px;width:100%;padding:.6rem .8rem;font-size:1rem}button[data-v-1d7fa43e]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:6px;width:100%;margin-top:.5rem;padding:.75rem;font-size:1rem}button[data-v-1d7fa43e]:disabled{opacity:.6;cursor:default}.error[data-v-1d7fa43e]{color:#d32f2f;font-size:.85rem}.hint[data-v-1d7fa43e]{text-align:center;color:var(--text-4);margin-top:1rem;font-size:.8rem}.calendar-wrap[data-v-9e6fdfd6]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;padding:1.5rem}.cal-header[data-v-9e6fdfd6]{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.title-block[data-v-9e6fdfd6]{text-align:center}.title-block h2[data-v-9e6fdfd6]{color:#222;margin:0;font-size:1.1rem}.cal-header button[data-v-9e6fdfd6]{background:var(--bg-input);border:1px solid var(--border-3);cursor:pointer;color:var(--text-1);border-radius:6px;padding:.3rem .8rem;font-size:1.2rem}.cal-header button[data-v-9e6fdfd6]:disabled{opacity:.3;cursor:default}.cal-grid[data-v-9e6fdfd6]{grid-template-columns:56px repeat(7,1fr);gap:2px;display:grid}.week-head[data-v-9e6fdfd6]{text-align:center;color:#aaa;padding:.4rem 0;font-size:.72rem;font-weight:600}.day-label[data-v-9e6fdfd6]{text-align:center;color:var(--text-3);padding:.4rem 0;font-size:.8rem;font-weight:600}.week-num[data-v-9e6fdfd6]{color:#aaa;white-space:nowrap;justify-content:center;align-items:flex-start;padding-top:.5rem;font-size:.68rem;font-weight:600;line-height:1.3;display:flex}.week-num.clickable[data-v-9e6fdfd6]{color:#1a73e8;cursor:pointer;text-decoration:underline}.week-num.clickable[data-v-9e6fdfd6]:hover{color:#1557b0}.day-cell[data-v-9e6fdfd6]{border:1px solid var(--border-2);border-radius:4px;flex-direction:column;gap:2px;min-height:72px;padding:.35rem .4rem;display:flex}.day-num[data-v-9e6fdfd6]{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.85rem;font-weight:500;display:flex}.other-month .day-num[data-v-9e6fdfd6]{color:#ccc}.out-semester[data-v-9e6fdfd6]{background:#fafafa}.out-semester .day-num[data-v-9e6fdfd6]{color:#ddd}.today[data-v-9e6fdfd6]{background:#e8f0fe}.today .day-num[data-v-9e6fdfd6]{color:#fff;background:#1a73e8}.sub-tags[data-v-9e6fdfd6]{flex-direction:column;gap:2px;display:flex}.sub-dot[data-v-9e6fdfd6]{white-space:nowrap;text-overflow:ellipsis;border-radius:3px;max-width:100%;padding:1px 4px;font-size:.68rem;font-weight:500;overflow:hidden}.sub-dot.pending[data-v-9e6fdfd6]{color:#e65100;background:#fff3e0}.sub-dot.accepted[data-v-9e6fdfd6]{color:#2e7d32;background:#e8f5e9}.sub-dot.other[data-v-9e6fdfd6]{color:#757575;background:#f5f5f5}.legend[data-v-9e6fdfd6]{flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:1rem;font-size:.8rem;display:flex}.legend-hint[data-v-9e6fdfd6]{color:#aaa;font-size:.75rem}@media (width<=768px){.calendar-wrap[data-v-9e6fdfd6]{border-radius:8px;padding:.75rem .5rem}.cal-header button[data-v-9e6fdfd6]{padding:.3rem .5rem}.title-block h2[data-v-9e6fdfd6]{font-size:.95rem}.cal-grid[data-v-9e6fdfd6]{display:block;overflow-x:auto}.cal-grid[data-v-9e6fdfd6]>*{display:contents}.cal-grid[data-v-9e6fdfd6]{grid-template-columns:32px repeat(7,minmax(38px,1fr));gap:1px;display:grid}.week-num[data-v-9e6fdfd6]{padding-top:.3rem;font-size:.58rem}.day-label[data-v-9e6fdfd6]{padding:.25rem 0;font-size:.65rem}.day-cell[data-v-9e6fdfd6]{min-height:52px;padding:.2rem .15rem}.day-num[data-v-9e6fdfd6]{width:20px;height:20px;font-size:.72rem}.sub-dot[data-v-9e6fdfd6]{padding:1px 2px;font-size:.58rem}}.toolbar[data-v-eadbf5df]{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}h2[data-v-eadbf5df]{margin:0}.card[data-v-eadbf5df]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;margin-bottom:1rem;padding:1.5rem;overflow-x:auto}table[data-v-eadbf5df]{border-collapse:collapse;width:100%}th[data-v-eadbf5df]{text-align:left;color:var(--text-3);border-bottom:2px solid var(--border-1);padding:.5rem .75rem;font-size:.8rem}td[data-v-eadbf5df]{border-bottom:1px solid var(--border-2);padding:.6rem .75rem;font-size:.9rem}.actions[data-v-eadbf5df],.row-actions[data-v-eadbf5df]{gap:.5rem;display:flex}button[data-v-eadbf5df]{border:1px solid var(--border-3);background:var(--bg-card);color:var(--text-1);cursor:pointer;border-radius:4px;padding:.35rem .7rem;font-size:.85rem}.btn-primary[data-v-eadbf5df]{color:#fff;background:#1a73e8;border-color:#1a73e8}.btn-danger[data-v-eadbf5df]{color:#fff;background:#d32f2f;border-color:#d32f2f}.btn-merge[data-v-eadbf5df]{color:#fff;background:#e65100;border-color:#e65100}.overlay[data-v-eadbf5df]{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.warn-text[data-v-eadbf5df]{color:#b71c1c;margin:.4rem 0 0;font-size:.85rem}.error-text[data-v-eadbf5df]{color:#c62828;background:#fdecea;border-radius:4px;margin:.4rem 0 0;padding:.4rem .7rem;font-size:.85rem}.modal[data-v-eadbf5df]{background:var(--bg-card);color:var(--text-1);border-radius:12px;width:420px;padding:2rem}.modal h3[data-v-eadbf5df]{margin:0 0 1.2rem}.field[data-v-eadbf5df]{margin-bottom:.9rem}.field label[data-v-eadbf5df]{color:var(--text-2);margin-bottom:.3rem;font-size:.85rem;display:block}.field input[type=text][data-v-eadbf5df],.field input[data-v-eadbf5df]:not([type=checkbox]){border:1px solid var(--border-3);box-sizing:border-box;background:var(--bg-input);width:100%;color:var(--text-1);border-radius:6px;padding:.5rem .7rem;font-size:.95rem}.field select[data-v-eadbf5df]{border:1px solid var(--border-3);background:var(--bg-input);width:100%;color:var(--text-1);border-radius:6px;padding:.5rem .7rem;font-size:.95rem}.checkbox label[data-v-eadbf5df]{align-items:center;gap:.5rem;display:flex}.modal-actions[data-v-eadbf5df]{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.creds[data-v-eadbf5df]{background:#e8f5e9;border-radius:6px;margin-top:1rem;padding:.75rem 1rem;font-family:monospace}.merge-card[data-v-eadbf5df]{margin-bottom:1rem}.merge-header[data-v-eadbf5df]{cursor:pointer;border-bottom:1px solid var(--border-2);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding-bottom:.6rem;font-size:.95rem;font-weight:600;display:flex}.badge[data-v-eadbf5df]{color:#fff;background:#e65100;border-radius:10px;margin-left:.4rem;padding:1px 8px;font-size:.78rem;font-weight:700}.arrow[data-v-eadbf5df]{font-size:1rem;transition:transform .2s;display:inline-block}.arrow.open[data-v-eadbf5df]{transform:rotate(90deg)}.merge-hint[data-v-eadbf5df]{color:var(--text-4);margin:.6rem 0 .8rem;font-size:.83rem}.pagination[data-v-eadbf5df]{flex-wrap:wrap;align-items:center;gap:.3rem;margin-top:1rem;display:flex}.pagination button[data-v-eadbf5df]{border:1px solid var(--border-3);background:var(--bg-card);color:var(--text-1);cursor:pointer;border-radius:4px;min-width:32px;padding:.3rem .6rem;font-size:.85rem}.pagination button[data-v-eadbf5df]:disabled{opacity:.4;cursor:default}.pagination button.active[data-v-eadbf5df]{color:#fff;background:#1a73e8;border-color:#1a73e8;font-weight:600}.pagination .ellipsis[data-v-eadbf5df]{color:#888;padding:0 .2rem}.page-info[data-v-eadbf5df]{color:#888;margin-left:.5rem;font-size:.83rem}.toolbar[data-v-c2d316b5]{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.hint-text[data-v-c2d316b5]{color:#888;margin-bottom:.75rem;font-size:.82rem}h2[data-v-c2d316b5]{margin:0}.filters[data-v-c2d316b5]{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex;padding:.75rem 1rem!important}.filters select[data-v-c2d316b5],.filters input[data-v-c2d316b5]{border:1px solid var(--border-3);background:var(--bg-input);color:var(--text-1);border-radius:6px;padding:.4rem .6rem;font-size:.9rem}.week-hint[data-v-c2d316b5]{color:var(--text-4);font-size:.82rem}.field-hint[data-v-c2d316b5]{color:#888;font-size:.78rem;font-weight:400}.warn-text[data-v-c2d316b5]{color:#b71c1c;margin:.3rem 0 0;font-size:.85rem}.card[data-v-c2d316b5]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;padding:1.5rem;overflow-x:auto}table[data-v-c2d316b5]{border-collapse:collapse;width:100%}th[data-v-c2d316b5]{text-align:left;color:var(--text-3);border-bottom:2px solid var(--border-1);padding:.5rem .75rem;font-size:.8rem}td[data-v-c2d316b5]{border-bottom:1px solid var(--border-2);padding:.6rem .75rem;font-size:.9rem}.actions button[data-v-c2d316b5]{cursor:pointer;border:none;border-radius:4px;padding:.3rem .6rem;font-size:.85rem}.btn-primary[data-v-c2d316b5]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:4px;padding:.4rem .9rem}.btn-danger[data-v-c2d316b5]{color:#fff;background:#d32f2f}.overlay[data-v-c2d316b5]{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal[data-v-c2d316b5]{background:var(--bg-card);color:var(--text-1);border-radius:12px;width:460px;max-height:90vh;padding:2rem;overflow-y:auto}.modal h3[data-v-c2d316b5]{margin:0 0 1.2rem}.field[data-v-c2d316b5]{margin-bottom:.9rem}.field label[data-v-c2d316b5]{color:var(--text-2);margin-bottom:.3rem;font-size:.85rem;display:block}.field input[type=text][data-v-c2d316b5],.field input[type=date][data-v-c2d316b5],.field select[data-v-c2d316b5],.field input[data-v-c2d316b5]:not([type=checkbox]){border:1px solid var(--border-3);box-sizing:border-box;background:var(--bg-input);width:100%;color:var(--text-1);border-radius:6px;padding:.5rem .7rem;font-size:.95rem}.period-list[data-v-c2d316b5]{flex-direction:column;gap:.4rem;margin-top:.3rem;display:flex}.period-item[data-v-c2d316b5]{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.modal-actions[data-v-c2d316b5]{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.modal-actions button[data-v-c2d316b5]{border:1px solid var(--border-3);cursor:pointer;background:var(--bg-card);color:var(--text-1);border-radius:4px;padding:.4rem .9rem}.toolbar[data-v-b5fa3864]{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}h2[data-v-b5fa3864]{margin:0}.card[data-v-b5fa3864]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;padding:1.5rem;overflow-x:auto}table[data-v-b5fa3864]{border-collapse:collapse;width:100%}th[data-v-b5fa3864]{text-align:left;color:var(--text-3);border-bottom:2px solid var(--border-1);padding:.5rem .75rem;font-size:.8rem}td[data-v-b5fa3864]{border-bottom:1px solid var(--border-2);padding:.6rem .75rem;font-size:.9rem}.actions[data-v-b5fa3864]{gap:.4rem;display:flex}.actions button[data-v-b5fa3864]{cursor:pointer;border:none;border-radius:4px;padding:.3rem .6rem;font-size:.82rem}.btn-primary[data-v-b5fa3864]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:4px;padding:.4rem .9rem}.btn-primary[data-v-b5fa3864]:disabled{opacity:.5;cursor:default}.btn-accept[data-v-b5fa3864]{color:#fff;background:#2e7d32}.btn-reject[data-v-b5fa3864]{color:#fff;background:#e65100}.btn-danger[data-v-b5fa3864]{color:#fff;background:#d32f2f}.btn-accept-all[data-v-b5fa3864]{color:#fff;background:#1b5e20}tr.group-first td[data-v-b5fa3864]{border-top:2px solid var(--border-1)}tr.group-sub td[data-v-b5fa3864]{border-bottom:1px solid var(--border-2);color:var(--text-2)}.badge[data-v-b5fa3864]{border-radius:12px;padding:.2rem .6rem;font-size:.78rem;font-weight:500}.badge-pending[data-v-b5fa3864]{color:#e65100;background:#fff3e0}.badge-accepted[data-v-b5fa3864]{color:#2e7d32;background:#e8f5e9}.badge-rejected[data-v-b5fa3864]{color:#c62828;background:#ffebee}.badge-cancelled[data-v-b5fa3864]{color:#757575;background:#f5f5f5}.overlay[data-v-b5fa3864]{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal[data-v-b5fa3864]{background:var(--bg-card);color:var(--text-1);border-radius:12px;width:460px;max-height:90vh;padding:2rem;overflow-y:auto}.modal h3[data-v-b5fa3864]{margin:0 0 1.2rem}.field[data-v-b5fa3864]{margin-bottom:.9rem}.field label[data-v-b5fa3864]{color:var(--text-2);margin-bottom:.3rem;font-size:.85rem;display:block}.field input[data-v-b5fa3864],.field select[data-v-b5fa3864]{border:1px solid var(--border-3);box-sizing:border-box;background:var(--bg-input);width:100%;color:var(--text-1);border-radius:6px;padding:.5rem .7rem;font-size:.95rem}.period-list[data-v-b5fa3864]{flex-direction:column;gap:.5rem;display:flex}.period-item[data-v-b5fa3864]{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.sub-info[data-v-b5fa3864]{color:#888;font-size:.82rem}.empty-hint[data-v-b5fa3864]{color:#e65100;margin:.5rem 0;font-size:.85rem}.date-past[data-v-b5fa3864]{opacity:.6;border-color:#bbb!important}.past-hint[data-v-b5fa3864]{color:#888;background:#f5f5f5;border-radius:4px;margin-top:.3rem;padding:.1rem .5rem;font-size:.78rem;display:inline-block}[data-theme=dark] .past-hint[data-v-b5fa3864]{color:#6e7681;background:#2d333b}.error-text[data-v-b5fa3864]{color:#c62828;background:#fdecea;border-radius:4px;margin:.4rem 0 0;padding:.4rem .7rem;font-size:.85rem}.modal-actions[data-v-b5fa3864]{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.modal-actions button[data-v-b5fa3864]{border:1px solid var(--border-3);cursor:pointer;background:var(--bg-card);color:var(--text-1);border-radius:4px;padding:.4rem .9rem}.toolbar[data-v-a81aa11f]{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}h2[data-v-a81aa11f]{margin:0}.card[data-v-a81aa11f]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;max-width:560px;padding:2rem}.field[data-v-a81aa11f]{margin-bottom:1rem}.field label[data-v-a81aa11f]{color:var(--text-2);margin-bottom:.3rem;font-size:.85rem;display:block}.field input[data-v-a81aa11f],.field select[data-v-a81aa11f]{border:1px solid var(--border-3);box-sizing:border-box;background:var(--bg-input);width:100%;color:var(--text-1);border-radius:6px;padding:.5rem .7rem;font-size:.95rem}.row2[data-v-a81aa11f]{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-actions[data-v-a81aa11f]{align-items:center;gap:1rem;margin-top:1.5rem;display:flex}.btn-primary[data-v-a81aa11f]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:4px;padding:.5rem 1.2rem;font-size:.95rem}.btn-primary[data-v-a81aa11f]:disabled{opacity:.5;cursor:default}.saved-msg[data-v-a81aa11f]{color:#2e7d32;font-size:.9rem}.toolbar[data-v-5dab38f8]{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}h2[data-v-5dab38f8]{margin:0}.card[data-v-5dab38f8]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;padding:1.5rem}table[data-v-5dab38f8]{border-collapse:collapse;width:100%}th[data-v-5dab38f8]{text-align:left;color:var(--text-3);border-bottom:2px solid var(--border-1);padding:.5rem .75rem;font-size:.8rem}td[data-v-5dab38f8]{border-bottom:1px solid var(--border-2);padding:.6rem .75rem;font-size:.9rem}.actions[data-v-5dab38f8]{gap:.4rem;display:flex}.actions button[data-v-5dab38f8]{cursor:pointer;border:none;border-radius:4px;padding:.3rem .6rem;font-size:.82rem}.btn-primary[data-v-5dab38f8]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:4px;padding:.4rem .9rem}.btn-primary[data-v-5dab38f8]:disabled{opacity:.5;cursor:default}.btn-edit[data-v-5dab38f8]{color:#fff;background:#1565c0}.btn-danger[data-v-5dab38f8]{color:#fff;background:#d32f2f}.overlay[data-v-5dab38f8]{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal[data-v-5dab38f8]{background:var(--bg-card);color:var(--text-1);border-radius:12px;width:400px;padding:2rem}.modal h3[data-v-5dab38f8]{margin:0 0 1.2rem}.field[data-v-5dab38f8]{margin-bottom:.9rem}.field label[data-v-5dab38f8]{color:var(--text-2);margin-bottom:.3rem;font-size:.85rem;display:block}.field input[data-v-5dab38f8]{border:1px solid var(--border-3);box-sizing:border-box;background:var(--bg-input);width:100%;color:var(--text-1);border-radius:6px;padding:.5rem .7rem;font-size:.95rem}.row2[data-v-5dab38f8]{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.modal-actions[data-v-5dab38f8]{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.modal-actions button[data-v-5dab38f8]{border:1px solid var(--border-3);cursor:pointer;background:var(--bg-card);color:var(--text-1);border-radius:4px;padding:.4rem .9rem}.toolbar[data-v-801db504]{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1.2rem;display:flex}.btn-back[data-v-801db504]{border:1px solid var(--border-3);cursor:pointer;color:var(--text-2);background:0 0;border-radius:6px;padding:.35rem .8rem;font-size:.9rem}.btn-back[data-v-801db504]:hover{background:#f5f5f5}.week-title[data-v-801db504]{text-align:center}.week-title h2[data-v-801db504]{margin:0;font-size:1.1rem}.sub-title[data-v-801db504]{color:var(--text-4);margin-top:.15rem;font-size:.78rem}.nav-btns[data-v-801db504]{gap:.4rem;display:flex}.nav-btns button[data-v-801db504]{border:1px solid var(--border-3);cursor:pointer;background:var(--bg-input);color:var(--text-1);border-radius:6px;padding:.35rem .7rem;font-size:.9rem}.nav-btns button[data-v-801db504]:hover{background:#f5f5f5}.week-grid-wrap[data-v-801db504]{overflow-x:auto}.week-table[data-v-801db504]{border-collapse:collapse;background:var(--bg-card);width:100%;box-shadow:var(--shadow-card);border-radius:12px;overflow:hidden}.week-table th[data-v-801db504],.week-table td[data-v-801db504]{border:1px solid var(--border-2);vertical-align:top;padding:.5rem .6rem}.week-table thead th[data-v-801db504]{text-align:center;background:#f8f9fa}.period-col[data-v-801db504]{width:72px;min-width:72px}.day-head-name[data-v-801db504]{color:#444;font-size:.9rem;font-weight:600}.day-head-date[data-v-801db504]{color:var(--text-4);margin-top:.1rem;font-size:.78rem}th.weekend[data-v-801db504]{background:#f5f5f5}th.today[data-v-801db504]{background:#e8f0fe}th.today .day-head-name[data-v-801db504]{color:#1a73e8}td.weekend[data-v-801db504]{background:#fafafa}td.today[data-v-801db504]{background:#f0f5ff}.period-cell[data-v-801db504]{text-align:center;background:#f8f9fa}.period-name[data-v-801db504]{color:#444;font-size:.85rem;font-weight:600}.period-time[data-v-801db504]{color:#aaa;margin-top:.1rem;font-size:.72rem}.sub-card[data-v-801db504]{border-radius:6px;margin-bottom:.3rem;padding:.4rem .5rem;font-size:.8rem}.sub-card.pending[data-v-801db504]{background:#fff8f0;border-left:3px solid #e65100}.sub-card.accepted[data-v-801db504]{background:#f0faf0;border-left:3px solid #2e7d32}.sub-card.rejected[data-v-801db504]{background:#fff0f0;border-left:3px solid #c62828}.sub-card.cancelled[data-v-801db504]{background:#f5f5f5;border-left:3px solid #bbb}.sub-row[data-v-801db504]{align-items:baseline;gap:.3rem;display:flex}.sub-label[data-v-801db504]{color:#999;min-width:22px;font-size:.7rem}.sub-name[data-v-801db504]{color:#333;font-size:.82rem;font-weight:500}.sub-status[data-v-801db504]{margin-top:.25rem;font-size:.7rem;font-weight:600}.sub-status.pending[data-v-801db504]{color:#e65100}.sub-status.accepted[data-v-801db504]{color:#2e7d32}.sub-status.rejected[data-v-801db504]{color:#c62828}.sub-status.cancelled[data-v-801db504]{color:#bbb}.sub-extra[data-v-801db504]{color:var(--text-4);margin-top:.15rem;font-size:.72rem}.sub-extra.reason[data-v-801db504]{font-style:italic}.import-wrap[data-v-f816e7c0]{background:#fff;border-radius:12px;max-width:720px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.import-wrap h2[data-v-f816e7c0]{margin:0 0 .4rem;font-size:1.2rem}.hint[data-v-f816e7c0]{color:#888;margin:0 0 1.2rem;font-size:.9rem}.drop-zone[data-v-f816e7c0]{text-align:center;cursor:pointer;color:#888;border:2px dashed #ccc;border-radius:10px;padding:2rem;transition:border-color .2s,background .2s}.drop-zone[data-v-f816e7c0]:hover,.drop-zone.drag-over[data-v-f816e7c0]{color:#1a73e8;background:#f0f5ff;border-color:#1a73e8}.drop-zone.has-file[data-v-f816e7c0]{color:#2e7d32;background:#f0faf0;border-color:#2e7d32}.file-icon[data-v-f816e7c0]{margin-bottom:.4rem;font-size:2rem}.file-name[data-v-f816e7c0]{font-size:.95rem;font-weight:600}.file-size[data-v-f816e7c0]{opacity:.7;margin-top:.2rem;font-size:.8rem}.actions[data-v-f816e7c0]{margin-top:1rem}.btn-primary[data-v-f816e7c0]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:6px;padding:.5rem 1.4rem;font-size:.95rem}.btn-primary[data-v-f816e7c0]:disabled{opacity:.5;cursor:default}.preview-card[data-v-f816e7c0]{border:1px solid #e0e0e0;border-radius:10px;margin-top:1.5rem;padding:1.2rem}.preview-card h3[data-v-f816e7c0]{margin:0 0 1rem;font-size:1rem}.stats-row[data-v-f816e7c0]{flex-wrap:wrap;gap:1rem;margin-bottom:1rem;display:flex}.stat[data-v-f816e7c0]{text-align:center;background:#f5f5f5;border-radius:8px;min-width:70px;padding:.6rem 1rem}.stat-num[data-v-f816e7c0]{color:#1a73e8;font-size:1.4rem;font-weight:700}.stat-label[data-v-f816e7c0]{color:#888;margin-top:.1rem;font-size:.75rem}.warn-box[data-v-f816e7c0]{color:#5d4037;background:#fff8e1;border-left:3px solid #f9a825;border-radius:4px;margin:.8rem 0;padding:.6rem .9rem;font-size:.88rem}.warn-box a[data-v-f816e7c0]{color:#1a73e8}.detail-block[data-v-f816e7c0]{margin:.8rem 0}.detail-block summary[data-v-f816e7c0]{cursor:pointer;color:#555;padding:.3rem 0;font-size:.88rem;font-weight:600}.preview-table[data-v-f816e7c0]{border-collapse:collapse;width:100%;margin-top:.5rem;font-size:.85rem}.preview-table th[data-v-f816e7c0],.preview-table td[data-v-f816e7c0]{text-align:left;border:1px solid #eee;padding:.3rem .6rem}.preview-table th[data-v-f816e7c0]{background:#f8f9fa}.teacher-list[data-v-f816e7c0]{flex-wrap:wrap;gap:.3rem;margin-top:.5rem;display:flex}.teacher-tag[data-v-f816e7c0]{border-radius:3px;padding:2px 7px;font-size:.78rem}.teacher-tag.new[data-v-f816e7c0]{color:#2e7d32;background:#e8f5e9}.teacher-tag.existing[data-v-f816e7c0]{color:#777;background:#f5f5f5}.legend-row[data-v-f816e7c0]{color:#888;gap:.5rem;margin-top:.4rem;font-size:.78rem;display:flex}.import-action[data-v-f816e7c0]{align-items:center;gap:1rem;margin-top:1rem;display:flex}.btn-import[data-v-f816e7c0]{color:#fff;cursor:pointer;background:#2e7d32;border:none;border-radius:6px;padding:.55rem 1.6rem;font-size:.95rem}.btn-import[data-v-f816e7c0]:disabled{opacity:.5;cursor:default}.disabled-hint[data-v-f816e7c0]{color:#999;font-size:.82rem}.result-card[data-v-f816e7c0]{background:#f1f8f1;border:1px solid #c8e6c9;border-radius:10px;margin-top:1.5rem;padding:1.2rem}.result-card h3[data-v-f816e7c0]{color:#2e7d32;margin:0 0 .8rem;font-size:1rem}.result-rows[data-v-f816e7c0]{flex-direction:column;gap:.3rem;display:flex}.result-row[data-v-f816e7c0]{border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:.25rem 0;font-size:.9rem;display:flex}.result-row[data-v-f816e7c0]:last-child{border-bottom:none}.result-hint[data-v-f816e7c0]{color:#666;margin-top:.8rem;font-size:.82rem}.error-box[data-v-f816e7c0]{color:#c62828;background:#fdecea;border-left:3px solid #c62828;border-radius:4px;margin-top:1rem;padding:.6rem .9rem;font-size:.88rem}.general-wrap[data-v-fda9be02]{max-width:600px}.general-wrap h2[data-v-fda9be02]{margin:0 0 1.2rem;font-size:1.2rem}.section-card[data-v-fda9be02]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;padding:1.5rem}.section-card h3[data-v-fda9be02]{margin:0 0 .5rem;font-size:1rem}.hint[data-v-fda9be02]{color:var(--text-4);margin:0 0 1.2rem;font-size:.85rem;line-height:1.5}.select-row[data-v-fda9be02]{align-items:center;gap:.75rem;font-size:.9rem;display:flex}.select-row span[data-v-fda9be02]{min-width:100px}.select-row select[data-v-fda9be02]{border:1px solid #ddd;border-radius:6px;padding:.3rem .5rem;font-size:.9rem}.toggle-row[data-v-fda9be02]{cursor:pointer;align-items:center;gap:.75rem;font-size:.9rem;display:flex}.toggle-row input[type=checkbox][data-v-fda9be02]{cursor:pointer;width:18px;height:18px}.toggle-label[data-v-fda9be02]{color:#1a73e8;font-weight:600}.manage-wrap[data-v-5a3bb8cd]{max-width:680px}.manage-wrap h2[data-v-5a3bb8cd]{margin:0 0 1.2rem;font-size:1.2rem}.section-card[data-v-5a3bb8cd]{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:12px;padding:1.5rem}.section-card h3[data-v-5a3bb8cd]{margin:0 0 .5rem;font-size:1rem}.hint[data-v-5a3bb8cd]{color:var(--text-4);margin:0 0 1rem;font-size:.85rem;line-height:1.5}.drop-zone[data-v-5a3bb8cd]{border:2px dashed var(--border-3);text-align:center;cursor:pointer;color:var(--text-4);border-radius:10px;padding:1.8rem;transition:border-color .2s,background .2s}.drop-zone[data-v-5a3bb8cd]:hover,.drop-zone.drag-over[data-v-5a3bb8cd]{color:#1a73e8;background:#f0f5ff;border-color:#1a73e8}.drop-zone.has-file[data-v-5a3bb8cd]{color:#2e7d32;background:#f0faf0;border-color:#2e7d32}[data-theme=dark] .drop-zone[data-v-5a3bb8cd]:hover,[data-theme=dark] .drop-zone.drag-over[data-v-5a3bb8cd]{background:#1a2a40}[data-theme=dark] .drop-zone.has-file[data-v-5a3bb8cd]{background:#0e2218}.file-icon[data-v-5a3bb8cd]{margin-bottom:.4rem;font-size:2rem}.file-name[data-v-5a3bb8cd]{font-size:.95rem;font-weight:600}.file-size[data-v-5a3bb8cd]{opacity:.7;margin-top:.2rem;font-size:.8rem}.imp-actions[data-v-5a3bb8cd]{align-items:center;gap:1rem;margin-top:1rem;display:flex}.btn-primary[data-v-5a3bb8cd]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:6px;padding:.5rem 1.4rem;font-size:.9rem}.btn-primary[data-v-5a3bb8cd]:disabled{opacity:.5;cursor:default}.btn-import[data-v-5a3bb8cd]{color:#fff;cursor:pointer;background:#2e7d32;border:none;border-radius:6px;padding:.5rem 1.4rem;font-size:.9rem}.btn-import[data-v-5a3bb8cd]:disabled{opacity:.5;cursor:default}.disabled-hint[data-v-5a3bb8cd]{color:var(--text-4);font-size:.82rem}.preview-card[data-v-5a3bb8cd]{border:1px solid var(--border-2);border-radius:10px;margin-top:1.2rem;padding:1.1rem}.preview-card h4[data-v-5a3bb8cd]{margin:0 0 .8rem;font-size:.95rem}.stats-row[data-v-5a3bb8cd]{flex-wrap:wrap;gap:.75rem;margin-bottom:.8rem;display:flex}.stat[data-v-5a3bb8cd]{background:var(--border-2);text-align:center;border-radius:8px;min-width:64px;padding:.5rem .9rem}.stat-num[data-v-5a3bb8cd]{color:#1a73e8;font-size:1.3rem;font-weight:700}.stat-label[data-v-5a3bb8cd]{color:var(--text-4);margin-top:.1rem;font-size:.72rem}.warn-box[data-v-5a3bb8cd]{color:#5d4037;background:#fff8e1;border-left:3px solid #f9a825;border-radius:4px;margin:.6rem 0;padding:.6rem .9rem;font-size:.85rem}.warn-box a[data-v-5a3bb8cd]{color:#1a73e8}[data-theme=dark] .warn-box[data-v-5a3bb8cd]{color:#ffd54f;background:#2a2000}.detail-block[data-v-5a3bb8cd]{margin:.6rem 0}.detail-block summary[data-v-5a3bb8cd]{cursor:pointer;color:var(--text-2);padding:.3rem 0;font-size:.85rem;font-weight:600}.preview-table[data-v-5a3bb8cd]{border-collapse:collapse;width:100%;margin-top:.4rem;font-size:.83rem}.preview-table th[data-v-5a3bb8cd],.preview-table td[data-v-5a3bb8cd]{border:1px solid var(--border-2);text-align:left;padding:.3rem .5rem}.preview-table th[data-v-5a3bb8cd]{background:var(--border-2);color:var(--text-2)}.teacher-list[data-v-5a3bb8cd]{flex-wrap:wrap;gap:.3rem;margin-top:.4rem;display:flex}.teacher-tag[data-v-5a3bb8cd]{border-radius:3px;padding:2px 7px;font-size:.78rem}.teacher-tag.new[data-v-5a3bb8cd]{color:#2e7d32;background:#e8f5e9}.teacher-tag.existing[data-v-5a3bb8cd]{background:var(--border-2);color:var(--text-3)}.legend-row[data-v-5a3bb8cd]{gap:.5rem;margin-top:.4rem;display:flex}.result-card[data-v-5a3bb8cd]{background:#f1f8f1;border:1px solid #c8e6c9;border-radius:10px;margin-top:1.2rem;padding:1.1rem}.result-card h4[data-v-5a3bb8cd]{color:#2e7d32;margin:0 0 .6rem;font-size:.95rem}[data-theme=dark] .result-card[data-v-5a3bb8cd]{background:#0e2218;border-color:#1e5e30}[data-theme=dark] .result-card h4[data-v-5a3bb8cd]{color:#7ec89a}.result-rows[data-v-5a3bb8cd]{flex-direction:column;gap:.25rem;display:flex}.result-row[data-v-5a3bb8cd]{border-bottom:1px solid var(--border-2);justify-content:space-between;padding:.25rem 0;font-size:.88rem;display:flex}.result-row[data-v-5a3bb8cd]:last-child{border-bottom:none}.result-hint[data-v-5a3bb8cd]{color:var(--text-4);margin-top:.6rem;font-size:.8rem}.error-box[data-v-5a3bb8cd]{color:#c62828;background:#fdecea;border-left:3px solid #c62828;border-radius:4px;margin-top:.8rem;padding:.6rem .9rem;font-size:.85rem}[data-theme=dark] .error-box[data-v-5a3bb8cd]{color:#f48a8a;background:#2a1010}.info-row[data-v-5a3bb8cd]{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.info-label[data-v-5a3bb8cd]{color:var(--text-2);flex-shrink:0;width:100px;font-size:.85rem}.info-value[data-v-5a3bb8cd]{font-family:monospace;font-size:.95rem;font-weight:600}.btn-reset[data-v-5a3bb8cd]{color:#fff;cursor:pointer;background:#1a73e8;border:none;border-radius:6px;padding:.5rem 1.2rem;font-size:.88rem}.btn-reset[data-v-5a3bb8cd]:hover{background:#1558b0}.creds-box[data-v-5a3bb8cd]{background:#1a1a2e;border-radius:8px;margin-bottom:.5rem;padding:1rem 1.2rem}.cred-row[data-v-5a3bb8cd]{align-items:center;gap:1rem;margin-bottom:.4rem;display:flex}.cred-row[data-v-5a3bb8cd]:last-child{margin-bottom:0}.cred-row span[data-v-5a3bb8cd]{color:#aaa;width:36px;font-size:.8rem}.cred-row code[data-v-5a3bb8cd]{color:#7ee787;font-family:monospace;font-size:1rem}.danger-zone[data-v-5a3bb8cd]{border:1px solid #f5c2c2}.action-row[data-v-5a3bb8cd]{justify-content:space-between;align-items:center;gap:1rem;display:flex}.action-info[data-v-5a3bb8cd]{flex:1}.action-title[data-v-5a3bb8cd]{margin-bottom:.25rem;font-size:.95rem;font-weight:600}.action-desc[data-v-5a3bb8cd]{color:var(--text-4);font-size:.83rem;line-height:1.5}.btn-danger-outline[data-v-5a3bb8cd]{background:var(--bg-card);color:#c62828;cursor:pointer;white-space:nowrap;border:1.5px solid #e53935;border-radius:6px;flex-shrink:0;padding:.4rem 1rem;font-size:.88rem}.btn-danger-outline[data-v-5a3bb8cd]:hover{background:#ffebee}.btn-danger-outline[data-v-5a3bb8cd]:disabled{opacity:.4;cursor:default}.overlay[data-v-5a3bb8cd]{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal[data-v-5a3bb8cd]{background:var(--bg-card);color:var(--text-1);border-radius:12px;width:460px;max-width:95vw;max-height:90vh;padding:2rem;overflow-y:auto}.modal h3[data-v-5a3bb8cd]{margin:0 0 1rem}.modal-desc[data-v-5a3bb8cd]{color:var(--text-2);margin-bottom:1rem;font-size:.9rem}.modal-actions[data-v-5a3bb8cd]{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.modal-actions button[data-v-5a3bb8cd]{border:1px solid var(--border-3);cursor:pointer;background:var(--bg-card);color:var(--text-1);border-radius:4px;padding:.4rem .9rem;font-size:.88rem}.btn-danger[data-v-5a3bb8cd]{color:#fff;background:#c62828;border-color:#c62828}.btn-danger[data-v-5a3bb8cd]:disabled{opacity:.4;cursor:default}.warn-text[data-v-5a3bb8cd]{color:#c62828;margin:.3rem 0 0;font-size:.84rem}.success-text[data-v-5a3bb8cd]{color:#2e7d32!important}.preview-box[data-v-5a3bb8cd]{border:1px solid var(--border-2);border-radius:8px;margin-bottom:1rem;overflow:hidden}.preview-row[data-v-5a3bb8cd]{border-bottom:1px solid var(--border-2);justify-content:space-between;align-items:center;padding:.5rem .9rem;font-size:.88rem;display:flex}.preview-row[data-v-5a3bb8cd]:last-child{border-bottom:none}.preview-row.del[data-v-5a3bb8cd]{color:#c62828;background:#fff5f5}.preview-row.keep[data-v-5a3bb8cd]{color:#2e7d32;background:#f0faf4}[data-theme=dark] .preview-row.del[data-v-5a3bb8cd]{color:#f48a8a;background:#2a1010}[data-theme=dark] .preview-row.keep[data-v-5a3bb8cd]{color:#7ec89a;background:#0e2218}.confirm-input[data-v-5a3bb8cd]{background:var(--bg-input);width:100%;color:var(--text-1);box-sizing:border-box;border:1.5px solid #e53935;border-radius:6px;margin-bottom:.5rem;padding:.5rem .7rem;font-size:1rem}.confirm-input[data-v-5a3bb8cd]:focus{border-color:#c62828;outline:none}code[data-v-5a3bb8cd]{background:var(--border-2);color:#c62828;border-radius:4px;padding:.1rem .4rem;font-family:monospace;font-size:.95em}:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#app{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
