@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=Nunito+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;1,9..144,300;1,9..144,400&display=swap";:root{--teal: #22C55E;--teal-rgb: 34, 197, 94;--teal-d: #16A34A;--teal-l: #DCFCE7;--teal-xl: #F0FDF4;--blue: #4F46E5;--blue-l: #E0E7FF;--green: #16A34A;--green-l: #DCFCE7;--amber: #D97706;--amber-l: #FEF3C7;--purple: #7C3AED;--purple-l: #EDE9FE;--pink: #DB2777;--pink-l: #FCE7F3;--orange: #EA580C;--orange-l: #FFF7ED;--rose: #E11D48;--indigo: #4338CA;--cyan: #0891B2;--cyan-l: #CFFAFE;--bg: #F6F8FC;--surface: #FFFFFF;--surface2: #EEF2F7;--modal-bg: #FFFFFF;--modal-surface2:#EEF2F7;--text: #1E293B;--text-mid: #334155;--text-sub: #64748B;--text-muted: #94A3B8;--border: #E2E8F0;--border2: #CBD5E1;--wb-bg: #F6F8FC;--wb-dot: rgba(100, 116, 139, .22);--wb-canvas: #F6F8FC;--wb-grid: rgba(100, 116, 139, .2);--shadow-sm: 0 6px 18px rgba(15, 23, 42, .06);--shadow: 0 14px 34px rgba(15, 23, 42, .1);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .14);--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 9999px;--rail-w: 76px;--topbar-h: 60px;--toolbar-h: 56px;--drawer-w: 360px;--font: "Nunito", system-ui, sans-serif;--font-body: "Nunito Sans", system-ui, sans-serif;--brand-bg: #2d1b69;--brand-bg-deep: #1e1457;--brand-border: rgba(255, 255, 255, .18);--brand-text: rgba(255, 255, 255, .95);--brand-text-sub: rgba(255, 255, 255, .88);--brand-text-muted: rgba(255, 255, 255, .65);--brand-accent: #a78bfa;--brand-hover: rgba(255, 255, 255, .1);--brand-active: rgba(255, 255, 255, .18);--brand-active-text: #ffffff}[data-theme=dark]{--bg: #0F0F14;--surface: #18181F;--surface2: #20202A;--modal-bg: #18181F;--modal-surface2:#20202A;--text: #F4F4F5;--text-mid: #E4E4E7;--text-sub: #A1A1AA;--text-muted: #71717A;--border: #2A2A36;--border2: #3B3B49;--wb-bg: #12121A;--wb-dot: rgba(255, 255, 255, .08);--wb-canvas: #12121A;--wb-grid: rgba(255, 255, 255, .08);--shadow-sm: 0 6px 18px rgba(0, 0, 0, .3);--shadow: 0 14px 34px rgba(0, 0, 0, .4);--shadow-lg: 0 24px 60px rgba(0, 0, 0, .56);--teal: #22D3EE;--teal-rgb: 34, 211, 238;--teal-d: #67E8F9;--teal-l: #11313A;--teal-xl: #0B2027;--blue: #818CF8;--blue-l: #242B52;--green: #34D399;--green-l: #103125;--amber: #F59E0B;--amber-l: #3A290B;--purple: #A78BFA;--purple-l: #2A214C;--pink: #F472B6;--pink-l: #3C1730;--orange: #FB923C;--orange-l: #3A1F10;--rose: #FB7185;--indigo: #818CF8;--cyan: #22D3EE;--cyan-l: #12313A;--brand-bg: #171127;--brand-bg-deep: #0f0b1b;--brand-border: rgba(255, 255, 255, .14);--brand-text: rgba(255, 255, 255, .96);--brand-text-sub: rgba(255, 255, 255, .82);--brand-text-muted: rgba(255, 255, 255, .58);--brand-accent: #a78bfa;--brand-hover: rgba(255, 255, 255, .08);--brand-active: rgba(255, 255, 255, .15);--brand-active-text: #ffffff}[data-theme=high-contrast]{--bg: #FFFFFF;--surface: #FFFFFF;--surface2: #F5F5F5;--modal-bg: #FFFFFF;--modal-surface2:#F5F5F5;--text: #000000;--text-mid: #111111;--text-sub: #222222;--text-muted: #333333;--border: #000000;--border2: #222222;--wb-bg: #FFFFFF;--wb-dot: rgba(0, 0, 0, .18);--wb-canvas: #FFFFFF;--wb-grid: rgba(0, 0, 0, .18);--shadow-sm: 0 1px 0 rgba(0, 0, 0, .85);--shadow: 0 3px 0 rgba(0, 0, 0, .85);--shadow-lg: 0 6px 0 rgba(0, 0, 0, .85);--teal: #005FCC;--teal-rgb: 0, 95, 204;--teal-d: #0049A3;--teal-l: #DCEBFF;--teal-xl: #F3F8FF;--blue: #005FCC;--blue-l: #DCEBFF;--green: #0A7A33;--green-l: #E3F7EA;--amber: #9A6700;--amber-l: #FFF4D6;--purple: #5B21B6;--purple-l: #EDE9FE;--pink: #BE185D;--pink-l: #FCE7F3;--orange: #C2410C;--orange-l: #FFF1E8;--rose: #BE123C;--indigo: #3730A3;--cyan: #0E7490;--cyan-l: #E0F7FA;--brand-bg: #000000;--brand-bg-deep: #000000;--brand-border: rgba(255, 255, 255, .36);--brand-text: #ffffff;--brand-text-sub: rgba(255, 255, 255, .9);--brand-text-muted: rgba(255, 255, 255, .72);--brand-accent: #ffffff;--brand-hover: rgba(255, 255, 255, .1);--brand-active: rgba(255, 255, 255, .18);--brand-active-text: #ffffff}[data-theme=terracotta-light]{--bg: #FFF7F3;--surface: #FFFFFF;--surface2: #FFEDE5;--modal-bg: #FFFFFF;--modal-surface2:#FFEDE5;--text: #4A1D0D;--text-mid: #6C2E16;--text-sub: #9A5C4A;--text-muted: #B77963;--border: #FFD8CC;--border2: #F0B8A6;--wb-bg: #FFF7F3;--wb-dot: rgba(154, 92, 74, .15);--wb-canvas: #FFF7F3;--wb-grid: rgba(154, 92, 74, .14);--shadow-sm: 0 6px 18px rgba(118, 59, 37, .07);--shadow: 0 14px 34px rgba(118, 59, 37, .1);--shadow-lg: 0 24px 60px rgba(118, 59, 37, .14);--teal: #C2410C;--teal-rgb: 194, 65, 12;--teal-d: #9A3412;--teal-l: #FDDCCB;--teal-xl: #FFF0E8;--blue: #8B5CF6;--blue-l: #F1E8FF;--green: #16A34A;--green-l: #E8F7EC;--amber: #D97706;--amber-l: #FFF1DA;--purple: #A855F7;--purple-l: #F3E8FF;--pink: #DB2777;--pink-l: #FCE7F3;--orange: #EA580C;--orange-l: #FFF1E8;--rose: #E11D48;--indigo: #7C3AED;--cyan: #0F766E;--cyan-l: #D9F4F1;--brand-bg: #5a2816;--brand-bg-deep: #411b0e;--brand-border: rgba(255, 255, 255, .18);--brand-text: rgba(255, 255, 255, .95);--brand-text-sub: rgba(255, 255, 255, .86);--brand-text-muted: rgba(255, 255, 255, .64);--brand-accent: #fb923c;--brand-hover: rgba(255, 255, 255, .09);--brand-active: rgba(255, 255, 255, .16);--brand-active-text: #ffffff}[data-theme=terracotta-dark]{--bg: #1A0F0A;--surface: #24140E;--surface2: #2E1A13;--modal-bg: #24140E;--modal-surface2:#2E1A13;--text: #FFEDE5;--text-mid: #F1D2C3;--text-sub: #D6A48F;--text-muted: #AF7F6C;--border: #3A231B;--border2: #553328;--wb-bg: #1A0F0A;--wb-dot: rgba(255, 221, 204, .1);--wb-canvas: #1A0F0A;--wb-grid: rgba(255, 221, 204, .09);--shadow-sm: 0 6px 18px rgba(0, 0, 0, .28);--shadow: 0 14px 34px rgba(0, 0, 0, .4);--shadow-lg: 0 24px 60px rgba(0, 0, 0, .58);--teal: #FB923C;--teal-rgb: 251, 146, 60;--teal-d: #F97316;--teal-l: #4A291B;--teal-xl: #2B1810;--blue: #A78BFA;--blue-l: #2F2148;--green: #34D399;--green-l: #142D23;--amber: #FBBF24;--amber-l: #3B2A12;--purple: #C084FC;--purple-l: #3A2750;--pink: #F472B6;--pink-l: #411A2E;--orange: #FB923C;--orange-l: #442314;--rose: #FB7185;--indigo: #A78BFA;--cyan: #2DD4BF;--cyan-l: #143532;--brand-bg: #2a160f;--brand-bg-deep: #180c08;--brand-border: rgba(255, 255, 255, .14);--brand-text: rgba(255, 255, 255, .96);--brand-text-sub: rgba(255, 255, 255, .84);--brand-text-muted: rgba(255, 255, 255, .6);--brand-accent: #fb923c;--brand-hover: rgba(255, 255, 255, .08);--brand-active: rgba(255, 255, 255, .15);--brand-active-text: #ffffff}[data-theme=violet]{--bg: #F7F3FF;--surface: #FFFFFF;--surface2: #F3EEFF;--modal-bg: #FFFFFF;--modal-surface2:#F3EEFF;--text: #2D1F4F;--text-mid: #4A3977;--text-sub: #6D5A9F;--text-muted: #8B79C9;--border: #E5DCFF;--border2: #CDBDFF;--wb-bg: #FBFAFF;--wb-dot: rgba(109, 90, 159, .16);--wb-canvas: #FBFAFF;--wb-grid: rgba(109, 90, 159, .14);--shadow-sm: 0 6px 18px rgba(60, 20, 120, .08);--shadow: 0 14px 34px rgba(60, 20, 120, .12);--shadow-lg: 0 24px 60px rgba(60, 20, 120, .18);--teal: #7C3AED;--teal-rgb: 124, 58, 237;--teal-d: #6D28D9;--teal-l: #DDD6FE;--teal-xl: #F3EEFF;--blue: #4F46E5;--blue-l: #E0E7FF;--green: #059669;--green-l: #D1FAE5;--amber: #D97706;--amber-l: #FEF3C7;--purple: #7C3AED;--purple-l: #EDE9FE;--pink: #DB2777;--pink-l: #FCE7F3;--orange: #EA580C;--orange-l: #FFF7ED;--rose: #E11D48;--indigo: #4338CA;--cyan: #0891B2;--cyan-l: #ECFEFF;--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 9999px;--font: "Nunito", system-ui, sans-serif;--font-body: "Nunito Sans", system-ui, sans-serif;--brand-bg: #2d1b69;--brand-bg-deep: #1e1457;--brand-border: rgba(255, 255, 255, .18);--brand-text: rgba(255, 255, 255, .95);--brand-text-sub: rgba(255, 255, 255, .88);--brand-text-muted: rgba(255, 255, 255, .65);--brand-accent: #c084fc;--brand-hover: rgba(255, 255, 255, .1);--brand-active: rgba(255, 255, 255, .18);--brand-active-text: #ffffff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);height:100vh;width:100vw;overflow:hidden;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:var(--font);cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:var(--font-body);color:var(--text)}a{color:var(--blue);text-decoration:none}.surface,.icon-rail{transition:background-color .2s ease-in-out,color .2s ease-in-out,border-color .2s ease-in-out}:focus-visible{outline:2px solid var(--teal);outline-offset:2px}:focus:not(:focus-visible){outline:none}button:focus-visible,[role=button]:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.rail__icon:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-sm, 6px)}.bottom-tab:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-sm, 6px)}.library-filter-pill:focus-visible,.tracker-pill:focus-visible,.tracker-subject-tab:focus-visible,.tracker-assign-btn:focus-visible,.tracker-back-btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-pill)}.library-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius)}.student-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-lg, 20px)}.activity-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:12px}.tracker-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius)}.library-header__close:focus-visible,.fullscreen-panel__close:focus-visible,.mobile-banner__dismiss:focus-visible,.add-content-modal__close:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:50%}.assign-button:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:var(--radius-pill)}.embedded-game__close:focus-visible,.embedded-game__mode-btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-pill)}.webcam-bubble:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:50%}.webcam__peer-thumb:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius)}.demo-chip__btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-pill)}.pen-toolbar__btn:focus-visible,.pen-toolbar__color:focus-visible,.pen-toolbar__width-btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:var(--radius-sm, 6px)}.color-swatch:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:50%}.activity-shelf__handle:focus-visible{outline:2px solid var(--teal);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--teal);outline-offset:0;border-color:var(--teal);box-shadow:0 0 0 3px rgba(var(--teal-rgb),.15)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-delay:0ms!important;transition-duration:1ms!important;transition-delay:0ms!important}}@media(max-width:1023px){:root{--rail-w: 76px;--topbar-h: 60px;--toolbar-h: 56px;--drawer-w: 360px;--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 9999px;--font: "Nunito", system-ui, sans-serif;--font-body: "Nunito Sans", system-ui, sans-serif}}@media(max-width:767px){:root{--rail-w: 76px;--topbar-h: 60px;--toolbar-h: 56px;--drawer-w: 360px;--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 9999px;--font: "Nunito", system-ui, sans-serif;--font-body: "Nunito Sans", system-ui, sans-serif}}[data-theme=clean-white]{--bg: #F8FAFC;--surface: #FFFFFF;--surface2: #F1F5F9;--modal-bg: #FFFFFF;--modal-surface2: #F1F5F9;--text: #1E293B;--text-mid: #334155;--text-sub: #64748B;--text-muted: #94A3B8;--border: #E2E8F0;--border2: #CBD5E1;--wb-bg: #FFFFFF;--wb-dot: rgba(148, 163, 184, .3);--wb-canvas: #FFFFFF;--wb-grid: rgba(148, 163, 184, .28);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 4px 16px rgba(0, 0, 0, .08), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .12), 0 8px 20px rgba(0, 0, 0, .07);--teal: #0D9488;--teal-rgb: 13, 148, 136;--teal-d: #0F766E;--teal-l: #CCFBF1;--teal-xl: #F0FDFA;--blue: #2563EB;--blue-l: #DBEAFE;--green: #059669;--green-l: #D1FAE5;--amber: #D97706;--amber-l: #FEF3C7;--purple: #7C3AED;--purple-l: #EDE9FE;--pink: #DB2777;--pink-l: #FCE7F3;--orange: #EA580C;--orange-l: #FFF7ED;--rose: #E11D48;--indigo: #4338CA;--cyan: #0891B2;--cyan-l: #ECFEFF;--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 9999px;--font: "Nunito", system-ui, sans-serif;--font-body: "Nunito Sans", system-ui, sans-serif;--brand-bg: #FFFFFF;--brand-bg-deep: #F8FAFC;--brand-border: #E2E8F0;--brand-text: #1E293B;--brand-text-sub: #475569;--brand-text-muted: #94A3B8;--brand-accent: #0EA5E9;--brand-hover: rgba(14, 165, 233, .08);--brand-active: #E0F2FE;--brand-active-text: #0369A1}[data-theme=clean-white] .brp__header-icon,[data-theme=clean-white] .snapshot-gallery__header-icon,[data-theme=clean-white] .settings-panel__header-icon,[data-theme=clean-white] .layer-panel__header-icon,[data-theme=clean-white] .ann-panel__header-icon,[data-theme=clean-white] .brp__close-btn:hover,[data-theme=clean-white] .snapshot-gallery__close-btn:hover,[data-theme=clean-white] .settings-panel__close-btn:hover,[data-theme=clean-white] .layer-panel__close:hover,[data-theme=clean-white] .ann-panel__close-btn:hover{background:#0ea5e91a;color:#0284c7}[data-theme=clean-white] .brp__create-btn{background:#0ea5e9;color:#fff}[data-theme=clean-white] .brp__create-btn:hover{background:#0284c7}[data-theme=clean-white] .ann-panel__place-btn{border-color:#0ea5e973;color:#0369a1}[data-theme=clean-white] .ann-panel__place-btn:hover,[data-theme=clean-white] .ann-panel__place-btn--active{background:#0ea5e91a;border-color:#0ea5e9;color:#0369a1}[data-theme=clean-white] .layer-panel__group-btn,[data-theme=clean-white] .layer-panel__merge-btn{border-color:#0ea5e959;background:#0ea5e912;color:#0369a1}[data-theme=clean-white] .layer-panel__group-btn:hover,[data-theme=clean-white] .layer-panel__merge-btn:hover{background:#0ea5e924}[data-theme=clean-white] .layer-panel__add{color:#64748b}[data-theme=clean-white] .layer-panel__add:hover{background:#0ea5e91a;color:#0284c7}[data-theme=clean-white] .pen-toolbar,[data-theme=clean-white] .pen-toolbar--pill{border:1px solid var(--border2, #CBD5E1)!important;box-shadow:0 2px 12px #00000017,0 1px 4px #0000000f}[data-theme=clean-white] .pen-toolbar__divider{background:var(--border2, #CBD5E1)}[data-theme=clean-white] .pen-toolbar__tool-btn.is-active,[data-theme=clean-white] .pen-toolbar__btn.is-active{background:#0ea5e91f;color:#0284c7;border-color:#0ea5e959}[data-theme=clean-white] .zoom-controls{box-shadow:0 2px 10px #0000001a,0 1px 3px #0000000f}[data-theme=clean-white] .topbar{box-shadow:0 1px 0 var(--border2, #CBD5E1)}[data-theme=clean-white] .icon-rail{box-shadow:1px 0 0 var(--border2, #CBD5E1)}[data-theme=clean-white] .pen-toolbar:not(.pen-toolbar--pill){border-top:1px solid var(--border2, #CBD5E1)!important;box-shadow:none}.skip-to-main{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-to-main:focus{position:fixed;top:8px;left:8px;width:auto;height:auto;overflow:visible;padding:8px 16px;background:var(--brand-bg);color:#fff;border-radius:var(--radius-sm);z-index:9999;font-size:14px;font-weight:700}[data-theme=pure-black]{--bg:#050505;--surface:#0B0B0B;--surface2:#121212;--modal-bg:#0B0B0B;--modal-surface2:#121212;--text:#F8FAFC;--text-mid:#E2E8F0;--text-sub:#CBD5E1;--text-muted:#94A3B8;--border:#1F2937;--border2:#334155;--wb-bg:#050505;--wb-dot:rgba(255,255,255,.1);--wb-canvas:#050505;--wb-grid:rgba(255,255,255,.09);--shadow-sm:0 6px 18px rgba(0,0,0,.38);--shadow:0 14px 34px rgba(0,0,0,.5);--shadow-lg:0 24px 60px rgba(0,0,0,.7);--teal:#22D3EE;--teal-rgb:34, 211, 238;--teal-d:#67E8F9;--teal-l:#12313A;--teal-xl:#091A1F;--blue:#60A5FA;--blue-l:#172554;--green:#34D399;--green-l:#052E2B;--amber:#F59E0B;--amber-l:#3B2A12;--purple:#C084FC;--purple-l:#2B153C;--pink:#F472B6;--pink-l:#3C1730;--orange:#FB923C;--orange-l:#3A1F10;--rose:#FB7185;--indigo:#818CF8;--cyan:#22D3EE;--cyan-l:#12313A;--brand-bg:#000000;--brand-bg-deep:#050505;--brand-border:rgba(255,255,255,.16);--brand-text:rgba(255,255,255,.97);--brand-text-sub:rgba(255,255,255,.86);--brand-text-muted:rgba(255,255,255,.62);--brand-accent:#c084fc;--brand-hover:rgba(255,255,255,.08);--brand-active:rgba(255,255,255,.16);--brand-active-text:#ffffff}:root{--polish-radius-xs: 10px;--polish-radius-sm: 14px;--polish-radius-md: 18px;--polish-radius-lg: 22px;--polish-shadow-xs: 0 4px 14px rgba(15, 23, 42, .04);--polish-shadow-sm: 0 10px 24px rgba(15, 23, 42, .07);--polish-shadow-md: 0 16px 40px rgba(15, 23, 42, .1);--polish-shadow-lg: 0 24px 60px rgba(15, 23, 42, .16);--polish-card-bg: color-mix(in srgb, var(--surface) 96%, white);--polish-card-bg-soft: color-mix(in srgb, var(--surface2) 72%, white);--polish-border: color-mix(in srgb, var(--border) 88%, white);--polish-border-strong: color-mix(in srgb, var(--border2, var(--border)) 92%, white);--polish-accent-gradient: linear-gradient(135deg, var(--purple, #7C3AED) 0%, var(--teal, #14B8A6) 100%);--polish-brand-gradient: linear-gradient(135deg, var(--brand-bg, #2d1b69) 0%, var(--brand-bg-deep, #1e1457) 100%);--polish-transition: .18s cubic-bezier(.2,.8,.2,1)}.polish-surface{background:var(--polish-card-bg);border:1px solid var(--polish-border);border-radius:var(--polish-radius-md);box-shadow:var(--polish-shadow-sm)}.polish-surface-soft{background:var(--polish-card-bg-soft);border:1px solid var(--polish-border);border-radius:var(--polish-radius-sm)}.polish-topbar{background:var(--polish-brand-gradient);border-bottom:1px solid var(--brand-border, rgba(255,255,255,.12));box-shadow:var(--polish-shadow-md)}.polish-header-title{font-family:var(--font, inherit);font-size:20px;font-weight:900;line-height:1.1;color:var(--brand-text, #fff);letter-spacing:-.02em}.polish-header-sub{margin-top:4px;font-size:12px;color:var(--brand-text-sub, rgba(255,255,255,.78))}.polish-btn,.polish-btn-soft,.polish-btn-ghost,.polish-btn-danger{min-height:38px;padding:0 14px;border-radius:12px;font-size:12px;font-weight:800;font-family:inherit;cursor:pointer;transition:transform var(--polish-transition),box-shadow var(--polish-transition),background var(--polish-transition),border-color var(--polish-transition),opacity var(--polish-transition)}.polish-btn:hover,.polish-btn-soft:hover,.polish-btn-ghost:hover,.polish-btn-danger:hover{transform:translateY(-1px)}.polish-btn{border:none;color:#fff;background:var(--polish-accent-gradient);box-shadow:0 10px 24px #7c3aed2e}.polish-btn-soft{border:1px solid var(--polish-border);background:var(--polish-card-bg);color:var(--text);box-shadow:var(--polish-shadow-xs)}.polish-btn-ghost{border:1px solid rgba(255,255,255,.16);background:#ffffff14;color:var(--brand-text, #fff)}.polish-btn-danger{border:1px solid #fecaca;background:#fef2f2;color:#b91c1c}.polish-tabbar{display:flex;gap:8px;align-items:flex-end;padding:14px 16px 0;background:var(--surface);border-bottom:1px solid var(--polish-border)}.polish-tab{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:14px 14px 0 0;border:1px solid transparent;border-bottom:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:800;font-family:inherit;cursor:pointer;transition:all var(--polish-transition)}.polish-tab.is-active{background:var(--bg);color:var(--purple);border-color:var(--polish-border);margin-bottom:-1px}.polish-card{background:var(--polish-card-bg);border:1px solid var(--polish-border);border-radius:var(--polish-radius-md);box-shadow:var(--polish-shadow-sm);overflow:hidden}.polish-card__hdr{padding:14px 16px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--polish-border)}.polish-card__title{font-family:var(--font, inherit);font-size:14px;font-weight:900;color:var(--text)}.polish-card__sub{margin-top:4px;font-size:11px;color:var(--text-muted)}.polish-stat{background:var(--polish-card-bg);border:1px solid var(--polish-border);border-radius:18px;box-shadow:var(--polish-shadow-sm);padding:16px}.polish-stat__value{margin-top:6px;font-family:var(--font, inherit);font-size:28px;font-weight:900;line-height:1}.polish-stat__label{margin-top:8px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--text)}.polish-stat__sub{margin-top:4px;font-size:11px;color:var(--text-muted)}.polish-input,.polish-select,.polish-textarea{width:100%;min-height:42px;padding:10px 12px;border-radius:12px;border:1px solid var(--polish-border-strong);background:var(--polish-card-bg);color:var(--text);font-size:13px;font-family:inherit;transition:border-color var(--polish-transition),box-shadow var(--polish-transition),background var(--polish-transition)}.polish-input:focus,.polish-select:focus,.polish-textarea:focus{outline:none;border-color:color-mix(in srgb,var(--purple) 55%,white);box-shadow:0 0 0 4px color-mix(in srgb,var(--purple) 12%,transparent)}.polish-label{display:block;margin-bottom:6px;font-size:12px;font-weight:800;color:var(--text)}.polish-hint{margin-top:6px;font-size:11px;color:var(--text-muted);line-height:1.45}.polish-panel-shell{background:var(--polish-card-bg);border-left:1px solid var(--polish-border);box-shadow:-12px 0 40px #0f172a24}.polish-panel-header{background:linear-gradient(180deg,color-mix(in srgb,var(--surface2) 74%,white) 0%,var(--surface) 100%);border-bottom:1px solid var(--polish-border)}.polish-section{background:var(--polish-card-bg);border:1px solid var(--polish-border);border-radius:18px;box-shadow:var(--polish-shadow-xs)}.polish-table th{background:var(--polish-card-bg-soft);color:var(--text-muted);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--polish-border)}.polish-table tr:hover td{background:color-mix(in srgb,var(--surface2) 56%,white)}.polish-chip{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 10px;border-radius:999px;border:1px solid var(--polish-border);background:var(--polish-card-bg);color:var(--text-sub, var(--text));font-size:11px;font-weight:800}.polish-muted{color:var(--text-muted)}.polish-tight-title{letter-spacing:-.02em}.polish-hover-lift{transition:transform var(--polish-transition),box-shadow var(--polish-transition)}.polish-hover-lift:hover{transform:translateY(-2px);box-shadow:var(--polish-shadow-md)}@media(max-width:760px){.polish-topbar{padding-top:14px;padding-bottom:14px}.polish-header-title{font-size:18px}.polish-tabbar{overflow-x:auto}}.error-boundary-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 24px;width:100%;text-align:center;color:var(--text-muted, #94A3B8);font-family:var(--font-ui, Arial, sans-serif)}.error-boundary-fallback p{margin:0;font-size:14px;line-height:1.5}.error-boundary-fallback strong{color:var(--text-base, #1B2631)}.error-boundary-fallback button{margin-top:4px;padding:6px 16px;border:1px solid var(--teal, #0D9488);border-radius:6px;background:transparent;color:var(--teal, #0D9488);font-size:13px;cursor:pointer;transition:background .15s,color .15s}.error-boundary-fallback button:hover{background:var(--teal, #0D9488);color:#fff}.ara-panel{display:flex;flex-direction:column;gap:18px}.ara-hero{display:flex;align-items:flex-start;gap:14px;padding:22px 24px;border:1px solid #e5e7eb;border-radius:18px;background:linear-gradient(135deg,#f8f5ff,#fff 62%,#f0fdfa);box-shadow:0 10px 28px #4f46e514}.ara-hero-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#4c1d95;color:#fff;font-size:22px;flex-shrink:0;box-shadow:0 10px 24px #4c1d9540}.ara-hero h2{margin:0;color:#1e293b;font-size:20px;line-height:1.2;font-weight:850}.ara-hero p{margin:6px 0 0;color:#64748b;font-size:13px;line-height:1.55;max-width:760px}.ara-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.ara-summary-card{padding:16px 18px;border-radius:14px;border:1px solid #e2e8f0;background:#fff;display:flex;flex-direction:column;gap:2px}.ara-summary-card--enabled{background:#f0fdf4;border-color:#bbf7d0}.ara-summary-card--selected{background:#f5f3ff;border-color:#ddd6fe}.ara-summary-number{font-size:26px;font-weight:900;color:#2d1b69;line-height:1}.ara-summary-label{color:#64748b;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.ara-toolbar,.ara-actions,.ara-pagination{display:flex;align-items:center;gap:10px}.ara-toolbar{padding:14px;border:1px solid #e2e8f0;border-radius:14px;background:#fff}.ara-search,.ara-select{height:42px;border:1px solid #cbd5e1;border-radius:10px;background:#fff;color:#1e293b;font-size:14px;outline:none}.ara-search{flex:1;min-width:180px;padding:0 14px}.ara-select{width:190px;padding:0 12px}.ara-actions{flex-wrap:wrap}.ara-actions-spacer{flex:1;min-width:10px}.ara-btn{min-height:36px;padding:0 14px;border-radius:9px;border:1px solid transparent;background:#fff;color:#334155;font-size:13px;font-weight:750;cursor:pointer;transition:transform .12s ease,opacity .12s ease,background .12s ease,border-color .12s ease}.ara-btn:hover:not(:disabled){transform:translateY(-1px)}.ara-btn:disabled{opacity:.48;cursor:not-allowed}.ara-btn--soft{border-color:#e2e8f0;background:#f8fafc}.ara-btn--enable{background:#16a34a;color:#fff}.ara-btn--danger{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.ara-btn--outline{color:#4c1d95;border-color:#c4b5fd;background:#f5f3ff}.ara-btn--outline-danger{color:#dc2626;border-color:#fecaca;background:#fff}.ara-message{padding:11px 14px;border-radius:12px;font-size:13px;font-weight:650}.ara-message--error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.ara-message--success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.ara-table-wrap{border:1px solid #e2e8f0;border-radius:16px;background:#fff;overflow:hidden}.ara-table{width:100%;border-collapse:collapse}.ara-table th{background:#f8fafc;color:#64748b;font-size:11px;font-weight:850;text-align:left;padding:12px 14px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #e2e8f0}.ara-table td{padding:13px 14px;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:#1e293b;font-size:13px}.ara-table tr:last-child td{border-bottom:none}.ara-th-check,.ara-cell-check{width:42px}.ara-th-action,.ara-action-cell{width:92px;text-align:right}.ara-user-cell{display:flex;align-items:center;gap:11px;min-width:220px}.ara-user-initial{width:38px;height:38px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;background:#ede9fe;color:#4c1d95;font-weight:900;flex-shrink:0}.ara-user-text{display:flex;flex-direction:column;gap:2px;min-width:0}.ara-user-text strong,.ara-user-text span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ara-user-text span{color:#64748b;font-size:12px}.ara-role-pill,.ara-status-pill,.ara-access-pill{display:inline-flex;align-items:center;min-height:24px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:800;white-space:nowrap}.ara-role-pill{background:#eff6ff;color:#1d4ed8}.ara-status-pill{background:#f8fafc;color:#475569;border:1px solid #e2e8f0}.ara-access-pill--on{background:#dcfce7;color:#15803d}.ara-access-pill--off{background:#f1f5f9;color:#64748b}.ara-toggle-btn{position:relative;width:46px;height:26px;border-radius:999px;border:none;background:#cbd5e1;cursor:pointer;transition:background .16s ease}.ara-toggle-btn span{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0f172a47;transition:transform .16s ease}.ara-toggle-btn--on{background:#16a34a}.ara-toggle-btn--on span{transform:translate(20px)}.ara-empty{padding:34px!important;text-align:center;color:#94a3b8!important;font-weight:700}.ara-pagination{justify-content:flex-end;color:#64748b;font-size:13px;font-weight:700}@media(max-width:900px){.ara-summary-grid{grid-template-columns:1fr}.ara-toolbar,.ara-actions,.ara-pagination{align-items:stretch;flex-direction:column}.ara-search,.ara-select,.ara-btn{width:100%}.ara-table-wrap{overflow-x:auto}}.ara-panel{display:flex;flex-direction:column;gap:18px;padding:24px;min-height:100%}.ara-hero{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:18px;align-items:stretch;border-radius:24px;padding:24px;background:linear-gradient(135deg,#2d1060,#4c1d95 52%,#0f766e);color:#fff;box-shadow:0 18px 48px #2d106038}.ara-eyebrow{margin:0 0 6px;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;opacity:.72}.ara-hero h1{margin:0;font-size:30px;line-height:1.1;letter-spacing:-.04em}.ara-hero p{margin:10px 0 0;max-width:720px;color:#ffffffc7;line-height:1.6}.ara-hero-card{border-radius:18px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;padding:18px;display:flex;flex-direction:column;justify-content:center;gap:6px}.ara-hero-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:#ffffff29;font-size:22px}.ara-hero-card strong{font-size:16px}.ara-hero-card span:last-child{color:#ffffffad;font-size:13px;line-height:1.45}.ara-toolbar,.ara-actions,.ara-pagination{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.ara-search,.ara-select{height:42px;border-radius:12px;border:1px solid #dbe3ef;background:#fff;color:#1e293b;padding:0 14px;font:inherit;outline:none}.ara-search{flex:1;min-width:260px}.ara-select{min-width:170px}.ara-search:focus,.ara-select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.ara-btn{min-height:38px;padding:0 14px;border-radius:11px;border:1px solid #dbe3ef;background:#fff;color:#334155;font-size:13px;font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.ara-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #0f172a14}.ara-btn:disabled{opacity:.45;cursor:not-allowed}.ara-btn--positive{background:#0d9488;border-color:#0d9488;color:#fff}.ara-btn--danger{background:#ef4444;border-color:#ef4444;color:#fff}.ara-btn--positive-soft{background:#ecfdf5;border-color:#99f6e4;color:#0f766e}.ara-btn--danger-soft{background:#fff1f2;border-color:#fecdd3;color:#e11d48}.ara-count{font-weight:900;color:#6d28d9;margin-right:auto}.ara-alert{border-radius:14px;padding:12px 14px;font-weight:700;font-size:13px}.ara-alert--ok{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}.ara-alert--error{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}.ara-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:12px}.ara-user{display:grid;grid-template-columns:28px 44px minmax(0,1fr) auto;gap:12px;align-items:center;min-height:92px;border-radius:18px;background:#fff;border:1px solid #e2e8f0;padding:14px;box-shadow:0 8px 22px #0f172a0a}.ara-check input{display:none}.ara-check span{width:22px;height:22px;display:block;border-radius:7px;border:2px solid #cbd5e1;background:#fff}.ara-check input:checked+span{background:#7c3aed;border-color:#7c3aed;box-shadow:inset 0 0 0 4px #fff}.ara-avatar{width:44px;height:44px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,#ede9fe,#ccfbf1);color:#4c1d95;font-weight:900}.ara-user-main{display:flex;flex-direction:column;gap:3px;min-width:0}.ara-user-main strong{color:#0f172a;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ara-user-main span{color:#64748b;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ara-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:4px}.ara-tags em{font-style:normal;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#6d28d9;background:#f3e8ff;border-radius:999px;padding:2px 7px}.ara-user-access{display:flex;align-items:center;gap:10px}.ara-status{font-size:12px;font-weight:900;white-space:nowrap}.ara-status.is-on{color:#0f766e}.ara-status.is-off{color:#94a3b8}.ara-toggle{width:48px;height:28px;border:none;border-radius:999px;padding:3px;background:#cbd5e1;cursor:pointer;transition:background .14s ease}.ara-toggle span{width:22px;height:22px;display:block;border-radius:50%;background:#fff;box-shadow:0 2px 7px #0000002e;transition:transform .14s ease}.ara-toggle.is-on{background:#0d9488}.ara-toggle.is-on span{transform:translate(20px)}.ara-empty{grid-column:1 / -1;border-radius:18px;border:1px dashed #cbd5e1;background:#fff;padding:42px;text-align:center;color:#64748b;font-weight:700}.ara-pagination{justify-content:center;color:#64748b;font-weight:700}@media(max-width:760px){.ara-panel{padding:16px}.ara-hero{grid-template-columns:1fr}.ara-user{grid-template-columns:28px 42px minmax(0,1fr)}.ara-user-access{grid-column:2 / -1;justify-content:space-between}}.htt-page{min-height:100%;background:linear-gradient(180deg,#f8f8ff,#f5f7fb)}.htt-main{position:relative;display:grid;grid-template-columns:320px minmax(0,1fr) 360px;gap:20px;align-items:start;transition:grid-template-columns .22s ease,gap .22s ease}.htt-panel{background:#fff;border:1px solid #e5e8f2;border-radius:24px;box-shadow:0 18px 40px #10182814;overflow:hidden}.htt-side,.htt-right{position:sticky;top:14px;padding:16px;display:grid;gap:16px}.htt-card{border:1px solid #e5e8f2;border-radius:18px;background:#fafbff;padding:14px;display:grid;gap:10px}.htt-card h3{margin:0;font-size:15px;line-height:1.2;letter-spacing:-.02em;color:#182234}.htt-sub,.htt-tiny{color:#667085;font-size:12px;line-height:1.45}.htt-field{display:grid;gap:6px}.htt-field span{color:#667085;font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.htt-field select,.htt-field input,.htt-field textarea{width:100%;min-height:42px;border-radius:14px;border:1px solid #e5e8f2;padding:0 12px;font:inherit;font-size:13px;color:#182234;background:#fff;outline:none}.htt-field textarea{min-height:84px;padding:10px 12px;resize:vertical}.htt-btn-row{display:flex;gap:8px;flex-wrap:wrap}.htt-btn{min-height:38px;padding:0 12px;border-radius:12px;border:1px solid #e5e8f2;background:#fff;color:#182234;font:inherit;font-size:12px;font-weight:850;cursor:pointer}.htt-btn.is-primary{background:#6b46f2;color:#fff;border-color:#6b46f2}.htt-btn.is-teal{background:#1aa39a;color:#fff;border-color:#1aa39a}.htt-btn.is-soft{background:#f1edff;color:#6b46f2;border-color:#dfd4ff}.htt-btn.is-warn{background:#fff3df;color:#c77f11;border-color:#eed7aa}.htt-btn.is-danger{background:#fff1f1;color:#b53e3e;border-color:#f2caca}.htt-ideas{display:grid;gap:10px}.htt-idea{padding:12px;border-radius:16px;border:1px solid #e5e8f2;background:#fff;cursor:pointer;display:grid;gap:6px}.htt-idea.is-active{border-color:#cab9ff;background:#f1edff}.htt-idea strong{font-size:13px;line-height:1.3}.htt-idea small{font-size:12px;line-height:1.4;color:#667085}.htt-workspace{padding:18px;display:grid;gap:16px}.htt-workspace-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}.htt-workspace-head h2{margin:0;font-size:28px;line-height:1.05;letter-spacing:-.04em;color:#182234}.htt-workspace-head p{margin:8px 0 0;color:#667085;font-size:14px;line-height:1.5;max-width:760px}.htt-pill-row{display:flex;gap:8px;flex-wrap:wrap}.htt-pill{display:inline-flex;min-height:30px;align-items:center;padding:0 10px;border-radius:999px;background:#fff;border:1px solid #e5e8f2;color:#667085;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.htt-pill.is-purple{background:#f1edff;color:#6b46f2;border-color:#dcd0ff}.htt-pill.is-teal{background:#eafaf8;color:#1aa39a;border-color:#ccefeb}.htt-pill.is-blue{background:#eaf3ff;color:#2d78ea;border-color:#d0e3ff}.htt-manage-bar{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap;padding:12px 14px;border:1px solid #e5e8f2;border-radius:18px;background:linear-gradient(180deg,#fff,#fbfbff)}.htt-manage-left,.htt-manage-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.htt-manage-count{display:inline-flex;align-items:center;min-height:32px;padding:0 10px;border-radius:999px;background:#f1edff;color:#6b46f2;font-size:12px;font-weight:900}.htt-manage-note{color:#667085;font-size:12px}.htt-week-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.htt-day{background:#fcfdff;border:1px solid #e5e8f2;border-radius:20px;overflow:hidden;min-height:470px;display:flex;flex-direction:column}.htt-day-head{padding:12px 12px 10px;border-bottom:1px solid #e5e8f2;background:linear-gradient(180deg,#fff,#fafbff)}.htt-day-head strong{display:block;font-size:14px;letter-spacing:-.02em}.htt-day-head small{color:#667085;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.htt-slots{padding:12px;display:grid;gap:10px}.htt-slot{position:relative;border-radius:16px;border:1px solid #e5e8f2;background:#fff;padding:10px;display:grid;grid-template-rows:auto auto 1fr auto;gap:8px;min-height:108px;cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.htt-slot:hover,.htt-slot.is-selected{transform:translateY(-1px);border-color:#cbbdff;box-shadow:0 10px 20px #6b46f214}.htt-slot.is-batch-selected{border-color:#7f63f7;background:#f1edff;box-shadow:0 12px 22px #6b46f21f}.htt-slot.is-empty{border-style:dashed;background:#fbfbff;color:#667085;justify-content:center;align-content:center;text-align:center;min-height:96px}.htt-slot-top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}.htt-time{display:inline-flex;padding:4px 7px;border-radius:999px;background:#f1edff;color:#6b46f2;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.htt-subject-tag{display:inline-flex;padding:4px 7px;border-radius:999px;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.htt-subject-tag.is-maths{background:#f1edff;color:#6b46f2}.htt-subject-tag.is-reading{background:#eaf3ff;color:#2d78ea}.htt-subject-tag.is-writing{background:#eef3ff;color:#345ac6}.htt-subject-tag.is-worksheet{background:#eafaf8;color:#1aa39a}.htt-subject-tag.is-life{background:#fff3df;color:#c77f11}.htt-subject-tag.is-project{background:#fdeef6;color:#b6407f}.htt-slot strong{font-size:13px;line-height:1.3}.htt-slot p{margin:0;color:#667085;font-size:12px;line-height:1.4}.htt-slot-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}.htt-mini-btn{min-height:28px;padding:0 9px;border-radius:10px;border:1px solid #e5e8f2;background:#fff;color:#182234;font:inherit;font-size:11px;font-weight:800;cursor:pointer}.htt-mini-btn.is-soft{background:#f1edff;color:#6b46f2;border-color:#dfd4ff}.htt-mini-btn.is-teal{background:#eafaf8;color:#1aa39a;border-color:#ccefeb}.htt-mini-btn.is-warn{background:#fff3df;color:#c77f11;border-color:#f2ddb0}.htt-select-mark{position:absolute;bottom:10px;right:10px;width:24px;height:24px;border-radius:999px;border:2px solid #c8bdf5;background:#fff;display:none;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:#fff;box-shadow:0 2px 8px #0000000d}.htt-main.is-manage-mode .htt-slot:not(.is-empty) .htt-select-mark{display:inline-flex}.htt-slot.is-batch-selected .htt-select-mark{background:#6b46f2;border-color:#6b46f2}.htt-slot.is-batch-selected .htt-select-mark:before{content:"✓"}.htt-suggestions{display:grid;gap:10px}.htt-suggestion{border:1px solid #e5e8f2;border-radius:16px;background:#fff;padding:12px;display:grid;gap:7px;cursor:pointer}.htt-suggestion.is-active{border-color:#cab9ff;box-shadow:0 8px 18px #6b46f214}.htt-suggestion strong{font-size:13px;line-height:1.3}.htt-suggestion p{margin:0;font-size:12px;line-height:1.4;color:#667085}.htt-suggestion-meta{display:flex;gap:6px;flex-wrap:wrap}.htt-empty-note{padding:16px;border:1px dashed #e5e8f2;border-radius:18px;color:#667085;font-size:13px;line-height:1.5;background:#fff}@media(max-width:1200px){.htt-main{grid-template-columns:1fr}.htt-side,.htt-right{position:static}}@media(max-width:900px){.htt-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.htt-week-grid{grid-template-columns:1fr}}.htt-page.is-left-closed .htt-main{grid-template-columns:0 minmax(0,1fr) 360px;column-gap:0}.htt-page.is-right-closed .htt-main{grid-template-columns:320px minmax(0,1fr) 0;column-gap:0}.htt-page.is-left-closed.is-right-closed .htt-main{grid-template-columns:0 minmax(0,1fr) 0}.htt-side-handle{position:absolute;top:272px;width:24px;height:84px;border-radius:999px;font:inherit;font-size:18px;font-weight:950;cursor:pointer;z-index:24;display:inline-flex;align-items:center;justify-content:center;transform:none;transition:left .22s ease,right .22s ease,background .16s ease,box-shadow .16s ease}.htt-side-handle--left{left:-12px;border:1px solid color-mix(in srgb,#6b46f2 22%,#e5e8f2);background:linear-gradient(180deg,#fff,#f3efff);color:#6b46f2;box-shadow:0 10px 24px #6b46f229}.htt-side-handle--left.is-open{left:330px}.htt-side-handle--right{right:-12px;border:1px solid color-mix(in srgb,#1aa39a 22%,#e5e8f2);background:linear-gradient(180deg,#fff,#eefcf9);color:#1aa39a;box-shadow:0 10px 24px #1aa39a29}.htt-side-handle--right.is-open{right:370px}.htt-side,.htt-right{min-width:0;transition:opacity .18s ease}.htt-side:not(.is-open),.htt-right:not(.is-open){opacity:0;pointer-events:none;overflow:hidden}@media(max-width:1200px){.htt-side-handle{display:none}.htt-page.is-left-closed .htt-main,.htt-page.is-right-closed .htt-main,.htt-page.is-left-closed.is-right-closed .htt-main,.htt-main{grid-template-columns:1fr;gap:20px}.htt-side:not(.is-open),.htt-right:not(.is-open){display:none}}.htt-mode-toggle{display:inline-flex;align-items:center;gap:5px;padding:5px;border-radius:999px;border:1px solid #e5e8f2;background:#f8f8ff}.htt-mode-toggle button{min-height:36px;padding:0 12px;border-radius:999px;border:1px solid transparent;background:transparent;color:#667085;font:inherit;font-size:13px;font-weight:850;cursor:pointer}.htt-mode-toggle button.is-active{background:#fff;color:#2c166f;border-color:#fff;box-shadow:0 8px 18px #1f23301a}.htt-simple-page{--htt-simple-bg: #f5f4fb;--htt-simple-ink: #202333;--htt-simple-muted: #697184;--htt-simple-line: #e4e7f2;--htt-simple-purple: #5b39d6;--htt-simple-purple-dark: #2c166f;--htt-simple-purple-soft: #f1edff;--htt-simple-purple-panel: #f5f1ff;--htt-simple-teal: #159c94;--htt-simple-teal-panel: #eefcf9;--htt-simple-gold-soft: #fff6e7;--htt-simple-shadow: 0 18px 44px rgba(31, 35, 48, .08);--htt-simple-shadow-purple: 0 16px 30px rgba(91, 57, 214, .14);padding:20px;display:grid;gap:18px;background:linear-gradient(180deg,#fbfbff 0%,var(--htt-simple-bg) 100%)}.htt-simple-hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.58fr);gap:18px;align-items:stretch}.htt-simple-hero__copy,.htt-simple-hero__side,.htt-simple-coach-card,.htt-simple-panel{box-shadow:var(--htt-simple-shadow)}.htt-simple-hero__copy{border-radius:30px;padding:34px;color:#fff;background:radial-gradient(circle at 92% 0%,rgba(255,255,255,.18),transparent 260px),linear-gradient(135deg,var(--htt-simple-purple-dark) 0%,#4d2ca5 58%,#1f746d 100%)}.htt-simple-kicker,.htt-simple-eyebrow{display:inline-flex;min-height:28px;align-items:center;padding:0 11px;border-radius:999px;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.htt-simple-kicker{color:#ffffffeb;background:#ffffff24;border:1px solid rgba(255,255,255,.22)}.htt-simple-eyebrow{color:var(--htt-simple-purple);background:#ffffffb8;border:1px solid rgba(91,57,214,.16)}.htt-simple-panel--week .htt-simple-eyebrow{background:var(--htt-simple-purple-soft)}.htt-simple-panel--action .htt-simple-eyebrow{color:var(--htt-simple-teal);background:#ffffffb8;border-color:#159c9433}.htt-simple-hero h2{margin:16px 0 10px;font-size:clamp(34px,4.6vw,60px);line-height:1.02;letter-spacing:-.055em}.htt-simple-hero p{max-width:890px;margin:0;color:#ffffffdb;font-size:16px;line-height:1.62}.htt-simple-hero__side{border-radius:30px;padding:22px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--htt-simple-line);display:grid;gap:16px;align-content:start}.htt-simple-mode-row{display:flex;justify-content:space-between;gap:14px;align-items:center}.htt-simple-mode-row>span{color:var(--htt-simple-muted);font-size:13px;font-weight:850}.htt-simple-hero-note,.htt-simple-help-box,.htt-simple-planner-note{border-radius:18px;padding:15px;background:var(--htt-simple-gold-soft);border:1px solid #f0ddb8}.htt-simple-hero-note strong,.htt-simple-help-box strong,.htt-simple-detail-box strong,.htt-simple-planner-note strong,.htt-simple-guidance-box strong{color:var(--htt-simple-ink)}.htt-simple-hero-note p,.htt-simple-help-box p,.htt-simple-planner-note p,.htt-simple-guidance-box p{margin:6px 0 0;color:var(--htt-simple-muted);line-height:1.5}.htt-simple-coach-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.htt-simple-coach-card{border-radius:22px;padding:16px;background:#fff;border:1px solid var(--htt-simple-line);display:flex;gap:12px;align-items:flex-start}.htt-simple-coach-card b{width:36px;height:36px;border-radius:999px;flex:0 0 36px;display:grid;place-items:center;background:var(--htt-simple-purple-soft);color:var(--htt-simple-purple);font-weight:950}.htt-simple-coach-card strong{display:block;color:var(--htt-simple-ink);font-size:15px;line-height:1.2}.htt-simple-coach-card span{display:block;margin-top:4px;color:var(--htt-simple-muted);font-size:13px;line-height:1.45}.htt-simple-coach-card.is-active{border-color:#d0c2ff;background:linear-gradient(180deg,#f8f5ff,#fff)}.htt-simple-workflow{display:grid;grid-template-columns:320px minmax(0,1fr) 340px;gap:18px;align-items:start}.htt-simple-panel{border-radius:30px;padding:20px;border:1px solid var(--htt-simple-line)}.htt-simple-panel--start{background:radial-gradient(circle at 0% 0%,rgba(91,57,214,.1),transparent 180px),linear-gradient(180deg,var(--htt-simple-purple-panel) 0%,#ffffff 100%);border-color:#ded3ff}.htt-simple-panel--week{background:#fff}.htt-simple-panel--action{background:radial-gradient(circle at 100% 0%,rgba(21,156,148,.1),transparent 180px),linear-gradient(180deg,var(--htt-simple-teal-panel) 0%,#ffffff 100%);border-color:#cdeeea}.htt-simple-panel-head{margin-bottom:16px}.htt-simple-panel-head--horizontal{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.htt-simple-panel-head h3{margin:10px 0 6px;color:var(--htt-simple-ink);font-size:28px;line-height:1.05;letter-spacing:-.04em}.htt-simple-panel-head p{margin:0;color:var(--htt-simple-muted);line-height:1.5;font-size:14px}.htt-simple-rhythm-list{display:grid;gap:10px}.htt-simple-rhythm-card{width:100%;text-align:left;display:grid;gap:7px;padding:16px;border-radius:20px;border:1px solid rgba(91,57,214,.13);background:#ffffffd1;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background .16s ease}.htt-simple-rhythm-card:hover,.htt-simple-rhythm-card.is-active{transform:translateY(-1px);border-color:#cbbbff;background:#fff;box-shadow:var(--htt-simple-shadow-purple)}.htt-simple-rhythm-card span{color:var(--htt-simple-purple);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.htt-simple-rhythm-card strong{color:var(--htt-simple-ink);font-size:15px;line-height:1.34}.htt-simple-rhythm-card small{color:var(--htt-simple-muted);font-size:13px;line-height:1.44}.htt-simple-help-box{margin-top:16px;background:#fff6e7d9}.htt-simple-week-actions{display:grid;gap:10px;min-width:220px}.htt-simple-load{border:1px solid var(--htt-simple-line);border-radius:18px;padding:12px;background:#fbfbff;display:grid;gap:3px}.htt-simple-load strong{color:var(--htt-simple-ink);font-size:13px}.htt-simple-load span{color:var(--htt-simple-muted);font-size:12px;line-height:1.35}.htt-simple-load.is-green{background:#eefcf5;border-color:#ccefdc}.htt-simple-load.is-teal{background:#eafaf8;border-color:#ccefeb}.htt-simple-load.is-amber{background:#fff6e7;border-color:#f0ddb8}.htt-simple-week-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.htt-simple-day-card{border:1px solid var(--htt-simple-line);border-radius:22px;background:#fbfcff;overflow:hidden;min-height:398px}.htt-simple-day-card__head{padding:14px;background:linear-gradient(180deg,#fff,#fbfbff);border-bottom:1px solid var(--htt-simple-line);display:grid;gap:3px}.htt-simple-day-card__head strong{color:var(--htt-simple-ink);font-size:17px;letter-spacing:-.02em}.htt-simple-day-card__head span{color:var(--htt-simple-muted);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.htt-simple-day-card__body{padding:10px;display:grid;gap:9px}.htt-simple-moment-card,.htt-simple-empty-slot{width:100%;text-align:left;border-radius:17px;padding:13px}.htt-simple-moment-card{display:grid;gap:5px;border:1px solid var(--htt-simple-line);background:#fff;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.htt-simple-moment-card:hover,.htt-simple-moment-card.is-active{transform:translateY(-1px);border-color:#cbbbff;box-shadow:0 12px 22px #5b39d61a}.htt-simple-moment-card span{width:fit-content;border-radius:999px;padding:4px 7px;background:var(--htt-simple-purple-soft);color:var(--htt-simple-purple);font-size:10px;font-weight:900;letter-spacing:.05em}.htt-simple-moment-card strong{color:var(--htt-simple-ink);font-size:14px;line-height:1.28}.htt-simple-moment-card small{color:var(--htt-simple-muted);font-size:12px;line-height:1.38}.htt-simple-empty-slot{min-height:46px;border:1px dashed #d8dce8;background:#fff;color:var(--htt-simple-muted);text-align:center;font-size:12px;font-weight:850}.htt-simple-detail-box{border-radius:18px;padding:15px;background:#ffffffbd;border:1px solid rgba(21,156,148,.2);display:grid;gap:7px}.htt-simple-detail-box span{color:var(--htt-simple-teal);font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.htt-simple-detail-box strong{line-height:1.42}.htt-simple-owner-field{margin-top:14px}.htt-simple-action-stack{margin-top:14px;display:grid;gap:10px}.htt-simple-action-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.htt-simple-action-stack .htt-btn,.htt-simple-action-row .htt-btn,.htt-simple-week-actions .htt-btn{min-height:44px;border-radius:14px;font-size:13px}.htt-simple-planner-note,.htt-simple-guidance-box{margin-top:14px;border-radius:18px;padding:15px}.htt-simple-planner-note{background:var(--htt-simple-gold-soft);border:1px solid #f0ddb8}.htt-simple-guidance-box{background:#ffffffc7;border:1px solid rgba(21,156,148,.18)}@media(max-width:1300px){.htt-simple-hero,.htt-simple-workflow,.htt-simple-coach-strip{grid-template-columns:1fr}.htt-simple-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.htt-simple-hero__side{grid-template-columns:1fr 1fr}}@media(max-width:780px){.htt-simple-page{padding:12px}.htt-simple-hero__copy,.htt-simple-hero__side,.htt-simple-panel{padding:18px}.htt-simple-hero__side,.htt-simple-panel-head--horizontal,.htt-simple-week-grid,.htt-simple-action-row{grid-template-columns:1fr}.htt-simple-panel-head--horizontal{display:grid}.htt-simple-hero h2{font-size:36px}}.htt-simple-page{padding:12px 16px 20px;gap:14px}.htt-simple-intro{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.38fr);gap:18px;align-items:start;padding:0 12px}.htt-simple-intro .htt-simple-kicker{color:var(--htt-simple-purple);background:var(--htt-simple-purple-soft);border:1px solid #ddd3ff}.htt-simple-intro h2{margin:12px 0 8px;color:var(--htt-simple-ink);font-size:clamp(28px,3vw,42px);line-height:1.04;letter-spacing:-.045em}.htt-simple-intro p{max-width:940px;margin:0;color:var(--htt-simple-ink);font-size:15px;line-height:1.5}.htt-simple-intro-note{border-radius:18px;padding:15px;background:var(--htt-simple-gold-soft);border:1px solid #f0ddb8}.htt-simple-intro-note strong{color:var(--htt-simple-ink)}.htt-simple-intro-note p{margin:6px 0 0;color:var(--htt-simple-muted);font-size:14px;line-height:1.5}.htt-simple-workflow{position:relative;transition:grid-template-columns .22s ease,gap .22s ease}.htt-simple-page.is-simple-left-closed .htt-simple-workflow{grid-template-columns:0 minmax(0,1fr) 340px;column-gap:0}.htt-simple-page.is-simple-right-closed .htt-simple-workflow{grid-template-columns:320px minmax(0,1fr) 0;column-gap:0}.htt-simple-page.is-simple-left-closed.is-simple-right-closed .htt-simple-workflow{grid-template-columns:0 minmax(0,1fr) 0}.htt-simple-panel{min-width:0}.htt-simple-panel--start,.htt-simple-panel--action{transition:opacity .18s ease,padding .18s ease,border-color .18s ease}.htt-simple-panel--start:not(.is-open),.htt-simple-panel--action:not(.is-open){opacity:0;pointer-events:none;overflow:hidden;padding-left:0;padding-right:0;border-color:transparent}.htt-simple-panel--week{min-width:0;overflow:hidden}.htt-simple-side-handle{position:absolute;top:180px;width:24px;height:70px;border-radius:999px;font:inherit;font-size:18px;font-weight:950;cursor:pointer;z-index:24;display:inline-flex;align-items:center;justify-content:center;transition:left .22s ease,right .22s ease,background .16s ease,box-shadow .16s ease}.htt-simple-side-handle--left{left:-12px;border:1px solid color-mix(in srgb,#6b46f2 24%,#e5e8f2);background:linear-gradient(180deg,#fff,#f3efff);color:#6b46f2;box-shadow:0 10px 24px #6b46f229}.htt-simple-side-handle--left.is-open{left:310px}.htt-simple-side-handle--right{right:-12px;border:1px solid color-mix(in srgb,#1aa39a 24%,#e5e8f2);background:linear-gradient(180deg,#fff,#eefcf9);color:#1aa39a;box-shadow:0 10px 24px #1aa39a29}.htt-simple-side-handle--right.is-open{right:330px}.htt-simple-week-grid{grid-template-columns:repeat(5,minmax(118px,1fr));overflow-x:auto;padding-bottom:4px;scrollbar-gutter:stable}.htt-simple-day-card{min-width:0}@media(max-width:1300px){.htt-simple-intro{grid-template-columns:1fr;padding:0}.htt-simple-side-handle{display:none}.htt-simple-page.is-simple-left-closed .htt-simple-workflow,.htt-simple-page.is-simple-right-closed .htt-simple-workflow,.htt-simple-page.is-simple-left-closed.is-simple-right-closed .htt-simple-workflow,.htt-simple-workflow{grid-template-columns:1fr;gap:18px}.htt-simple-panel--start:not(.is-open),.htt-simple-panel--action:not(.is-open){display:none}}.htt-simple-edit-card,.htt-simple-resource-card{margin-top:14px;border-radius:18px;padding:15px;border:1px solid rgba(21,156,148,.18);background:#ffffffd1;display:grid;gap:12px}.htt-simple-resource-card{border-color:#5b39d629;background:#ffffffdb}.htt-simple-mini-head{display:grid;gap:5px}.htt-simple-mini-head strong{color:var(--htt-simple-ink, #202333);font-size:14px;line-height:1.25}.htt-simple-mini-head span{color:var(--htt-simple-muted, #697184);font-size:12px;line-height:1.45}.htt-simple-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.htt-simple-resource-list{display:grid;gap:10px}.htt-simple-resource-item{width:100%;text-align:left;display:grid;gap:6px;padding:13px;border-radius:16px;border:1px solid var(--htt-simple-line, #e4e7f2);background:#fff;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.htt-simple-resource-item:hover,.htt-simple-resource-item.is-active{transform:translateY(-1px);border-color:#cbbbff;box-shadow:0 12px 22px #5b39d61a}.htt-simple-resource-item span{width:fit-content;min-height:22px;display:inline-flex;align-items:center;padding:0 8px;border-radius:999px;background:var(--htt-simple-purple-soft, #f1edff);color:var(--htt-simple-purple, #5b39d6);font-size:10px;font-weight:900;letter-spacing:.05em;text-transform:uppercase}.htt-simple-resource-item strong{color:var(--htt-simple-ink, #202333);font-size:13px;line-height:1.3}.htt-simple-resource-item small{color:var(--htt-simple-muted, #697184);font-size:12px;line-height:1.4}@media(max-width:780px){.htt-simple-edit-grid{grid-template-columns:1fr}}.htt-mini-btn.is-purple{background:#f1edff;color:#6b46f2;border-color:#dfd4ff}.htt-linked-summary{display:grid;gap:8px;border-radius:16px;border:1px solid #d7efe9;background:linear-gradient(180deg,#f0fdf9,#fff);padding:12px;color:#145c55;font-size:12px;line-height:1.45;font-weight:750}.htt-linked-summary span{display:block}.htt-linked-summary strong{color:#182234}.htt-linked-start-card{display:grid;gap:9px;border-radius:16px;border:1px solid #dfd4ff;background:linear-gradient(180deg,#f7f4ff,#fff);padding:12px}.htt-linked-start-card strong{color:#2c166f;font-size:13px;font-weight:950}.htt-linked-start-card span{color:#667085;font-size:12px;line-height:1.45}.htt-simple-resource-card>.htt-btn{justify-self:start}.htt-simple-card-link{display:block;width:fit-content;max-width:100%;border-radius:999px;padding:4px 8px;background:#eafaf8;color:#0f766e;border:1px solid #ccefeb;font-size:11px;font-style:normal;font-weight:850;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.htt-simple-card-link.is-workspace{background:#f1edff;color:#6b46f2;border-color:#dfd4ff}.htt-simple-action-stack--empty{margin-bottom:12px;border-radius:18px;border:1px dashed #cdeeea;background:linear-gradient(180deg,#f0fdf9,#fff);padding:12px}.htt-simple-action-group{display:grid;gap:9px;border-radius:18px;border:1px solid rgba(124,58,237,.13);background:linear-gradient(180deg,#ffffffeb,#faf8ffeb);padding:12px}.htt-simple-action-group--planner{border-color:#10b9812e;background:linear-gradient(180deg,#f0fdf9,#fff)}.htt-simple-action-label{color:#5b39d6;font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.htt-simple-action-group--planner .htt-simple-action-label{color:#047857}.htt-simple-action-help{margin:-3px 0 2px;color:#667085;font-size:12px;line-height:1.45;font-weight:700}.htt-simple-card-link.is-start{background:#fff6e7;color:#9a5b05;border-color:#f4d49a}.htt-linked-start-card{border-color:#bdebe6!important;background:linear-gradient(180deg,#ecfdf5,#fff)!important}.htt-simple-moment-card{cursor:pointer}.htt-simple-moment-card.has-linked-work{border-color:#10b9813d}.htt-simple-moment-card.is-attempted,.htt-simple-moment-card.is-done{border-color:#22c55e61;background:radial-gradient(circle at 100% 0%,rgba(34,197,94,.1),transparent 120px),linear-gradient(180deg,#f0fdf4,#fff)}.htt-simple-moment-card.is-done{border-color:#10b98185;box-shadow:inset 0 0 0 1px #10b9811a,0 12px 24px #10b9811a}.htt-simple-card-topline{display:flex;justify-content:space-between;gap:8px;align-items:center}.htt-simple-card-status{min-height:22px;border-radius:999px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;background:#dcfce7;color:#15803d;border:1px solid #bbf7d0;font-size:10px;font-style:normal;font-weight:950;line-height:1}.htt-simple-card-status.is-attempted{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.htt-simple-card-status.is-done{background:#dcfce7;color:#15803d;border-color:#86efac}.htt-simple-card-start{width:fit-content;min-height:34px;border:0;border-radius:12px;padding:0 15px;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;font:inherit;font-size:12px;font-weight:950;cursor:pointer;box-shadow:0 10px 20px #7c3aed2e}.htt-simple-card-start:hover,.htt-simple-card-start:focus-visible{transform:translateY(-1px);outline:none}.htt-simple-card-start.is-repeat{background:linear-gradient(135deg,#7c3aed,#6d28d9)}.htt-slot.has-linked-work{border-color:#10b98140}.htt-slot.is-attempted,.htt-slot.is-done{background:radial-gradient(circle at 100% 0%,rgba(34,197,94,.1),transparent 140px),linear-gradient(180deg,#f0fdf4,#fff);border-color:#22c55e59}.htt-simple-card-link.is-auto{background:#f8fafc;color:#475569;border-color:#e2e8f0}.htt-child-empty-note{display:grid;gap:5px;border-radius:16px;border:1px solid rgba(245,158,11,.22);background:linear-gradient(180deg,#fffbeb,#fff);padding:12px;color:#92400e}.htt-child-empty-note strong{font-size:12px;font-weight:950}.htt-child-empty-note span{color:#7a5b12;font-size:12px;line-height:1.42;font-weight:700}.htt-simple-card-link.is-custom{background:#f8fafc;color:#475569;border-color:#e2e8f0}.htt-simple-delete-toolbar{margin:0 18px 14px;border-radius:20px;border:1px solid rgba(220,38,38,.18);background:linear-gradient(180deg,#fff1f2,#fff);padding:14px;display:flex;justify-content:space-between;gap:14px;align-items:center}.htt-simple-delete-toolbar strong{color:#991b1b;font-weight:950}.htt-simple-delete-toolbar span{display:block;color:#7f1d1d;font-size:12px;font-weight:750;line-height:1.4}.htt-simple-delete-actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:flex-end}.htt-simple-moment-card.is-delete-mode{border-color:#dc262633;cursor:pointer}.htt-simple-moment-card.is-delete-mode:hover,.htt-simple-moment-card.is-delete-mode.is-batch-selected{border-color:#dc26269e;box-shadow:0 14px 28px #dc262624}.htt-simple-moment-card.is-batch-selected{background:radial-gradient(circle at 100% 0%,rgba(220,38,38,.1),transparent 140px),linear-gradient(180deg,#fff7f7,#fff)}.htt-simple-select-dot{min-height:24px;border-radius:999px;border:1px solid rgba(220,38,38,.25);background:#fff;color:#991b1b;padding:0 9px;display:inline-flex;align-items:center;font-size:10px;font-style:normal;font-weight:950}.htt-simple-select-dot.is-selected{background:#dc2626;color:#fff;border-color:#dc2626}@media(max-width:900px){.htt-simple-delete-toolbar{align-items:stretch;flex-direction:column}.htt-simple-delete-actions{justify-content:flex-start}}.htt-btn.is-active-action{border-color:#7c3aed59;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;box-shadow:0 12px 24px #7c3aed29}.htt-simple-edit-card{scroll-margin-top:18px}.htt-simple-edit-card:focus-within{border-color:#7c3aed47;box-shadow:0 12px 28px #7c3aed1a}.htt-child-multi-field{display:grid;gap:9px}.htt-child-multi-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.htt-child-multi-head span{color:var(--htt-simple-ink, #1f2937);font-size:12px;font-weight:950}.htt-child-multi-head em{color:#6b7280;font-size:11px;font-style:normal;font-weight:850}.htt-child-chip-row{display:flex;flex-wrap:wrap;gap:8px}.htt-child-chip{min-height:34px;border-radius:999px;border:1px solid rgba(124,58,237,.16);background:#fff;color:#4b5563;padding:0 11px;display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:12px;font-weight:850;cursor:pointer}.htt-child-chip span{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#f3f0ff;color:#5b39d6;font-size:10px;font-weight:950}.htt-child-chip.is-selected{border-color:#10b98173;background:linear-gradient(180deg,#ecfdf5,#fff);color:#065f46}.htt-child-chip.is-selected span{background:#10b981;color:#fff}.htt-child-multi-help{margin:0;color:#667085;font-size:12px;line-height:1.42;font-weight:700}.htt-db-save-pill{min-height:34px;border-radius:999px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;background:#f8fafc;color:#475569;border:1px solid #e2e8f0;font-size:11px;font-weight:950;white-space:nowrap}.htt-db-save-pill.is-saved{background:#ecfdf5;color:#047857;border-color:#bbf7d0}.htt-db-save-pill.is-saving,.htt-db-save-pill.is-loading{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.htt-db-save-pill.is-offline{background:#fffbeb;color:#92400e;border-color:#fde68a}.htt-simple-moment-card small{white-space:normal;overflow-wrap:anywhere;line-height:1.35}.htt-simple-assigned-summary{display:flex;justify-content:space-between;gap:12px;align-items:center;border-radius:18px;border:1px solid rgba(124,58,237,.13);background:linear-gradient(180deg,#fff,#faf8ff);padding:12px}.htt-simple-assigned-summary span{display:block;color:#6b7280;font-size:10px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.htt-simple-assigned-summary strong{display:block;margin-top:3px;color:#111827;font-size:13px;line-height:1.35;font-weight:950}.htt-mini-link{border:0;background:transparent;color:#5b39d6;font:inherit;font-size:12px;font-weight:950;cursor:pointer;text-decoration:underline;text-underline-offset:3px;white-space:nowrap}@media(max-width:760px){.htt-simple-assigned-summary{align-items:flex-start;flex-direction:column}}.htt-modal-backdrop{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:24px;background:#1118276b;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.htt-duplicate-modal{width:min(720px,96vw);max-height:min(760px,92vh);overflow-y:auto;border-radius:28px;border:1px solid rgba(124,58,237,.16);background:#fff;box-shadow:0 30px 80px #11182740;padding:20px}.htt-duplicate-modal__head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;border-radius:22px;background:linear-gradient(135deg,#f5f3ff,#ecfeff);padding:18px}.htt-duplicate-modal__head span{color:#5b39d6;font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.htt-duplicate-modal__head h3{margin:4px 0 5px;color:#111827;font-size:24px;line-height:1.1}.htt-duplicate-modal__head p{margin:0;color:#667085;font-size:13px;line-height:1.45;font-weight:700}.htt-modal-close{width:38px;height:38px;border:0;border-radius:14px;background:#ffffffe0;color:#111827;font-size:24px;font-weight:800;cursor:pointer}.htt-duplicate-modal__section{margin-top:16px;display:grid;gap:10px}.htt-duplicate-modal__section>strong{color:#111827;font-size:13px;font-weight:950}.htt-duplicate-chip-grid{display:flex;flex-wrap:wrap;gap:9px}.htt-duplicate-chip{min-height:38px;border-radius:999px;border:1px solid rgba(124,58,237,.16);background:#fff;color:#4b5563;padding:0 14px;font:inherit;font-size:12px;font-weight:900;cursor:pointer}.htt-duplicate-chip.is-selected{border-color:#10b98173;background:linear-gradient(180deg,#ecfdf5,#fff);color:#065f46;box-shadow:0 10px 18px #10b9811a}.htt-duplicate-help{margin:0;color:#667085;font-size:12px;line-height:1.42;font-weight:700}.htt-duplicate-modal__actions{margin-top:18px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}@media(max-width:760px){.htt-modal-backdrop{padding:12px}.htt-duplicate-modal{border-radius:22px;padding:14px}.htt-duplicate-modal__head{border-radius:18px}}.htt-add-modal{width:min(760px,96vw);max-height:min(780px,92vh);overflow-y:auto;border-radius:28px;border:1px solid rgba(124,58,237,.16);background:#fff;box-shadow:0 30px 80px #11182740;padding:20px}.htt-add-modal__head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;border-radius:22px;background:linear-gradient(135deg,#f5f3ff,#ecfeff);padding:18px}.htt-add-modal__head span{color:#5b39d6;font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.htt-add-modal__head h3{margin:4px 0 5px;color:#111827;font-size:24px;line-height:1.1}.htt-add-modal__head p,.htt-add-help{margin:0;color:#667085;font-size:13px;line-height:1.45;font-weight:700}.htt-add-modal__section{margin-top:16px;display:grid;gap:10px}.htt-add-modal__section>strong{color:#111827;font-size:13px;font-weight:950}.htt-add-chip-grid{display:flex;flex-wrap:wrap;gap:9px}.htt-add-chip{min-height:38px;border-radius:999px;border:1px solid rgba(124,58,237,.16);background:#fff;color:#4b5563;padding:0 14px;font:inherit;font-size:12px;font-weight:900;cursor:pointer}.htt-add-chip.is-selected{border-color:#10b98173;background:linear-gradient(180deg,#ecfdf5,#fff);color:#065f46;box-shadow:0 10px 18px #10b9811a}.htt-add-modal__grid{margin-top:16px;display:grid;grid-template-columns:minmax(150px,.5fr) minmax(240px,1fr);gap:12px}.htt-add-modal__tabs{margin-top:16px;display:flex;gap:8px;flex-wrap:wrap;padding:6px;border-radius:999px;background:#f8fafc;border:1px solid rgba(124,58,237,.1)}.htt-add-modal__tabs button{border:0;border-radius:999px;background:transparent;color:#475569;min-height:34px;padding:0 14px;font:inherit;font-size:12px;font-weight:950;cursor:pointer}.htt-add-modal__tabs button.is-active{background:#fff;color:#5b39d6;box-shadow:0 8px 18px #7c3aed1f}.htt-simple-card-link.is-block{background:#f5f3ff;color:#5b21b6;border-color:#7c3aed29}.htt-block-activity-list{display:grid;gap:9px}.htt-block-activity-row{display:flex;justify-content:space-between;align-items:center;gap:12px;border-radius:16px;border:1px solid rgba(124,58,237,.12);background:#fff;padding:11px}.htt-block-activity-row span{display:block;color:#5b39d6;font-size:10px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.htt-block-activity-row strong{display:block;color:#111827;font-size:13px;line-height:1.25}.htt-block-activity-row small{display:block;color:#6b7280;font-size:12px;line-height:1.35;font-weight:700}@media(max-width:760px){.htt-add-modal{border-radius:22px;padding:14px}.htt-add-modal__head{border-radius:18px}.htt-add-modal__grid{grid-template-columns:1fr}.htt-block-activity-row{align-items:stretch;flex-direction:column}}.htt-simple-intro__topline{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:6px}.htt-simple-intro__topline .htt-mode-toggle{flex-shrink:0}.hph-page{min-height:100%;background:linear-gradient(180deg,#f8f8ff,#f5f7fb)}.hph-shell{min-height:100%;display:flex;flex-direction:column;gap:18px;padding:20px}.hph-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap;border-radius:30px;padding:26px 28px;color:#fff;background:radial-gradient(circle at 92% 0%,rgba(255,255,255,.18),transparent 260px),linear-gradient(135deg,#2c166f,#4d2ca5 55%,#1f4769);box-shadow:0 18px 40px #1018281a}.hph-hero__main{display:flex;align-items:flex-start;gap:14px;min-width:0;flex:1 1 560px}.hph-hero__side{display:grid;gap:10px;justify-items:end;align-self:flex-start}.hph-hero__icon{width:56px;height:56px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);font-size:26px;flex-shrink:0}.hph-kicker{display:inline-flex;min-height:28px;align-items:center;padding:0 10px;border-radius:999px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}.hph-hero h1{margin:0;font-size:clamp(30px,4vw,52px);line-height:1.03;letter-spacing:-.05em}.hph-hero p{margin:10px 0 0;max-width:920px;font-size:15px;line-height:1.55;color:#ffffffd6;font-weight:560}.hph-toggle{display:inline-flex;gap:8px;align-items:center;padding:7px;border-radius:999px;background:#ffffff1f;border:1px solid rgba(255,255,255,.16);align-self:flex-start}.hph-toggle button{min-height:42px;padding:0 14px;border-radius:999px;border:1px solid transparent;background:transparent;color:#ffffffd6;font:inherit;font-size:13px;font-weight:850;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.hph-toggle button.is-active{background:#fff;color:#2e176f;border-color:#fff;box-shadow:0 8px 22px #0000001f}.hph-help-trigger{position:relative;width:50px;height:50px;min-width:50px;display:inline-grid;place-items:center;padding:0;border-radius:18px;border:1px solid rgba(255,255,255,.28);background:linear-gradient(135deg,#ffffff2e,#1aa39a2e);color:#fff;font-family:inherit;cursor:pointer;box-shadow:inset 0 1px #ffffff47,0 14px 30px #00000029;overflow:visible;transition:transform .19s ease,border-color .19s ease,box-shadow .19s ease,background .19s ease}.hph-help-trigger:before{content:"";position:absolute;inset:-1px;border-radius:19px;background:linear-gradient(130deg,transparent 8%,rgba(255,255,255,.36) 42%,transparent 72%);opacity:0;transform:translate(-20%) rotate(8deg);transition:opacity .18s ease,transform .52s ease;z-index:0}.hph-help-trigger:hover,.hph-help-trigger:focus-visible{transform:translateY(-2px) scale(1.035);border-color:#1aa39a85;box-shadow:inset 0 1px #ffffff57,0 20px 42px #00000038;outline:none}.hph-help-trigger:hover:before,.hph-help-trigger:focus-visible:before{opacity:1;transform:translate(24%) rotate(8deg)}.hph-help-trigger__halo{position:absolute;inset:5px;border-radius:16px;background:radial-gradient(circle at 28% 24%,rgba(255,255,255,.52),transparent 38%),#ffffff14;z-index:1;transition:transform .21s ease,opacity .19s ease}.hph-help-trigger__orb{position:relative;z-index:2;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#fff,color-mix(in srgb,#1aa39a 16%,#fff));color:#2c166f;box-shadow:0 9px 20px #0003;transition:transform .22s ease,color .19s ease}.hph-help-trigger:hover .hph-help-trigger__orb,.hph-help-trigger:focus-visible .hph-help-trigger__orb{transform:rotate(-8deg) scale(1.08)}.hph-help-trigger:hover .hph-help-trigger__halo,.hph-help-trigger:focus-visible .hph-help-trigger__halo{transform:scale(1.08);opacity:.92}.hph-help-trigger__dot{position:absolute;right:7px;top:7px;z-index:3;width:9px;height:9px;border-radius:999px;background:#fff;box-shadow:0 0 0 3px #1aa39a61,0 0 18px #1aa39ab3;transition:transform .19s ease}.hph-help-trigger:hover .hph-help-trigger__dot,.hph-help-trigger:focus-visible .hph-help-trigger__dot{transform:scale(1.18)}.hph-view{min-height:0;flex:1 1 auto}.hph-help-portal{position:fixed;inset:0;z-index:1700;pointer-events:none}.hph-help-portal.is-open{pointer-events:auto}.hph-help-scrim{position:absolute;inset:0;background:#0f172a5c;opacity:0;transition:opacity .18s ease}.hph-help-scrim.is-open{opacity:1}.hph-help-drawer{position:absolute;top:0;right:0;bottom:0;width:min(560px,calc(100vw - 18px));height:100dvh;max-height:100dvh;display:flex;flex-direction:column;min-height:0;background:#fff;box-shadow:-18px 0 40px #1018282e;transform:translate(100%);transition:transform .22s ease;overflow:hidden}.hph-help-drawer.is-open{transform:translate(0)}.hph-help-top{position:relative;padding:18px 20px 0;background:radial-gradient(circle at 18% 4%,rgba(255,255,255,.14),transparent 200px),linear-gradient(135deg,#2c166f,#4d2ca5 55%,#1f4769);color:#fff}.hph-help-glow{position:absolute;inset:auto auto 24px -18px;width:120px;height:120px;border-radius:999px;background:#ffffff1a;filter:blur(18px)}.hph-help-head{position:relative;z-index:1;display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding-bottom:14px}.hph-help-brand{display:flex;gap:12px;align-items:flex-start;min-width:0}.hph-help-icon{width:44px;height:44px;border-radius:15px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.hph-help-brand h2{margin:0;font-size:24px;line-height:1.05;letter-spacing:-.03em}.hph-help-brand p{margin:6px 0 0;color:#fffc;font-size:13px;line-height:1.45}.hph-help-close{width:42px;height:42px;border-radius:14px;border:1px solid rgba(255,255,255,.16);background:#ffffff1f;color:#fff;font:inherit;font-size:26px;line-height:1;cursor:pointer}.hph-help-search{margin:0 0 13px;display:flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.22);border-radius:18px;background:#ffffff1f;padding:0 14px;min-height:50px;position:relative;z-index:1}.hph-help-search span{font-size:18px;opacity:.92}.hph-help-search input{width:100%;border:0;background:transparent;color:#fff;font:inherit;font-size:14px;outline:none}.hph-help-search input::placeholder{color:#ffffffad}.hph-help-cats{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}.hph-help-cats button{min-height:32px;padding:0 12px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#ffffffd6;font:inherit;font-size:12px;font-weight:800;cursor:pointer}.hph-help-cats button.is-active{background:#fff;color:#2e176f;border-color:#fff}.hph-help-top-gap{height:18px}.hph-help-results{flex:1 1 auto;min-height:0;overflow:auto;padding:18px;background:linear-gradient(180deg,#fbfbff,#fff);display:flex;flex-direction:column;gap:12px}.hph-help-article{border:1px solid #e5e8f2;border-radius:18px;background:#fff;overflow:hidden}.hph-help-article__top{width:100%;padding:14px;border:0;background:transparent;cursor:pointer;display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:10px;align-items:center;text-align:left}.hph-help-article__icon{width:32px;height:32px;border-radius:10px;background:#f1edff;color:#6b46f2;display:inline-flex;align-items:center;justify-content:center;font-size:15px}.hph-help-article__text{min-width:0;display:flex;flex-direction:column;gap:3px}.hph-help-article__text strong{color:#182234;font-size:14px;line-height:1.3}.hph-help-article__text small{color:#667085;font-size:12px;line-height:1.4}.hph-help-chip{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;background:#eafaf8;color:#1aa39a;font-size:11px;font-weight:800;white-space:nowrap}.hph-help-chevron{color:#667085;font-size:18px;line-height:1}.hph-help-article.is-open .hph-help-chevron{transform:rotate(180deg)}.hph-help-article__body{padding:0 16px 16px 58px;display:grid;gap:12px}.hph-help-article__body ol{margin:0;padding-left:18px;display:grid;gap:9px;color:#334155;font-size:13px;line-height:1.55}.hph-help-tip{border-radius:14px;border:1px solid #dfd4ff;background:#f7f4ff;color:#4a31a4;padding:12px 13px;display:grid;gap:5px}.hph-help-tip strong{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.hph-help-tip span{font-size:13px;line-height:1.45}.hph-help-empty{border:1px dashed #e5e8f2;border-radius:18px;background:#fff;padding:18px;display:grid;gap:6px;color:#667085}.hph-help-empty strong{color:#182234;font-size:14px}@media(max-width:800px){.hph-shell{padding:12px}.hph-hero{padding:22px;border-radius:24px}.hph-hero__side{width:100%;flex-wrap:wrap}.hph-help-trigger{width:48px;height:48px;min-width:48px}.hph-help-drawer{width:min(100vw,520px)}.hph-help-article__top{grid-template-columns:auto minmax(0,1fr) auto}.hph-help-chip{grid-column:2 / span 1;justify-self:start}.hph-help-chevron{grid-column:3;grid-row:1}.hph-help-article__body{padding-left:16px}}.hph-page.is-locked-view .hph-toggle{display:none}.hph-hero.is-planner .hph-hero__icon,.hph-hero.is-timetable .hph-hero__icon{background:#ffffff21}.hph-hero__side{align-items:end}.hph-weekly-tools{display:inline-flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.hph-header-actions{display:flex;justify-content:flex-end;gap:9px;flex-wrap:wrap}.hph-action-btn{min-height:38px;padding:0 13px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:#ffffff1f;color:#ffffffeb;font:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:transform .17s ease,background .17s ease,box-shadow .17s ease}.hph-action-btn:hover,.hph-action-btn:focus-visible{transform:translateY(-1px);background:#ffffff2e;outline:none}.hph-action-btn.is-primary{background:#fff;color:#2e176f;border-color:#fff;box-shadow:0 8px 22px #0000001f}.hph-page.is-planner .hph-hero{margin-bottom:0}@media(max-width:800px){.hph-hero__side{align-items:start;width:100%}.hph-header-actions{justify-content:flex-start}}.hph-mode-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px;border-radius:999px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);box-shadow:inset 0 1px #ffffff29;align-self:flex-start}.hph-mode-toggle button{min-height:40px;padding:0 15px;border-radius:999px;border:1px solid transparent;background:transparent;color:#ffffffdb;font:inherit;font-size:13px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;transition:background .17s ease,color .17s ease,box-shadow .17s ease,transform .17s ease}.hph-mode-toggle button:hover,.hph-mode-toggle button:focus-visible{color:#fff;background:#ffffff1a;outline:none}.hph-mode-toggle button.is-active{background:#fff;color:#2e176f;border-color:#fff;box-shadow:0 8px 22px #0000001f}.hph-mode-toggle button.is-active:hover,.hph-mode-toggle button.is-active:focus-visible{color:#2e176f;background:#fff}@media(max-width:800px){.hph-mode-toggle{width:100%;justify-content:stretch}.hph-mode-toggle button{flex:1 1 0}}.wspx-page{min-height:100%;padding:24px;background:linear-gradient(180deg,#f8fafc,#fff);color:var(--text, #111827);font-family:var(--font-body, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif)}.wspx-header-stack{display:flex;flex-direction:column;gap:0;margin:20px 0 0}.wspx-hero{min-height:132px;padding:24px 28px;border-radius:26px 26px 0 0;border:1px solid color-mix(in srgb,var(--brand-text, #ffffff) 12%,transparent);border-bottom:0;background:radial-gradient(circle at 82% 4%,color-mix(in srgb,var(--brand-text, #ffffff) 18%,transparent),transparent 220px),linear-gradient(135deg,var(--brand-bg, #2d1a69) 0%,color-mix(in srgb,var(--brand-bg, #2d1a69) 78%,var(--teal, #159e9b)) 100%);color:var(--brand-text, #ffffff);box-shadow:0 18px 42px #2d1a6929;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}.wspx-hero-main{display:flex;align-items:center;gap:14px;min-width:0;flex:1 1 420px}.wspx-hero-icon{width:54px;height:54px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--brand-text, #ffffff) 12%,transparent);border:1px solid color-mix(in srgb,var(--brand-text, #ffffff) 20%,transparent);box-shadow:inset 0 1px color-mix(in srgb,var(--brand-text, #ffffff) 14%,transparent);font-size:24px;flex-shrink:0}.wspx-hero h2{margin:0;font-size:clamp(26px,2.8vw,40px);line-height:1.05;letter-spacing:-.04em;font-weight:950}.wspx-hero p{margin:8px 0 0;max-width:780px;color:var(--brand-text-sub, rgba(255, 255, 255, .82));font-size:14px;line-height:1.5;font-weight:650}.wspx-hero-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;flex:0 1 auto;margin-left:auto;align-self:center}.wspx-hero-actions button,.wspx-hero-actions span{border-radius:999px;min-height:40px;padding:0 14px;background:color-mix(in srgb,var(--brand-text, #ffffff) 12%,transparent);border:1px solid color-mix(in srgb,var(--brand-text, #ffffff) 20%,transparent);color:var(--brand-text, #ffffff);font:inherit;font-size:12px;font-weight:900;white-space:nowrap}.wspx-hero-actions button{background:var(--brand-text, #ffffff);color:var(--brand-bg, #2d1a69);cursor:pointer;box-shadow:0 12px 28px #0000001f}.wspx-hero-actions span{display:inline-flex;align-items:center}.wspx-stats-band{padding:16px 18px 18px;border-radius:0 0 26px 26px;border:1px solid color-mix(in srgb,var(--brand-text, #ffffff) 10%,transparent);border-top:0;background:var(--brand-bg, #2d1a69);box-shadow:0 18px 42px #2d1a691f}.wspx-stats-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.wspx-stat-card{background:color-mix(in srgb,var(--brand-text, #ffffff) 11%,transparent);border:1px solid color-mix(in srgb,var(--brand-text, #ffffff) 16%,transparent);border-radius:18px;padding:14px 16px;box-shadow:inset 0 1px color-mix(in srgb,var(--brand-text, #ffffff) 10%,transparent)}.wspx-stat-card strong{display:block;font-size:28px;font-weight:900;color:var(--brand-text, #ffffff);line-height:1}.wspx-stat-card span{display:block;margin-top:8px;font-size:11px;font-weight:800;color:var(--brand-text-sub, rgba(255, 255, 255, .74));text-transform:uppercase;letter-spacing:.45px}.wspx-shell{position:relative;display:grid;grid-template-columns:288px minmax(0,1fr) 288px;gap:22px;align-items:start;margin-top:22px;transition:grid-template-columns .22s ease,gap .22s ease}.wspx-page.is-left-closed .wspx-shell{grid-template-columns:0 minmax(0,1fr) 288px;column-gap:0}.wspx-page.is-right-closed .wspx-shell{grid-template-columns:288px minmax(0,1fr) 0;column-gap:0}.wspx-page.is-left-closed.is-right-closed .wspx-shell{grid-template-columns:0 minmax(0,1fr) 0}.wspx-side-handle{position:absolute;top:132px;width:24px;height:84px;border-radius:999px;font:inherit;font-size:18px;font-weight:950;cursor:pointer;z-index:24;display:inline-flex;align-items:center;justify-content:center;transition:left .22s ease,right .22s ease,background .16s ease,box-shadow .16s ease}.wspx-side-handle--left{left:-12px;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 22%,var(--border, #e5e7eb));background:linear-gradient(180deg,var(--surface, #ffffff) 0%,color-mix(in srgb,var(--purple, #7c3aed) 7%,var(--surface2, #f8fafc)) 100%);color:var(--purple, #7c3aed);box-shadow:0 10px 24px #704fa829}.wspx-side-handle--left.is-open{left:298px}.wspx-side-handle--right{right:-12px;border:1px solid color-mix(in srgb,var(--teal, #14b8a6) 22%,var(--border, #e5e7eb));background:linear-gradient(180deg,var(--surface, #ffffff) 0%,color-mix(in srgb,var(--teal, #14b8a6) 7%,var(--surface2, #f8fafc)) 100%);color:var(--teal, #14b8a6);box-shadow:0 10px 24px #1bc6b329}.wspx-side-handle--right.is-open{right:298px}.wspx-curriculum-rail,.wspx-right-rail{min-width:0;transition:opacity .18s ease}.wspx-curriculum-rail:not(.is-open),.wspx-right-rail:not(.is-open){opacity:0;pointer-events:none;overflow:hidden}.wspx-curriculum-card,.wspx-library,.wspx-my-work-card,.wspx-progress-card{border-radius:24px;background:var(--surface, #ffffff);border:1px solid var(--border, #e5e7eb);box-shadow:var(--shadow-sm, 0 8px 22px rgba(15, 23, 42, .06));overflow:hidden}.wspx-curriculum-card{position:sticky;top:18px;display:flex;flex-direction:column;min-height:560px;max-height:calc(100dvh - 160px)}.wspx-card-head{padding:16px 18px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border, #e5e7eb);background:color-mix(in srgb,var(--surface, #ffffff) 96%,var(--purple-l, #f4f0ff))}.wspx-title-with-icon{display:flex;align-items:center;gap:10px;min-width:0}.wspx-title-with-icon h3{margin:0;color:var(--text, #111827);font-size:15px;font-weight:850;letter-spacing:-.02em}.wspx-title-with-icon p{margin:4px 0 0;color:var(--text-muted, #64748b);font-size:12px;line-height:1.35;font-weight:650}.wspx-mini-icon{width:24px;height:24px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;background:color-mix(in srgb,var(--purple, #7c3aed) 10%,var(--surface, #ffffff));color:var(--purple, #7c3aed);flex-shrink:0;box-shadow:inset 0 1px #ffffff8c;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 10%,var(--border, #e5e7eb))}.wspx-curriculum-body{padding:18px 16px 16px;display:flex;flex-direction:column;gap:14px;min-height:0;overflow-y:auto;background:linear-gradient(180deg,#ffffff2e,#ffffff0f)}.wspx-path-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:linear-gradient(180deg,color-mix(in srgb,var(--purple, #7c3aed) 16%,var(--surface2, #f8fafc)),color-mix(in srgb,var(--purple, #7c3aed) 10%,var(--surface, #fff)));color:var(--purple, #7c3aed);font-size:11px;font-weight:800;align-self:flex-start;flex-wrap:wrap;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 12%,var(--border, #e5e7eb))}.wspx-curriculum-tools-row{display:flex;gap:8px;flex-wrap:wrap}.wspx-curriculum-tools-row button,.wspx-rail-reset{border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 12%,var(--border, #e5e7eb));background:color-mix(in srgb,var(--purple, #7c3aed) 6%,var(--surface, #ffffff));color:var(--purple, #7c3aed);border-radius:999px;padding:7px 10px;font-size:11px;font-weight:800;cursor:pointer;font-family:inherit}.wspx-filter-select{display:flex;flex-direction:column;gap:6px;padding:12px;border-radius:16px;background:color-mix(in srgb,var(--purple, #7c3aed) 4%,var(--surface, #ffffff));border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 10%,var(--border, #e5e7eb));box-shadow:inset 0 1px #ffffff73}.wspx-filter-select span{color:var(--text-muted, #64748b);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.wspx-filter-select select{width:100%;height:42px;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 10%,var(--border, #e5e7eb));border-radius:14px;background:#ffffffd1;color:var(--text, #111827);font:inherit;font-size:13px;font-weight:750;padding:0 13px;outline:none}.wspx-tip-card{margin-top:4px;padding:14px;border-radius:16px;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 14%,var(--border, #e5e7eb));background:linear-gradient(180deg,color-mix(in srgb,var(--purple, #7c3aed) 12%,var(--surface, #fff)),color-mix(in srgb,var(--purple, #7c3aed) 7%,var(--surface2, #f8fafc)));color:var(--purple, #7c3aed);font-size:13px;line-height:1.5;box-shadow:inset 0 1px #ffffff8c}.wspx-tip-card strong{display:block;margin-bottom:4px;color:var(--purple, #7c3aed)}.wspx-library{min-width:0;position:relative;border-radius:24px}.wspx-library-head{min-height:60px;border-radius:24px 24px 0 0}.wspx-library-body{padding:14px;display:flex;flex-direction:column;gap:12px}.wspx-search-input input{width:100%;box-sizing:border-box;padding:11px 14px;border-radius:var(--radius-sm, 14px);border:1px solid var(--border, #e5e7eb);font-size:14px;background:var(--surface, #ffffff);color:var(--text, #111827);outline:none;font-family:inherit}.wspx-search-input input:focus{border-color:color-mix(in srgb,var(--purple, #7c3aed) 40%,var(--border, #e5e7eb));box-shadow:0 0 0 4px color-mix(in srgb,var(--purple, #7c3aed) 10%,transparent)}.wspx-subject-tabs,.wspx-year-tabs{display:flex;flex-wrap:wrap;gap:8px}.wspx-subject-tabs button,.wspx-year-tabs button{padding:7px 12px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid var(--border, #e5e7eb);background:var(--surface, #ffffff);color:var(--text-muted, #64748b);cursor:pointer;font-family:inherit}.wspx-subject-tabs button.is-active{background:var(--teal, #16a34a);color:#fff;border-color:var(--teal, #16a34a)}.wspx-year-tabs button.is-active{background:var(--purple, #7c3aed);color:#fff;border-color:var(--purple, #7c3aed)}.wspx-sticky-selection-bar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--purple, #7c3aed) 92%,black),color-mix(in srgb,var(--teal, #14b8a6) 85%,black));box-shadow:0 8px 32px #7c3aed47,0 2px 8px #0000001f;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 40%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.wspx-sticky-left,.wspx-sticky-actions{display:flex;align-items:center;gap:8px}.wspx-sticky-left{min-width:0;color:#ffffffeb;font-size:13px;font-weight:750}.wspx-sticky-icon{width:32px;height:32px;border-radius:10px;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:15px;border:1px solid rgba(255,255,255,.18)}.wspx-sticky-count{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;padding:0 8px;border-radius:999px;background:#ffffff38;color:#fff;font-size:13px;font-weight:800;line-height:1;border:1px solid rgba(255,255,255,.25)}.wspx-sticky-actions button{padding:8px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.25);background:#ffffff1f;color:#ffffffe0;font:inherit;font-size:12px;font-weight:700;cursor:pointer}.wspx-sticky-actions button.is-primary{border-color:#ffffff59;background:#fffffff2;color:var(--purple, #7c3aed);font-weight:800;box-shadow:0 4px 12px #00000026}.wspx-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding-bottom:8px}.wspx-activity-card{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:var(--radius, 18px);background:color-mix(in srgb,var(--surface, #fff) 82%,var(--surface2, #f8fafc));border:1px solid color-mix(in srgb,var(--border, #e5e7eb) 78%,transparent);box-shadow:var(--shadow-sm, 0 8px 22px rgba(15, 23, 42, .04));min-height:208px;transition:outline .15s ease,transform .15s ease,background .15s ease,border-color .15s ease}.wspx-activity-card:hover,.wspx-activity-card.is-selected{transform:translateY(-1px);border-color:color-mix(in srgb,var(--purple, #7c3aed) 30%,var(--border, #e5e7eb))}.wspx-activity-card.is-selected{outline:2px solid var(--teal, #14b8a6);outline-offset:1px;background:color-mix(in srgb,var(--surface, #ffffff) 72%,var(--teal-l, #dcfce7))}.wspx-activity-card__top,.wspx-card-meta,.wspx-card-footer{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;flex-wrap:wrap}.wspx-emoji-box{width:40px;height:40px;border-radius:var(--radius-sm, 14px);background:color-mix(in srgb,var(--surface2, #f8fafc) 76%,transparent);border:1px solid color-mix(in srgb,var(--border, #e5e7eb) 72%,transparent);display:inline-flex;align-items:center;justify-content:center;font-size:20px}.wspx-assigned-badge{padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700;background:color-mix(in srgb,var(--teal, #14b8a6) 18%,transparent);color:var(--teal, #14b8a6);border:1px solid color-mix(in srgb,var(--teal, #14b8a6) 30%,var(--border, #e5e7eb));white-space:nowrap}.wspx-subject-pill,.wspx-year-pill,.wspx-template-pills span{display:inline-block;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700}.wspx-subject-pill{background:var(--purple-l, #ede9fe);color:var(--purple, #7c3aed)}.wspx-year-pill{background:var(--surface2, #f8fafc);color:var(--text-muted, #64748b)}.wspx-template-pills{display:flex;gap:6px;flex-wrap:wrap}.wspx-template-pills span{background:color-mix(in srgb,var(--purple, #7c3aed) 12%,var(--surface2, #f8fafc));color:var(--purple, #7c3aed)}.wspx-card-title{font-size:15px;font-weight:800;color:var(--text, #111827);line-height:1.3}.wspx-card-desc{margin:0;font-size:12px;color:var(--text-muted, #64748b);line-height:1.45;min-height:18px}.wspx-card-path{color:var(--text-muted, #64748b);font-size:12px;line-height:1.35}.wspx-card-footer{margin-top:auto;align-items:center}.wspx-select-btn{padding:8px 12px;border-radius:var(--radius-sm, 14px);border:none;background:var(--teal, #16a34a);color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}.wspx-select-btn.is-active{background:var(--purple, #7c3aed)}.wspx-side-col{display:flex;flex-direction:column;gap:16px;overflow:visible;padding-bottom:22px;min-height:0}.wspx-right-rail{min-width:0;position:sticky;top:18px;align-self:start;max-height:calc(100dvh - 160px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable;padding:0 4px 20px 0}.wspx-my-work-card{min-height:220px}.wspx-sort-tabs{display:flex;flex-wrap:wrap;gap:8px;padding:12px 14px 0}.wspx-sort-tabs button{padding:6px 10px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);color:var(--text-muted, #64748b);cursor:pointer;font-family:inherit}.wspx-sort-tabs button.is-active{background:var(--purple, #7c3aed);color:#fff;border-color:var(--purple, #7c3aed)}.wspx-work-list{display:flex;flex-direction:column;min-height:0;flex:0 0 auto;overflow-y:visible;overscroll-behavior:contain;scrollbar-gutter:stable;padding-bottom:8px}.wspx-empty-mini{padding:16px;font-size:12px;color:var(--text-muted, #64748b)}.wspx-work-group>strong{display:block;padding:12px 14px 2px;color:var(--text-muted, #64748b);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.wspx-work-row{display:flex;flex-direction:column;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border, #e5e7eb)}.wspx-work-row.is-inactive{opacity:.72}.wspx-work-left{display:flex;flex-direction:column;gap:3px;min-width:0}.wspx-work-title{font-size:12px;font-weight:700;color:var(--text, #111827);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.wspx-work-sub,.wspx-future-note{font-size:11px;color:var(--text-muted, #64748b);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wspx-future-note{color:var(--amber, #d97706);font-weight:750}.wspx-work-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.wspx-play-btn{padding:6px 12px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--purple, #7c3aed) 0%,color-mix(in srgb,var(--purple, #7c3aed) 80%,var(--teal, #14b8a6)) 100%);color:#fff;font-size:11px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 4px 10px #7c3aed40}.wspx-play-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.wspx-remove-btn{padding:6px 10px;border-radius:8px;border:1px solid var(--border, #e5e7eb);background:transparent;color:var(--text-muted, #64748b);font-size:14px;font-weight:800;cursor:pointer;font-family:inherit;margin-left:auto}.wspx-progress-card{min-height:210px}.wspx-progress-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:12px}.wspx-progress-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.wspx-progress-header span{font-size:12px;font-weight:700;color:var(--text-muted, #64748b);text-transform:uppercase;letter-spacing:.04em}.wspx-progress-header strong{font-size:22px;font-weight:900;color:var(--teal, #14b8a6);letter-spacing:-.02em}.wspx-progress-track{height:8px;border-radius:999px;background:var(--border, #e5e7eb);overflow:hidden}.wspx-progress-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--teal, #14b8a6) 0%,color-mix(in srgb,var(--teal, #14b8a6) 70%,var(--purple, #7c3aed)) 100%)}.wspx-progress-body small{font-size:11px;color:var(--text-muted, #64748b);font-weight:600}.wspx-error,.wspx-message,.wspx-empty{padding:12px 14px;border-radius:15px;font-size:13px;font-weight:800}.wspx-error{color:#991b1b;background:#fee2e2;border:1px solid rgba(239,68,68,.22)}.wspx-message{color:#065f46;background:#dcfce7;border:1px solid rgba(16,185,129,.22)}.wspx-empty{color:var(--text-muted, #64748b);background:var(--surface2, #f8fafc);border:1px dashed var(--border, #e5e7eb);text-align:center}.wspx-overlay{position:fixed;inset:0;z-index:1600;background:#0f172a61;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px}.wspx-dialog{width:min(760px,94vw);max-height:min(760px,92vh);overflow:auto;background:var(--surface, #ffffff);border-radius:26px;border:1px solid var(--border, #e5e7eb);box-shadow:0 30px 90px #0f172a40;padding:24px;display:flex;flex-direction:column;gap:16px}.wspx-dialog-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.wspx-dialog h3{margin:0;color:var(--text, #111827);font-size:20px;font-weight:900;letter-spacing:-.03em}.wspx-dialog p{margin:6px 0 0;color:var(--text-muted, #64748b);font-size:13px;line-height:1.45}.wspx-dialog-close{width:38px;height:38px;border-radius:14px;border:1px solid var(--border, #e5e7eb);background:var(--surface2, #f8fafc);color:var(--text-muted, #64748b);font-size:24px;cursor:pointer}.wspx-learner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;min-height:168px;align-content:start}.wspx-learner-card{border:1px solid var(--border, #e5e7eb);border-radius:var(--radius-sm, 14px);background:var(--surface, #ffffff);padding:12px;display:flex;align-items:center;gap:10px;cursor:pointer;font:inherit;text-align:left;color:var(--text, #111827)}.wspx-learner-card.is-selected{outline:2px solid var(--teal, #14b8a6);outline-offset:1px;background:var(--surface2, #f8fafc)}.wspx-learner-card span{width:20px;height:20px;border-radius:999px;border:1px solid var(--border, #e5e7eb);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:transparent;flex-shrink:0}.wspx-learner-card.is-selected span{background:var(--teal, #14b8a6);border-color:var(--teal, #14b8a6);color:#fff}.wspx-dialog-planner-box{display:grid;gap:12px;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 12%,var(--border, #e5e7eb));background:color-mix(in srgb,var(--purple, #7c3aed) 4%,var(--surface, #fff));border-radius:18px;padding:14px}.wspx-switch-row{display:flex;gap:10px;align-items:flex-start}.wspx-switch-row input{margin-top:4px;accent-color:var(--purple, #7c3aed)}.wspx-switch-row strong,.wspx-switch-row small{display:block}.wspx-switch-row strong{color:var(--text, #111827);font-size:13px}.wspx-switch-row small{margin-top:3px;color:var(--text-muted, #64748b);font-size:12px;line-height:1.4}.wspx-date-field{display:grid;gap:6px}.wspx-date-field span{color:var(--text-muted, #64748b);font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:.06em}.wspx-date-field input{height:42px;border-radius:14px;border:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);color:var(--text, #111827);padding:0 12px;font:inherit;font-size:13px;font-weight:750}.wspx-dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.wspx-cancel-btn,.wspx-confirm-btn{padding:10px 18px;border-radius:var(--radius-sm, 14px);font:inherit;font-size:14px;font-weight:750;cursor:pointer}.wspx-cancel-btn{border:1px solid var(--border, #e5e7eb);background:transparent;color:var(--text, #111827)}.wspx-confirm-btn{border:none;background:var(--teal, #14b8a6);color:#fff}.wspx-confirm-btn:disabled{opacity:.55;cursor:not-allowed}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:1180px){.wspx-shell,.wspx-page.is-left-closed .wspx-shell,.wspx-page.is-right-closed .wspx-shell,.wspx-page.is-left-closed.is-right-closed .wspx-shell{grid-template-columns:1fr;gap:14px}.wspx-side-handle{display:none}.wspx-curriculum-rail:not(.is-open),.wspx-right-rail:not(.is-open){display:none}.wspx-curriculum-card,.wspx-right-rail{position:static;max-height:none}.wspx-curriculum-rail,.wspx-right-rail{opacity:1;pointer-events:auto}.wspx-curriculum-rail{order:1}.wspx-library{order:2}.wspx-right-rail{order:3}}@media(max-width:700px){.wspx-page{padding:12px}.wspx-header-stack{margin-top:10px}.wspx-hero{padding:18px;border-radius:22px 22px 0 0;flex-direction:column;align-items:stretch}.wspx-hero-actions{justify-content:flex-start;margin-left:0;align-self:stretch}.wspx-stats-band{padding:12px;border-radius:0 0 22px 22px}.wspx-stats-row{grid-template-columns:1fr;gap:8px}.wspx-stat-card{padding:10px}.wspx-library-grid{grid-template-columns:1fr}.wspx-sticky-selection-bar,.wspx-library-head,.wspx-dialog-head,.wspx-dialog-actions{align-items:stretch;flex-direction:column}.wspx-sticky-actions{width:100%}.wspx-sticky-actions button{flex:1}.wspx-learner-grid{grid-template-columns:1fr;max-height:42vh;overflow:auto}}.wspx-library{overflow:visible}.wspx-sticky-selection-bar{position:sticky;top:12px;z-index:80;margin:2px 0 4px}@media(max-width:1180px){.wspx-sticky-selection-bar{top:10px}}@media(max-width:700px){.wspx-sticky-selection-bar{top:8px}}.wspx-dialog-tools{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin:4px 0 10px}.wspx-dialog-tools button{border:1px solid rgba(124,58,237,.16);background:#f6f3ff;color:#5b21b6;border-radius:12px;min-height:34px;padding:0 12px;font:inherit;font-size:12px;font-weight:900;cursor:pointer}.wspx-date-mode-box{display:grid;gap:10px;margin-top:10px}.wspx-date-mode-row{display:flex;gap:10px;flex-wrap:wrap}.wspx-date-mode-row label{display:inline-flex;align-items:center;gap:6px;color:#334155;font-size:12px;font-weight:850}.wspx-date-mode-row input,.wspx-switch-row input{accent-color:#7c3aed}.wspx-child-date-list{display:grid;gap:8px}.wspx-child-date-list label{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:8px;align-items:center;color:#334155;font-size:12px;font-weight:850}.wspx-child-date-list label>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wspx-child-date-list input{height:38px;border:1px solid rgba(124,58,237,.16);border-radius:12px;padding:0 10px;font:inherit}.wspx-assigning-message{display:grid;gap:4px;margin-top:10px;padding:12px 13px;border-radius:15px;border:1px solid rgba(245,158,11,.28);background:#fff7ed;color:#7c2d12}.wspx-assigning-message strong{font-size:13px;font-weight:950}.wspx-assigning-message span{font-size:12px;line-height:1.45;font-weight:750}@media(max-width:640px){.wspx-child-date-list label{grid-template-columns:1fr}}.wspx-status-pill{display:inline-flex;align-items:center;width:fit-content;border-radius:999px;border:1px solid var(--border, #e5e7eb);padding:4px 8px;font-size:10px;font-weight:900;line-height:1}.wspx-status-pill.is-green{color:var(--green, #149667);background:color-mix(in srgb,var(--green, #149667) 10%,transparent);border-color:color-mix(in srgb,var(--green, #149667) 22%,var(--border, #e5e7eb))}.wspx-status-pill.is-blue{color:#2563eb;background:color-mix(in srgb,#2563eb 9%,transparent);border-color:color-mix(in srgb,#2563eb 22%,var(--border, #e5e7eb))}.wspx-status-pill.is-teal{color:var(--teal, #159e9b);background:color-mix(in srgb,var(--teal, #159e9b) 10%,transparent);border-color:color-mix(in srgb,var(--teal, #159e9b) 22%,var(--border, #e5e7eb))}.wspx-status-pill.is-muted{color:var(--text-muted, #64748b);background:var(--surface2, #f8fafc)}.wspx-repeat-btn{background:linear-gradient(135deg,var(--purple, #7c3aed) 0%,color-mix(in srgb,var(--purple, #7c3aed) 80%,var(--teal, #159e9b)) 100%)}.wspx-change-planner-btn{min-width:auto;padding-inline:9px}.wspx-my-work-tools{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin-left:auto}.wspx-my-work-tool{padding:6px 10px;border-radius:999px;font-size:11px;font-weight:800;border:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);color:var(--text-muted, #64748b);cursor:pointer;font-family:inherit}.wspx-my-work-tool:disabled{opacity:.55;cursor:not-allowed}.wspx-my-work-select{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--text-muted, #64748b)}.wspx-my-work-select input{accent-color:var(--purple, #7c3aed)}@media(max-width:700px){.wspx-my-work-tools{justify-content:flex-start;margin-left:0;width:100%}}.wspx-icon-btn{min-width:34px;height:34px;padding:0;border-radius:10px;border:1px solid var(--border, #e5e7eb);background:var(--surface, #ffffff);color:var(--text-muted, #64748b);font-size:15px;font-weight:900;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center}.wspx-calendar-btn{border-color:color-mix(in srgb,var(--purple, #7c3aed) 16%,var(--border, #e5e7eb));background:color-mix(in srgb,var(--purple, #7c3aed) 6%,var(--surface, #ffffff));color:var(--purple, #7c3aed)}.wspx-dialog--compact{width:min(460px,94vw)}.wspx-library-view-controls{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin:4px 0 10px}.wspx-library-view-controls>span{margin-right:auto;color:var(--text-muted, #64748b);font-size:12px;font-weight:800}.wspx-library-view-controls button{padding:7px 11px;border-radius:999px;border:1px solid var(--border, #e5e7eb);background:var(--surface, #ffffff);color:var(--text-muted, #64748b);font-size:11px;font-weight:800;cursor:pointer;font-family:inherit}.wspx-skill-mode-list{display:grid;gap:14px;padding-bottom:8px}.wspx-skill-mode-card{border-radius:22px;border:1px solid color-mix(in srgb,var(--purple, #7c3aed) 14%,var(--border, #e5e7eb));background:linear-gradient(180deg,color-mix(in srgb,var(--surface, #fff) 96%,var(--purple-l, #ede9fe)) 0%,var(--surface, #fff) 100%);box-shadow:var(--shadow-sm, 0 8px 22px rgba(15, 23, 42, .04));padding:16px;display:grid;gap:12px}.wspx-skill-mode-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.wspx-skill-mode-title-block{display:grid;gap:8px;min-width:0;flex:1 1 360px}.wspx-skill-mode-title{font-size:20px;line-height:1.16;color:var(--text, #111827);font-weight:950}.wspx-skill-mode-path{margin:0;color:var(--text-muted, #64748b);font-size:12px;line-height:1.45;font-weight:750}.wspx-skill-mode-toggle{padding:10px 14px;border-radius:12px;border:1px solid var(--border, #e5e7eb);background:#fff;color:var(--text, #111827);font-size:12px;font-weight:850;cursor:pointer;font-family:inherit}.wspx-mode-row,.wspx-detail-type-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.wspx-mode-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 11px;border-radius:999px;border:1px solid var(--border, #e5e7eb);font-size:12px;font-weight:900;line-height:1}.wspx-mode-pill.is-available{background:color-mix(in srgb,var(--purple, #7c3aed) 9%,#fff);color:var(--purple, #7c3aed);border-color:color-mix(in srgb,var(--purple, #7c3aed) 22%,var(--border, #e5e7eb))}.wspx-mode-pill.is-unavailable{background:var(--surface2, #f8fafc);color:var(--text-muted, #64748b);opacity:.48}.wspx-detail-type-label{font-size:11px;font-weight:900;color:var(--text-muted, #64748b);text-transform:uppercase;letter-spacing:.06em;margin-right:2px}.wspx-detail-type-chip{display:inline-flex;padding:4px 9px;border-radius:999px;background:#fff;border:1px solid var(--border, #e5e7eb);color:var(--text, #111827);font-size:11px;font-weight:800}.wspx-activity-type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}.wspx-activity-type-card{display:grid;gap:10px;padding:12px;border-radius:16px;border:1px solid var(--border, #e5e7eb);background:#fff;box-shadow:0 4px 14px #0f172a09}.wspx-activity-type-card.is-selected{border:2px solid var(--teal, #14b8a6);box-shadow:0 8px 22px #14b8a61f}.wspx-activity-type-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.wspx-activity-type-head strong{display:block;font-size:15px;font-weight:950;color:var(--text, #111827);line-height:1.22}.wspx-activity-type-head span:not(.wspx-emoji-box){display:block;margin-top:3px;font-size:11px;font-weight:900;color:var(--purple, #7c3aed)}.wspx-activity-type-card p{margin:0;color:var(--text-muted, #64748b);font-size:12px;line-height:1.45}.wspx-activity-type-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.wspx-skill-mode-summary{padding:10px 12px;border-radius:14px;background:var(--surface2, #f8fafc);color:var(--text-muted, #64748b);font-size:12px;font-weight:750;border:1px dashed var(--border, #e5e7eb)}@media(max-width:700px){.wspx-activity-type-grid{grid-template-columns:1fr}.wspx-skill-mode-toggle,.wspx-activity-type-footer .wspx-select-btn{width:100%}}.wspx-activity-choice-panel{display:grid;gap:8px;padding-top:2px}.wspx-activity-chip-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.wspx-activity-select-chip{display:inline-flex;flex-direction:column;align-items:flex-start;gap:3px;min-width:132px;padding:9px 12px;border-radius:14px;border:1px solid var(--border, #e5e7eb);background:#fff;color:var(--text, #111827);cursor:pointer;font-family:inherit;box-shadow:0 4px 12px #0f172a09;text-align:left}.wspx-activity-select-chip.is-selected{border:2px solid var(--teal, #14b8a6);background:color-mix(in srgb,var(--teal, #14b8a6) 8%,#fff);box-shadow:0 8px 20px #14b8a61f}.wspx-activity-select-chip span{font-size:12px;font-weight:950;line-height:1.2;color:var(--text, #111827)}.wspx-activity-select-chip small{font-size:10px;font-weight:850;line-height:1.25;color:var(--purple, #7c3aed);white-space:normal}@media(max-width:700px){.wspx-activity-select-chip{width:100%}}.wspx-mode-pill-button{cursor:pointer;font-family:inherit}.wspx-mode-pill-button.is-selected{background:linear-gradient(135deg,var(--purple, #7c3aed) 0%,color-mix(in srgb,var(--purple, #7c3aed) 78%,var(--teal, #14b8a6)) 100%);color:#fff;border-color:var(--purple, #7c3aed);box-shadow:0 8px 18px #7c3aed2e}.shell{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.page-tab-bar{flex-shrink:0}[data-fullscreen] .page-tab-bar{display:none!important}[data-perspective=student] .page-tab-bar{display:none}.topbar{height:var(--topbar-h);flex-shrink:0;width:100%;background:var(--brand-bg);border-bottom:none;box-shadow:0 2px 12px #00000059;display:flex;align-items:center;padding:0 14px;gap:8px;z-index:100;position:relative;transition:background .2s ease-in-out}.body-row{display:flex;flex:1;overflow:hidden;min-height:0}.icon-rail{width:var(--rail-w);flex-shrink:0;height:100%;background:var(--brand-bg);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;padding:6px 0;gap:1px;z-index:90;transition:background .2s ease-in-out}.main-canvas{flex:1;height:100%;position:relative;overflow:hidden;background:var(--wb-bg);padding-bottom:var(--toolbar-h);transition:background .2s ease-in-out}[data-perspective=student] .icon-rail{display:none}[data-perspective=student] .main-canvas{flex:1;padding-bottom:0}[data-fullscreen] .topbar,[data-fullscreen] .icon-rail{display:none!important}[data-fullscreen] .pen-toolbar{position:fixed;bottom:24px;left:50%;right:auto;width:auto;height:auto;transform:translate(-50%);padding:6px 10px;border-radius:var(--radius-pill, 999px);border:1px solid var(--brand-border);overflow:visible;box-shadow:0 4px 28px #0000008c,0 2px 8px #0000004d;z-index:250}[data-fullscreen] .body-row{height:100vh}[data-fullscreen] .main-canvas{position:fixed;inset:0;z-index:200;width:100vw;height:100vh;padding-bottom:0}[data-perspective=student] .main-canvas,[data-toolbar-pill] .main-canvas,[data-toolbar-fab] .main-canvas{padding-bottom:0}[data-toolbar-pill] .zoom-controls{bottom:20px}.fullscreen-exit-btn{position:absolute;top:16px;right:16px;z-index:210;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#0f172a8c;color:#ffffffd9;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-pill, 999px);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-size:13px;font-weight:600;font-family:var(--font-body, sans-serif);cursor:pointer;-webkit-user-select:none;user-select:none;opacity:.55;transition:opacity .18s ease-out,background .18s ease-out,transform .12s ease-out}.fullscreen-exit-btn:hover{opacity:1;background:#dc2626cc;transform:scale(1.04)}.fullscreen-exit-btn:active{transform:scale(.97)}.topbar__icon-btn--fullscreen{font-size:20px}@media(max-width:767px){.shell{padding-bottom:56px}[data-fullscreen] .shell{padding-bottom:0}}[data-appview=dashboard] .zoom-controls{display:none!important}.board-empty-state{position:absolute;inset:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;padding-bottom:var(--toolbar-h, 56px)}.board-empty-state__logo{width:110px;height:110px;object-fit:contain;border-radius:0;opacity:.35;margin-bottom:-18px;filter:drop-shadow(0 4px 16px rgba(0,0,0,.08));-webkit-user-select:none;user-select:none;pointer-events:none}.board-empty-state__title{margin:0;font-size:18px;font-weight:600;color:var(--text-muted, #94a3b8);opacity:.45;letter-spacing:.01em;text-shadow:0 1px 3px rgba(255,255,255,.8),0 1px 3px rgba(0,0,0,.08)}.board-empty-state__sub{margin:3px 0 0;font-size:13px;color:var(--text-muted, #94a3b8);opacity:.35;text-shadow:0 1px 3px rgba(255,255,255,.8),0 1px 3px rgba(0,0,0,.08)}[data-fullscreen] .pen-toolbar .pen-toolbar__tool-btn{width:36px;height:36px;gap:0;flex-direction:row}[data-fullscreen] .pen-toolbar .pen-toolbar__tool-btn:after{display:none}[data-fullscreen] .pen-toolbar .pen-toolbar__group{background:transparent;border:none;padding:0;gap:2px}[data-fullscreen] .pen-toolbar .pen-toolbar__action-btn{min-width:36px;height:36px;padding:0 8px;font-size:12px}[data-fullscreen] .pen-toolbar .pen-toolbar__action-btn:after{display:none}.dr06-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9000}.dr06-dialog{background:var(--modal-bg, #fff);color:var(--text-primary, #1C2833);border-radius:12px;padding:24px 28px;max-width:380px;width:calc(100% - 40px);box-shadow:0 8px 32px #00000038}.dr06-dialog__title{margin:0 0 12px;font-size:16px;font-weight:600}.dr06-dialog__body{margin:0 0 20px;font-size:14px;line-height:1.55;color:var(--text-secondary, #475569)}.dr06-dialog__actions{display:flex;gap:10px;justify-content:flex-end}.dr06-dialog__btn{padding:8px 18px;border-radius:8px;border:none;font-size:14px;font-weight:500;cursor:pointer}.dr06-dialog__btn--cancel{background:var(--surface-2, #F1F5F9);color:var(--text-primary, #1C2833)}.dr06-dialog__btn--confirm{background:var(--accent, #6366F1);color:#fff}.dr06-dialog__btn--cancel:hover{background:var(--surface-3, #E2E8F0)}.dr06-dialog__btn--confirm:hover{filter:brightness(1.08)}.topbar__logo{display:flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;transition:opacity .12s ease}.topbar__logo:hover{opacity:.85}.topbar__logo--static{cursor:default;pointer-events:none}.topbar__logo-img{width:70px;height:70px;object-fit:contain;flex-shrink:0}.topbar__logo-text{display:flex;flex-direction:column;align-items:flex-start;gap:1px;overflow:hidden}.topbar__logo-name{font-family:var(--font);font-size:15px;font-weight:900;color:var(--brand-text);letter-spacing:-.3px;white-space:nowrap;line-height:1.2}.topbar__logo-sub{font-family:var(--font-body);font-size:9.5px;font-weight:600;color:var(--brand-text-muted);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;opacity:.7;line-height:1}.topbar__logo-icon{font-size:22px;line-height:1}.topbar__chip{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-pill);font-family:var(--font);font-size:12px;font-weight:700;flex-shrink:1;min-width:0;white-space:nowrap;overflow:hidden;cursor:default;transition:background .12s ease}.topbar__chip span:last-child{overflow:hidden;text-overflow:ellipsis;min-width:0}.topbar__chip--tutor{background:#ffffff1f;border:1px solid rgba(255,255,255,.18);color:var(--brand-text)}.topbar__chip--tutor:hover{background:#ffffff2e}.topbar__chip--student{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:var(--brand-text-sub)}.topbar__chip--student:hover{background:#ffffff29}.topbar__timer-wrap{position:relative;flex-shrink:0}.topbar__timer{font-family:Nunito Sans,monospace;font-size:12px;font-weight:700;color:var(--brand-text-sub);padding:5px 10px;border-radius:var(--radius-pill);background:#ffffff14;border:1px solid rgba(255,255,255,.12);cursor:pointer;transition:background .12s ease,color .12s ease;letter-spacing:.5px;min-width:72px;text-align:center}.topbar__timer:hover{background:#ffffff24;color:var(--brand-text)}.topbar__timer--confirm{background:#a78bfa40;color:var(--brand-accent);border:1px solid rgba(167,139,250,.4)}.topbar__timer--confirm:hover{background:#a78bfa59}.topbar__timer-tooltip{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep);color:var(--brand-text);font-family:var(--font-body);font-size:11px;font-weight:600;padding:3px 8px;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;animation:timerTooltipIn .15s ease forwards;z-index:9999;border:1px solid var(--brand-border)}.topbar__timer-tooltip:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-bottom-color:var(--brand-bg-deep)}@media(prefers-reduced-motion:no-preference){@keyframes timerTooltipIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}}.topbar__spacer{flex:1;min-width:0}.topbar__controls-group{display:flex;align-items:center;gap:2px;flex-shrink:0}.topbar__sep{display:none}.topbar__icon-btn{width:30px;height:30px;border-radius:7px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fffc;flex-shrink:0;transition:background .15s ease,color .15s ease}.topbar__icon-btn svg{width:18px;height:18px;flex-shrink:0;shape-rendering:geometricPrecision}.topbar__icon-btn:hover{background:#ffffff1f;color:#fff}.topbar__avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;cursor:pointer;transition:opacity .12s ease}.topbar__avatar:hover{opacity:.85}.topbar__avatar--tutor{background:#ffffff26;border:1.5px solid rgba(255,255,255,.25)}.topbar__avatar--student{background:#ffffff1f;border:1.5px solid rgba(255,255,255,.18)}.topbar__stars{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-pill);background:#fde04733;border:1px solid rgba(253,224,71,.35);font-family:var(--font);font-size:12px;font-weight:800;color:#fde047;flex-shrink:0;transition:transform .1s ease-out}.topbar__stars--pop{animation:star-pop .2s ease-out forwards}@media(prefers-reduced-motion:no-preference){@keyframes star-pop{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}}.topbar__icon-btn--active{background:#a78bfa40;color:var(--brand-accent);border:1.5px solid rgba(167,139,250,.4)}.topbar__icon-btn--active:hover{background:#a78bfa59}.topbar__icon-btn--recording{background:#ef444433;color:#fca5a5;border:1.5px solid rgba(239,68,68,.35)}.topbar__icon-btn--recording:hover{background:#ef44444d}@media(prefers-reduced-motion:no-preference){.topbar__icon-btn--recording{animation:rec-pulse 1.4s ease-in-out infinite}@keyframes rec-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef444400}}}.ie-wrap{position:relative;flex-shrink:0}.ie-trigger svg{transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.ie-trigger--open svg{transform:rotate(180deg)}.ie-panel{position:absolute;top:calc(100% + 8px);right:0;width:256px;background:var(--modal-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:10px;z-index:500;animation:ie-panel-in .16s cubic-bezier(.16,1,.3,1) both}@keyframes ie-panel-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ie-panel__section-header{padding:2px 8px 6px;display:flex;align-items:center}.ie-panel__badge{font-family:var(--font);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-pill)}.ie-panel__badge--import{background:var(--teal-xl);color:var(--teal-d);border:1px solid var(--teal-l)}.ie-panel__badge--export{background:var(--blue-l);color:var(--blue);border:1px solid #BFDBFE}[data-theme=dark] .ie-panel__badge--export{background:#1e3a5f;border-color:#2563eb4d}.ie-panel__divider{height:1px;background:var(--border);margin:6px 0}.ie-panel__items{display:flex;flex-direction:column;gap:2px}.ie-panel__item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;text-align:left;transition:background .1s ease,transform 80ms ease;color:var(--text)}.ie-panel__item:hover{background:var(--modal-surface2);transform:translate(2px)}.ie-panel__item:active{transform:translate(2px) scale(.98)}.ie-panel__item-icon{font-size:18px;line-height:1;flex-shrink:0;width:26px;text-align:center}.ie-panel__item-text{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.ie-panel__item-label{font-family:var(--font);font-size:13px;font-weight:700;color:var(--text);line-height:1.2}.ie-panel__item-sub{font-family:var(--font-body);font-size:11px;color:var(--text-muted);line-height:1.3}.ie-panel__item-arrow{font-size:16px;color:var(--text-muted);flex-shrink:0;opacity:0;transform:translate(-4px);transition:opacity .1s ease,transform .1s ease}.ie-panel__item:hover .ie-panel__item-arrow{opacity:1;transform:translate(0)}@media(max-width:1200px){.topbar__chip span:last-child{display:none}.topbar__chip{padding:5px 8px}}@media(max-width:1000px){.topbar__logo-text{display:none}.topbar__controls-group{gap:1px}}.ie-backdrop{position:fixed;inset:0;z-index:499;background:transparent;cursor:default}.topbar__icon-btn--more{font-size:20px;letter-spacing:1px;width:36px}.topbar-more-backdrop{position:fixed;inset:0;z-index:149;background:transparent}.topbar-more-sheet{position:fixed;top:calc(var(--topbar-h, 60px) + 4px);right:8px;z-index:500;width:240px;background:var(--modal-bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 32px #00000038,0 2px 8px #0000001f;padding:6px 0;overflow:visible;animation:topbar-more-in .16s cubic-bezier(.22,1,.36,1) both}@keyframes topbar-more-in{0%{transform:translateY(-8px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.topbar-more-sheet__item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 16px;border:none;background:transparent;color:var(--text);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;text-align:left;transition:background 80ms ease;-webkit-tap-highlight-color:transparent}.topbar-more-sheet__item:hover,.topbar-more-sheet__item:active{background:var(--surface2)}.topbar-more-sheet__item:disabled{opacity:.35;cursor:not-allowed}.topbar-more-sheet__item.is-active{color:var(--brand-accent)}.topbar-more-sheet__icon{font-size:18px;width:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.topbar-more-sheet__icon svg{width:18px;height:18px}.topbar-more-sheet__label{flex:1}.topbar-more-sheet__divider{height:1px;background:var(--border);margin:4px 0}@media(max-width:767px){.topbar-more-sheet .ie-panel{position:relative;top:auto;right:auto;width:100%;margin:0;border-radius:0 0 10px 10px;box-shadow:none;border:none;border-top:1px solid var(--border);animation:none}.topbar-more-sheet .ie-backdrop{display:none}}@media(max-width:767px){.topbar__chip,.topbar__timer-wrap{display:none}}.topbar__mode-switcher{display:flex;gap:2px;align-items:center;background:#0003;border-radius:18px;padding:2px;flex-shrink:0;border:1px solid rgba(255,255,255,.1);margin:0 4px}.topbar__mode-btn{width:28px;height:28px;border-radius:14px;border:none;background:transparent;color:#ffffff73;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease,box-shadow .15s ease;padding:0;line-height:1}.topbar__mode-btn:hover{color:#ffffffd9;background:#ffffff1a}.topbar__mode-btn--active{background:var(--brand-accent, #4A2DC4);color:#fff;box-shadow:0 1px 6px #4a2dc480}.topbar__mode-btn--active:hover{opacity:.92}@media(max-width:600px){.topbar__mode-switcher{padding:2px;gap:1px}.topbar__mode-btn{width:24px;height:24px;font-size:12px}}.topbar__game-mode{display:flex;gap:3px;align-items:center;background:#ffffff12;border-radius:10px;padding:3px;flex-shrink:0}.topbar__game-btn{padding:5px 13px;border-radius:7px;border:none;background:transparent;color:var(--brand-text-sub, rgba(255,255,255,.6));font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s;font-family:inherit}.topbar__game-btn:hover{background:#ffffff1a;color:var(--brand-text, #fff)}.topbar__game-btn--active{background:var(--game-color, var(--teal, #0D9488));color:#fff;box-shadow:0 1px 6px color-mix(in srgb,var(--game-color, #0D9488) 50%,transparent)}.topbar__game-btn--active:hover{opacity:.9}.topbar__game-btn:focus-visible{outline:2px solid var(--game-color, var(--teal, #0D9488));outline-offset:2px}.whiteboard-video-quick-controls{position:fixed;right:58px;bottom:8px;z-index:82;display:inline-flex;align-items:center;gap:4px;padding:2px;border-radius:10px;background:var(--brand-hover, rgba(255,255,255,.08));border:1px solid var(--brand-border, rgba(255,255,255,.14));box-shadow:0 2px 12px #0000002e;pointer-events:auto}.whiteboard-video-quick-controls__btn{position:relative;width:34px;height:34px;border:none;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--brand-text-sub, rgba(255,255,255,.72));cursor:pointer;transition:background .12s ease,color .12s ease,transform .12s ease}.whiteboard-video-quick-controls__btn:hover{background:var(--brand-active, rgba(255,255,255,.12));color:var(--brand-text, #fff);transform:translateY(-1px)}.whiteboard-video-quick-controls__btn.is-active{background:var(--brand-active, rgba(255,255,255,.14));color:var(--brand-accent, #a78bfa);box-shadow:inset 0 1px 0 var(--brand-border, rgba(255,255,255,.14))}.whiteboard-video-quick-controls__badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#f59e0b;color:#fff;font-size:10px;font-weight:900;line-height:16px;text-align:center;box-shadow:0 0 0 2px var(--brand-bg-deep, #1e0a4e);pointer-events:none}@media(max-width:767px){.whiteboard-video-quick-controls{display:none}}.settings-panel{position:absolute;top:0;right:0;bottom:0;width:300px;max-width:calc(100vw - 72px);background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:-4px 0 24px #0000001a;z-index:310;display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none;opacity:0;transform:translate(16px);transition:opacity .18s cubic-bezier(.4,0,.2,1),transform .18s cubic-bezier(.4,0,.2,1);pointer-events:none}.settings-panel.is-open{opacity:1;transform:translate(0);pointer-events:auto}@keyframes settings-panel-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.settings-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0;gap:12px}.settings-panel__header-left{display:flex;align-items:center;gap:14px}.settings-panel__header-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--brand-hover);color:var(--brand-text);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.settings-panel__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0 0 2px;font-family:var(--font-body, sans-serif);line-height:1.3}.settings-panel__subtitle{font-size:12px;color:var(--brand-text-sub);font-family:var(--font-body, sans-serif);margin:0}.settings-panel__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-sub);font-size:14px;cursor:pointer;transition:background .12s,color .12s;margin-left:auto;flex-shrink:0}.settings-panel__close:hover{background:#ffffff1f;color:var(--brand-text)}.settings-panel__body{flex:1;overflow-y:auto;padding:8px 0}.settings-panel__section{padding:12px 14px 4px}.settings-panel__section-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted, #94a3b8);font-family:var(--font-body, sans-serif);margin-bottom:8px}.settings-panel__row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border, #e2e8f0);gap:12px}.settings-panel__row:last-child{border-bottom:none}.settings-panel__row-info{flex:1;min-width:0}.settings-panel__row-label{font-size:13px;font-weight:600;color:var(--text, #1e293b);font-family:var(--font-body, sans-serif);line-height:1.3}.settings-panel__row-desc{font-size:11px;color:var(--text-sub, #64748b);font-family:var(--font-body, sans-serif);margin-top:3px;line-height:1.45}.settings-toggle{position:relative;flex-shrink:0;width:38px;height:22px;cursor:pointer}.settings-toggle input{opacity:0;width:0;height:0;position:absolute}.settings-toggle__track{position:absolute;inset:0;border-radius:var(--radius-pill);background:var(--border2, #cbd5e1);transition:background .2s}.settings-toggle input:checked+.settings-toggle__track{background:var(--brand-accent, #a78bfa)}.settings-toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #00000040}.settings-toggle input:checked+.settings-toggle__track:after{transform:translate(16px)}.settings-panel__section-desc{font-size:11px;color:var(--text-sub, #64748b);font-family:var(--font-body, sans-serif);margin:-4px 0 12px;line-height:1.5}.settings-theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:8px}.settings-theme-swatch{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 8px 9px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface2, #f1f5f9);cursor:pointer;transition:border-color .14s,background .14s,transform .1s;text-align:center;overflow:hidden}.settings-theme-swatch:hover{border-color:var(--brand-accent, #a78bfa);background:var(--modal-surface2, #f1f5f9);transform:translateY(-1px)}.settings-theme-swatch--active{border-color:var(--brand-accent, #a78bfa);background:var(--surface2, #f1f5f9);box-shadow:0 0 0 2px var(--brand-accent, #a78bfa)}.settings-theme-swatch__preview{width:100%;height:28px;border-radius:6px;display:flex;align-items:flex-end;padding:4px;position:relative;overflow:hidden;flex-shrink:0}.settings-theme-swatch__accent{height:7px;width:42%;border-radius:4px;opacity:.9}.settings-theme-swatch__icon{font-size:16px;line-height:1;flex-shrink:0}.settings-theme-swatch__label{font-size:11px;font-weight:700;color:var(--text-sub, #64748b);font-family:var(--font-body, sans-serif);letter-spacing:.01em;line-height:1.2}.settings-theme-swatch--active .settings-theme-swatch__label{color:var(--text, #1e293b)}.settings-theme-swatch__tick{position:absolute;top:5px;right:6px;width:16px;height:16px;border-radius:50%;background:var(--brand-accent, #a78bfa);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1}.settings-grid-row{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:8px}.settings-grid-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px 9px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface2, #f1f5f9);cursor:pointer;transition:border-color .14s,background .14s,transform .1s;text-align:center;overflow:hidden}.settings-grid-btn:hover{border-color:var(--brand-accent, #a78bfa);background:var(--modal-surface2, #f1f5f9);transform:translateY(-1px)}.settings-grid-btn--active{border-color:var(--brand-accent, #a78bfa);box-shadow:0 0 0 2px var(--brand-accent, #a78bfa)}.settings-grid-btn__icon{color:var(--text-sub, #64748b);display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-grid-btn--active .settings-grid-btn__icon{color:var(--text, #1e293b)}.settings-grid-btn__label{font-size:11px;font-weight:700;color:var(--text-sub, #64748b);font-family:var(--font-body, sans-serif);letter-spacing:.01em;line-height:1.2}.settings-grid-btn--active .settings-grid-btn__label{color:var(--text, #1e293b)}.settings-grid-size-row{display:flex;align-items:center;gap:6px;margin-top:8px;margin-bottom:4px}.settings-grid-size-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted, #94a3b8);font-family:var(--font-body, sans-serif);margin-right:2px}.settings-grid-size-btn{width:36px;height:30px;border-radius:7px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface2, #f1f5f9);color:var(--text-sub, #64748b);font-family:var(--font, sans-serif);font-size:12px;font-weight:700;cursor:pointer;transition:border-color .14s,background .14s}.settings-grid-size-btn:hover{border-color:var(--brand-accent, #a78bfa);color:var(--text, #1e293b)}.settings-grid-size-btn--active{border-color:var(--brand-accent, #a78bfa);background:var(--surface2, #f1f5f9);box-shadow:0 0 0 2px var(--brand-accent, #a78bfa);color:var(--text, #1e293b)}@media(max-width:767px){.settings-panel{position:fixed;top:var(--topbar-h, 60px);right:0;bottom:56px;width:100vw;max-width:100vw;z-index:200}}.settings-panel__controls{display:flex;align-items:center;gap:0;padding:6px 14px;border-bottom:1px solid var(--border, #e2e8f0);background:var(--surface2, #f8fafc);flex-shrink:0}.settings-ctrl-btn{flex:1;padding:5px 0;border:none;background:transparent;color:var(--brand-accent, #a78bfa);font-size:11px;font-weight:700;font-family:var(--font-body, sans-serif);cursor:pointer;text-align:center;transition:color .12s,opacity .12s;border-radius:6px}.settings-ctrl-btn:hover:not(:disabled){color:var(--text, #1e293b);background:var(--border, #e2e8f0)}.settings-ctrl-btn:disabled{opacity:.3;cursor:default}.settings-ctrl-divider{width:1px;height:14px;background:var(--border, #e2e8f0);flex-shrink:0}.settings-section{border-bottom:1px solid var(--border, #e2e8f0)}.settings-section:last-child{border-bottom:none}.settings-section__header{display:flex;align-items:center;gap:8px;width:100%;padding:11px 14px;border:none;background:transparent;cursor:pointer;text-align:left;transition:background .12s;min-height:42px}.settings-section__header:hover,.settings-section--open .settings-section__header{background:var(--surface2, #f8fafc)}.settings-section__title{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text, #1e293b);font-family:var(--font-body, sans-serif);flex-shrink:0}.settings-section__summary{flex:1;font-size:11px;font-weight:500;color:var(--text-muted, #94a3b8);font-family:var(--font-body, sans-serif);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:4px}.settings-section__chevron{font-size:11px;color:var(--text-muted, #94a3b8);flex-shrink:0;margin-left:auto;transition:color .12s}.settings-section--open .settings-section__chevron{color:var(--text-sub, #64748b)}.settings-section__body{padding:4px 14px 14px;animation:settings-section-open .16s cubic-bezier(.16,1,.3,1)}@keyframes settings-section-open{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-toolbar-row{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:8px}.settings-toolbar-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:7px;padding:12px 6px 10px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface2, #f1f5f9);cursor:pointer;transition:border-color .14s,background .14s,transform .1s;text-align:center;overflow:hidden}.settings-toolbar-btn:hover{border-color:var(--brand-accent, #a78bfa);transform:translateY(-1px)}.settings-toolbar-btn--active{border-color:var(--brand-accent, #a78bfa);box-shadow:0 0 0 2px var(--brand-accent, #a78bfa)}.settings-toolbar-btn__icon{color:var(--text-sub, #64748b);display:flex;align-items:center;justify-content:center}.settings-toolbar-btn--active .settings-toolbar-btn__icon{color:var(--teal, #0D9488)}.settings-toolbar-btn__label{font-size:11px;font-weight:700;color:var(--text-sub, #64748b);font-family:var(--font-body, sans-serif);letter-spacing:.01em}.settings-toolbar-btn--active .settings-toolbar-btn__label{color:var(--text, #1e293b)}.pen-toolbar{position:fixed;bottom:0;left:var(--rail-w);right:0;height:var(--toolbar-h);z-index:50;display:flex;align-items:center;gap:4px;padding:0 14px;overflow:visible;background:var(--brand-bg-deep);border-top:1px solid var(--brand-border);box-shadow:0 -4px 20px #00000059;pointer-events:all;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .2s ease-in-out,border-color .2s ease-in-out}.pen-toolbar__group{display:flex;align-items:center;gap:1px;background:var(--brand-hover);border:1px solid var(--brand-border);border-radius:8px;padding:2px;flex-shrink:0}.pen-toolbar__divider{width:1px;height:24px;background:var(--brand-border);margin:0 6px;border-radius:1px;flex-shrink:0}.pen-toolbar__tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-width:36px;width:auto;padding:0 8px;height:42px;border:none;border-radius:6px;background:transparent;cursor:pointer;font-size:17px;transition:background .12s ease-out,transform .12s ease-out,color .12s;position:relative;color:var(--brand-text-sub);flex-shrink:0}.pen-toolbar__tool-btn:after{content:attr(title);font-size:8px;font-weight:600;font-family:var(--font-body, sans-serif);color:var(--brand-text-muted);text-transform:uppercase;letter-spacing:.4px;line-height:1;pointer-events:none;white-space:nowrap}.pen-toolbar__tool-btn.is-text-icon{font-size:15px;font-weight:700;font-family:var(--font-body, sans-serif);color:var(--brand-text-muted)}.pen-toolbar__tool-btn:hover{background:var(--brand-hover);color:var(--brand-text);transform:scale(1.05)}.pen-toolbar__tool-btn:hover:after{color:var(--brand-text-sub)}.pen-toolbar__tool-btn.is-active{background:var(--brand-hover);box-shadow:inset 0 1px 0 var(--brand-border);color:var(--brand-accent)}.pen-toolbar__tool-btn.is-active:after{color:var(--brand-accent);font-weight:800}.pen-toolbar__tool-btn.is-amber{color:var(--amber)}.pen-toolbar__tool-btn.is-amber.is-active{background:var(--brand-hover);box-shadow:inset 0 1px 0 var(--brand-border);color:var(--amber)}.pen-toolbar__tool-btn.is-amber.is-active:after{color:var(--amber)}.pen-toolbar__colour-group{position:relative}.pen-toolbar__colour-trigger{display:flex;align-items:center;gap:4px;padding:4px 8px;border:1.5px solid var(--brand-border);border-radius:var(--radius-sm);background:var(--brand-hover);cursor:pointer;transition:background .12s ease-out,border-color .12s ease-out,transform .12s ease-out}.pen-toolbar__colour-trigger:hover{background:var(--brand-active);border-color:var(--brand-accent);transform:scale(1.04)}.pen-toolbar__colour-trigger.is-open{background:var(--brand-active);border-color:var(--brand-accent)}.pen-toolbar__colour-dot{display:block;width:20px;height:20px;border-radius:50%;background:var(--trigger-color, #1E293B);border:2px solid var(--brand-border);box-shadow:0 0 0 1px #0000004d;flex-shrink:0}.pen-toolbar__colour-chevron{font-size:7px;color:var(--brand-text-muted);line-height:1;transition:transform .15s ease-out,color .12s}.pen-toolbar__colour-trigger.is-open .pen-toolbar__colour-chevron{transform:rotate(180deg);color:var(--brand-accent)}.pen-toolbar__btn-wrap{position:relative;display:flex}.pen-popover{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(calc(-50% + var(--pen-nudge, 0px)));z-index:200;min-width:200px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #00000047;padding:12px;display:flex;flex-direction:column;gap:10px;animation:pen-pop-in .14s cubic-bezier(.34,1.4,.64,1) both}@keyframes pen-pop-in{0%{opacity:0;transform:translate(calc(-50% + var(--pen-nudge, 0px))) translateY(6px) scale(.96)}to{opacity:1;transform:translate(calc(-50% + var(--pen-nudge, 0px))) translateY(0) scale(1)}}.pen-popover:after{content:"";position:absolute;bottom:-6px;left:var(--arrow-left, 50%);transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.pen-popover__title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-text-muted);margin:0}.pen-popover__swatches{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.pen-popover__dot{width:22px;height:22px;border-radius:50%;background:var(--dot-color);border:2px solid transparent;padding:0;cursor:pointer;outline:2px solid transparent;outline-offset:2px;transition:transform 80ms ease,outline-color 80ms ease}.pen-popover__dot.is-highlight{border-radius:6px}.pen-popover__dot:hover{transform:scale(1.15)}.pen-popover__dot.is-active{outline-color:var(--brand-text);transform:scale(1.1)}.pen-popover__custom-row{display:flex;align-items:center;gap:8px;position:relative;cursor:pointer;padding:5px 4px;border-radius:6px;margin-top:2px;transition:background 80ms ease}.pen-popover__custom-row:hover{background:var(--brand-hover, rgba(0,0,0,.06))}.pen-popover__custom-row input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}.pen-popover__custom-swatch{width:22px;height:22px;border-radius:50%;border:2px solid var(--brand-border);display:block;flex-shrink:0}.pen-popover__custom-label{font-size:11px;font-weight:500;color:var(--brand-text-muted, #64748b);white-space:nowrap}.pen-popover__width-row{display:flex;align-items:center;gap:8px}.pen-popover__width-icon{flex-shrink:0;color:var(--brand-text-muted)}.pen-popover__slider{flex:1;height:4px;accent-color:var(--brand-accent)}.pen-popover__width-val{font-size:10px;font-weight:700;color:var(--brand-text-muted);min-width:28px;text-align:right}.pen-popover__presets{border-top:1px solid var(--brand-border);padding-top:8px;display:flex;flex-direction:column;gap:6px}.pen-popover__presets-header{display:flex;align-items:center;justify-content:space-between}.pen-popover__presets-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-text-muted)}.pen-popover__presets-save{font-size:10px;font-weight:700;color:var(--brand-accent);background:transparent;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background 80ms ease}.pen-popover__presets-save:hover{background:var(--brand-active)}.pen-popover__presets-empty{font-size:10px;color:var(--brand-text-muted);opacity:.6}.pen-popover__presets-dots{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.pen-popover__preset-wrap{position:relative;display:inline-flex}.pen-popover__preset-dot{width:22px;height:22px;border-radius:50%;background:var(--dot-color);border:2px solid transparent;cursor:pointer;padding:0;outline:2px solid transparent;outline-offset:2px;transition:transform 80ms ease,outline-color 80ms ease}.pen-popover__preset-dot.is-active{outline-color:var(--brand-text)}.pen-popover__preset-delete{position:absolute;top:-4px;right:-4px;width:12px;height:12px;border-radius:50%;background:var(--brand-bg-deep, var(--brand-bg));border:1px solid var(--brand-border);color:var(--brand-text-muted);font-size:9px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0}.pen-popover__preset-wrap:hover .pen-popover__preset-delete{display:flex}.fill-popover{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);z-index:200;min-width:186px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #00000047;padding:12px;display:flex;flex-direction:column;gap:10px;animation:fill-pop-in .14s cubic-bezier(.34,1.4,.64,1) both}@keyframes fill-pop-in{0%{opacity:0;transform:translate(-50%) translateY(6px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.fill-popover:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.fill-popover__title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-text-muted);margin:0}.fill-popover__swatches{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.fill-popover__dot{width:22px;height:22px;border-radius:50%;background:var(--dot-color);border:2px solid transparent;padding:0;cursor:pointer;outline:2px solid transparent;outline-offset:2px;transition:transform 80ms ease,outline-color 80ms ease}.fill-popover__dot:hover{transform:scale(1.15)}.fill-popover__dot.is-active{outline-color:var(--brand-text);transform:scale(1.1)}.fill-popover__custom-row{display:flex;align-items:center;gap:8px;padding:6px 4px;border-top:1px solid var(--brand-border);cursor:pointer;position:relative;border-radius:6px;transition:background 80ms ease}.fill-popover__custom-row:hover{background:var(--brand-active)}.fill-popover__custom-row input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}.fill-popover__custom-swatch{width:22px;height:22px;border-radius:50%;border:2px solid var(--brand-border);display:block;flex-shrink:0}.fill-popover__custom-label{font-size:12px;font-weight:500;color:var(--brand-text-sub);line-height:1}.eraser-popover{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);z-index:200;min-width:186px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #00000047;padding:12px;display:flex;flex-direction:column;gap:10px;animation:eraser-pop-in .14s cubic-bezier(.34,1.4,.64,1) both}@keyframes eraser-pop-in{0%{opacity:0;transform:translate(-50%) translateY(6px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.eraser-popover:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.eraser-popover__title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-text-muted);margin:0}.eraser-popover__modes{display:flex;gap:6px}.eraser-popover__mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 10px;border:1.5px solid var(--brand-border);border-radius:8px;background:transparent;color:var(--brand-text-muted);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-body, sans-serif);transition:background .1s,color .1s,border-color .1s}.eraser-popover__mode-btn:hover{background:var(--brand-active);color:var(--brand-text);border-color:var(--brand-accent)}.eraser-popover__mode-btn.is-active{background:var(--brand-active);color:#fff;border-color:var(--brand-accent)}.eraser-popover__mode-label{line-height:1}.eraser-popover__width-row{display:flex;align-items:center;gap:8px}.eraser-popover__width-icon{flex-shrink:0;color:var(--brand-text-muted)}.eraser-popover__slider{flex:1;height:4px;accent-color:var(--brand-accent)}.eraser-popover__width-val{font-size:10px;font-weight:700;color:var(--brand-text-muted);min-width:28px;text-align:right}.colour-picker-panel{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);z-index:50;display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #00000073;animation:picker-pop .14s cubic-bezier(.34,1.56,.64,1) both;white-space:nowrap;min-width:max-content}@media(prefers-reduced-motion:no-preference){@keyframes picker-pop{0%{opacity:0;transform:translate(-50%) scale(.88)}to{opacity:1;transform:translate(-50%) scale(1)}}}.colour-picker-panel:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.colour-picker-panel__swatches{display:flex;align-items:center;gap:6px;justify-content:center}.colour-picker-panel__dot{width:26px;height:26px;border-radius:50%;border:2px solid transparent;background:var(--dot-color);cursor:pointer;padding:0;flex-shrink:0;outline:1.5px solid rgba(128,128,128,.25);outline-offset:1px;transition:transform .12s ease-out,border-color .12s ease-out,box-shadow .12s ease-out}.colour-picker-panel__dot:hover{transform:scale(1.2);outline-color:#80808080}.colour-picker-panel__dot.is-active{border-color:var(--brand-text);outline:none;box-shadow:0 0 0 2px var(--brand-bg-deep, var(--brand-bg)),0 0 0 4px var(--dot-color);transform:scale(1.12)}.colour-picker-panel__custom{position:relative;display:flex;align-items:center;gap:8px;cursor:pointer;padding-top:10px;border-top:1px solid var(--brand-border)}.colour-picker-panel__custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0;pointer-events:all}.colour-picker-panel__custom-swatch{display:block;width:20px;height:20px;border-radius:4px;border:1.5px solid var(--brand-border);flex-shrink:0;pointer-events:none;transition:transform .12s}.colour-picker-panel__custom:hover .colour-picker-panel__custom-swatch{transform:scale(1.1)}.colour-picker-panel__custom-label{font-size:12px;font-weight:500;color:var(--brand-text-muted);font-family:var(--font-body, sans-serif);pointer-events:none;transition:color .12s}.colour-picker-panel__custom:hover .colour-picker-panel__custom-label{color:var(--brand-text)}.colour-picker-panel__presets{border-top:1px solid var(--brand-border);padding-top:10px;margin-top:2px}.colour-picker-panel__presets-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.colour-picker-panel__presets-label{font-size:11px;font-weight:600;color:var(--brand-text-muted);text-transform:uppercase;letter-spacing:.04em;font-family:var(--font-body, sans-serif)}.colour-picker-panel__presets-save{font-size:11px;font-weight:700;color:var(--brand-accent);background:none;border:1px solid var(--brand-accent);cursor:pointer;padding:2px 7px;border-radius:20px;font-family:var(--font-body, sans-serif);transition:background .12s,color .12s}.colour-picker-panel__presets-save:hover{background:var(--brand-accent);color:var(--brand-bg-deep, var(--brand-bg))}.colour-picker-panel__presets-empty{font-size:11px;color:var(--brand-text-muted);font-style:italic;font-family:var(--font-body, sans-serif);opacity:.6}.colour-picker-panel__presets-dots{display:flex;flex-wrap:wrap;gap:6px}.colour-picker-panel__preset-wrap{position:relative}.colour-picker-panel__preset-dot{width:28px;height:28px;border-radius:50%;border:2px solid transparent;background:var(--dot-color, #1E293B);cursor:pointer;padding:0;outline:1.5px solid rgba(128,128,128,.25);outline-offset:1px;transition:transform .1s,border-color .1s}.colour-picker-panel__preset-dot:hover{transform:scale(1.15)}.colour-picker-panel__preset-dot.is-active{border-color:var(--brand-accent);outline:none;box-shadow:0 0 0 2px var(--brand-bg-deep, var(--brand-bg)),0 0 0 4px var(--brand-accent)}.colour-picker-panel__preset-delete{display:none;position:absolute;top:-5px;right:-5px;width:15px;height:15px;border-radius:50%;background:var(--brand-bg-deep, var(--brand-bg));border:1px solid var(--brand-border);color:var(--brand-text-muted);font-size:10px;line-height:1;cursor:pointer;align-items:center;justify-content:center;padding:0}.colour-picker-panel__preset-wrap:hover .colour-picker-panel__preset-delete{display:flex}.pen-toolbar__width-group{display:flex;align-items:center;gap:6px;padding:0 4px}.pen-toolbar__width-icon{flex-shrink:0;color:var(--brand-text-muted);display:flex;align-items:center}.pen-toolbar__width-slider{width:90px;height:4px;accent-color:var(--brand-accent);cursor:pointer;flex-shrink:0}.pen-toolbar__width-val{font-size:10px;font-weight:600;color:var(--brand-text-muted);min-width:26px;text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-body, sans-serif)}.pen-toolbar__action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-width:36px;width:auto;padding:0 8px;height:42px;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:16px;color:var(--brand-text-sub);transition:background .12s ease-out,color .12s,transform .12s ease-out;flex-shrink:0}.pen-toolbar__action-btn:after{content:attr(title);font-size:8px;font-weight:600;font-family:var(--font-body, sans-serif);color:var(--brand-text-muted);text-transform:uppercase;letter-spacing:.4px;line-height:1;pointer-events:none;white-space:nowrap}.pen-toolbar__action-btn:hover{background:var(--brand-hover);color:var(--brand-text);transform:scale(1.05)}.pen-toolbar__action-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.pen-toolbar__action-btn:disabled:hover{background:transparent;color:var(--brand-text-sub);transform:none}.pen-toolbar__action-btn--clear{color:var(--brand-text-muted)}.pen-toolbar__action-btn--clear:hover{background:var(--brand-hover);color:var(--brand-accent)}.pen-toolbar--pill .pen-toolbar__action-btn{width:36px;height:36px;min-width:36px;padding:0;gap:0;flex-direction:row}.pen-toolbar--pill .pen-toolbar__action-btn:after{display:none}.ptclear__backdrop{position:fixed;inset:0;z-index:9500;background:#00000052;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:16px;animation:ptclear-fade .14s ease}@keyframes ptclear-fade{0%{opacity:0}to{opacity:1}}.ptclear__modal{background:var(--brand-bg-deep, var(--brand-bg));border:1px solid var(--brand-border);border-radius:20px;box-shadow:0 16px 48px #0000002e;padding:22px 18px 16px;width:280px;max-width:100%;display:flex;flex-direction:column;gap:12px;animation:ptclear-pop .18s cubic-bezier(.34,1.56,.64,1)}@keyframes ptclear-pop{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ptclear__title{margin:0;font-size:14px;font-weight:700;color:var(--brand-text);text-align:center}.ptclear__options{display:flex;flex-direction:column;gap:7px}.ptclear__btn{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:12px;border:1.5px solid var(--brand-border);background:var(--modal-surface2);cursor:pointer;text-align:left;width:100%;transition:background .13s,border-color .13s,transform .1s;min-height:52px}.ptclear__btn:active{transform:scale(.97)}.ptclear__btn-icon{font-size:20px;line-height:1;flex-shrink:0;width:28px;text-align:center}.ptclear__btn-body{display:flex;flex-direction:column;gap:2px;min-width:0}.ptclear__btn-label{font-size:13px;font-weight:700;color:var(--brand-text);line-height:1.3;white-space:nowrap}.ptclear__btn-hint{font-size:11px;color:var(--brand-text-muted);line-height:1.3;white-space:nowrap}.ptclear__btn--drawings:hover{background:var(--brand-active);border-color:var(--brand-accent)}.ptclear__btn--drawings:hover .ptclear__btn-label{color:var(--brand-accent)}.ptclear__btn--all:hover{background:var(--brand-active);border-color:var(--brand-accent)}.ptclear__btn--all:hover .ptclear__btn-label{color:var(--brand-accent)}.ptclear__cancel{background:transparent;border:none;color:var(--brand-text-muted);font-size:13px;font-weight:600;cursor:pointer;padding:4px 0;text-align:center;transition:color .13s}.ptclear__cancel:hover{color:var(--brand-text)}@media(max-width:767px){.pen-toolbar{flex-wrap:wrap;bottom:12px;padding:5px 8px;max-width:calc(100vw - 24px)}.pen-toolbar__tool-btn,.pen-toolbar__action-btn{min-width:40px;min-height:40px}.ptclear__modal{width:100%;padding:20px 14px 14px}}@media(max-width:480px){.pen-toolbar{gap:1px;padding:4px 6px}.pen-toolbar__divider{margin:0 2px}}.eraser-mode-strip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:2px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:10px;padding:4px 6px;box-shadow:0 6px 24px #00000073;z-index:10;animation:eraser-strip-in .15s ease-out both}@keyframes eraser-strip-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.eraser-mode-strip__btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:7px;background:transparent;color:var(--brand-text-muted);cursor:pointer;transition:background .12s,color .12s;padding:0}.eraser-mode-strip__btn:hover{background:var(--brand-hover);color:var(--brand-text)}.eraser-mode-strip__btn.is-active{background:var(--brand-active);color:var(--brand-active-text)}.shape-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:14px;box-shadow:0 8px 32px #00000073;padding:10px;display:flex;flex-direction:column;gap:8px;animation:shape-strip-in .12s ease;z-index:20;width:230px}@keyframes shape-strip-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.shape-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.shape-strip__grid{display:grid;grid-template-columns:repeat(5,32px);gap:3px}.shape-strip__btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:7px;background:transparent;color:var(--brand-text-muted);cursor:pointer;transition:background .12s,color .12s;padding:0}.shape-strip__btn:hover{background:var(--brand-active);color:var(--brand-text)}.shape-strip__btn.is-active{background:var(--brand-active);color:#fff}.shape-strip__color-section{display:flex;align-items:center;gap:6px;padding-top:6px;border-top:1px solid var(--brand-border)}.shape-strip__color-label{font-size:10px;font-weight:600;color:var(--brand-text-muted);min-width:34px;letter-spacing:.03em}.shape-strip__color-swatches{display:flex;align-items:center;gap:3px;flex-wrap:wrap}.shape-strip__color-dot{width:18px;height:18px;border-radius:50%;background:var(--dot, #ccc);border:2px solid transparent;cursor:pointer;transition:transform 80ms,border-color 80ms;flex-shrink:0;padding:0;display:flex;align-items:center;justify-content:center}.shape-strip__color-dot:hover{transform:scale(1.15)}.shape-strip__color-dot.is-active{border-color:var(--brand-accent);transform:scale(1.1)}.shape-strip__color-dot--none{background:#fff;border-color:var(--brand-border);color:var(--brand-text-muted)}.shape-strip__color-dot--none.is-active{border-color:var(--brand-accent)}.shape-strip__color-custom{position:relative;width:18px;height:18px;cursor:pointer;flex-shrink:0}.shape-strip__color-custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0}.shape-strip__color-custom-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:1.5px dashed var(--brand-border);font-size:12px;color:var(--brand-text-muted);line-height:1;pointer-events:none}.shape-strip__opacity-row{display:flex;align-items:center;gap:6px;padding-top:4px}.shape-strip__opacity-label{font-size:10px;font-weight:600;color:var(--brand-text-muted);white-space:nowrap;min-width:34px;letter-spacing:.03em}.shape-strip__opacity-pct{font-size:10px;color:var(--brand-text-muted);min-width:28px;text-align:right}.shape-strip__sep{height:1px;background:var(--brand-border);margin:4px 0}.shape-strip__opacity-slider{flex:1;height:4px;accent-color:var(--brand-accent);cursor:pointer}.shape-strip__fill-btn{display:flex;align-items:center;gap:7px;padding:6px 10px;border:1.5px solid var(--brand-border);border-radius:7px;background:transparent;color:var(--brand-text-muted);font-size:11px;font-weight:600;font-family:var(--font-body, sans-serif);cursor:pointer;width:100%;transition:background .12s,border-color .12s,color .12s}.shape-strip__fill-btn:hover{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-text)}.shape-strip__fill-btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:#fff}.insert-strip__sticky-colors{display:flex;flex-wrap:wrap;gap:5px;padding-top:4px}.insert-strip__sticky-dot{width:22px;height:22px;border-radius:50%;background:var(--dot, #FEF08A);border:1.5px solid transparent;cursor:pointer;transition:transform 80ms ease,outline-color 80ms ease;padding:0}.insert-strip__sticky-dot:hover{transform:scale(1.12)}.insert-strip__sticky-dot.is-active{border-color:var(--brand-accent);transform:scale(1.1);outline:2px solid var(--brand-accent);outline-offset:1px}.insert-strip__sticky-custom{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1.5px dashed var(--brand-border);cursor:pointer;position:relative;color:var(--brand-text-muted);font-size:13px}.insert-strip__sticky-custom input[type=color]{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer}.select-mode-strip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:2px;background:var(--modal-surface2);border:1.5px solid var(--brand-border);border-radius:10px;padding:4px 6px;box-shadow:0 6px 24px #00000073;z-index:10;animation:eraser-strip-in .15s ease-out both}.select-mode-strip__btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:7px;background:transparent;color:var(--text, #475569);cursor:pointer;transition:background .12s,color .12s;padding:0}.select-mode-strip__btn:hover{background:var(--brand-bg-deep, var(--brand-bg))}.select-mode-strip__btn.is-active{background:color-mix(in srgb,var(--brand-accent) 18%,transparent);color:var(--brand-accent)}.pen-toolbar__presets-group{position:relative}.pen-toolbar__presets-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid transparent;border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:16px;color:var(--brand-text-muted);transition:background .12s ease-out,color .12s,border-color .12s,transform .12s ease-out}.pen-toolbar__presets-btn:hover{background:var(--brand-hover);color:var(--brand-text);transform:scale(1.08)}.pen-toolbar__presets-btn.is-open{background:var(--brand-active);color:var(--brand-accent);border-color:var(--brand-accent)}.pen-toolbar__presets-btn.has-active,.pen-toolbar__presets-btn.is-open.has-active{color:var(--brand-accent)}.preset-strip{position:absolute;bottom:calc(100% + 10px);right:50%;transform:translate(50%);z-index:50;display:flex;flex-direction:column;gap:10px;padding:10px 12px;min-width:max-content;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:14px;box-shadow:0 8px 32px #00000073;animation:preset-strip-in .15s cubic-bezier(.34,1.4,.64,1) both}@keyframes preset-strip-in{0%{opacity:0;transform:translate(50%) translateY(6px) scale(.95)}to{opacity:1;transform:translate(50%) translateY(0) scale(1)}}.preset-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.preset-strip__label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-text-muted);font-family:var(--font-body, sans-serif);padding-bottom:2px;border-bottom:1px solid var(--brand-border)}.preset-strip__dots{display:flex;align-items:center;gap:8px;flex-wrap:wrap;max-width:320px}.preset-strip__dot-wrap{position:relative;flex-shrink:0}.preset-strip__dot{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:2.5px solid transparent;background:var(--preset-color, #1E293B);cursor:pointer;padding:0;flex-shrink:0;position:relative;transition:transform .13s ease-out,border-color .13s ease-out,box-shadow .13s ease-out;overflow:visible}.preset-strip__dot:hover{transform:scale(1.1);box-shadow:0 3px 10px #0000002e}.preset-strip__dot.is-active{border-color:#fff;box-shadow:0 0 0 2.5px var(--preset-color, #1E293B),0 3px 10px #0000002e;transform:scale(1.08)}.preset-strip__tool-icon{position:absolute;bottom:-4px;right:-4px;font-size:13px;line-height:1;background:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #00000026;pointer-events:none}.preset-strip__delete{position:absolute;top:-5px;right:-5px;z-index:2;display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:none;background:var(--brand-bg-deep, var(--brand-bg));color:var(--brand-text);font-size:11px;line-height:1;cursor:pointer;padding:0;opacity:.75;transition:opacity .12s,transform .12s,background .12s}.preset-strip__delete:hover{opacity:1;background:var(--brand-accent);transform:scale(1.15)}.preset-strip__save{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:44px;height:44px;border-radius:50%;border:2px dashed var(--brand-border);background:transparent;cursor:pointer;padding:0;flex-shrink:0;color:var(--brand-text-muted);transition:border-color .13s,color .13s,background .13s,transform .13s}.preset-strip__save:hover{border-color:var(--brand-accent);color:var(--brand-accent);background:var(--brand-hover);transform:scale(1.08)}.preset-strip__save-icon{font-size:16px;line-height:1}.preset-strip__save-label{font-size:9px;font-weight:700;font-family:var(--font-body, sans-serif);letter-spacing:.04em;line-height:1}.preset-strip__full-msg{font-size:11px;color:var(--brand-text-muted);font-family:var(--font-body, sans-serif);padding:0 4px;align-self:center}.pen-toolbar__grid-group{position:relative}.pen-toolbar__grid-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-muted);cursor:pointer;transition:background .15s,color .15s;padding:0}.pen-toolbar__grid-btn:hover{background:var(--brand-active);color:var(--brand-text)}.pen-toolbar__grid-btn.is-active{color:var(--brand-accent)}.pen-toolbar__grid-btn.is-open{background:var(--brand-active);color:var(--brand-accent)}.grid-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 28px #00000073;padding:10px 12px;display:flex;flex-direction:column;gap:8px;z-index:200;min-width:190px;white-space:nowrap}.grid-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.grid-strip__row{display:flex;align-items:center;gap:6px}.grid-strip__label{font-size:10px;font-weight:700;font-family:var(--font-body, sans-serif);color:var(--brand-text-muted);letter-spacing:.06em;text-transform:uppercase;width:32px;flex-shrink:0}.grid-strip__btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:5px 8px;border:1.5px solid var(--brand-border);border-radius:7px;background:transparent;color:var(--brand-text-muted);cursor:pointer;font-family:var(--font-body, sans-serif);transition:background .12s,border-color .12s,color .12s;min-width:42px;height:40px}.grid-strip__btn:hover{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-text)}.grid-strip__btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:#fff}.grid-strip__btn-label{font-size:9px;font-weight:700;line-height:1;letter-spacing:.03em}.grid-strip__btn--size{font-size:13px;font-weight:700;min-width:36px}.grid-strip__snap-btn{font-size:11px;font-weight:600;min-width:42px}.pen-toolbar__ruler-group{position:relative;display:flex;align-items:center;gap:2px}.pen-toolbar__ruler-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-muted);cursor:pointer;transition:background .15s,color .15s;padding:0}.pen-toolbar__ruler-btn:hover{background:var(--brand-active);color:var(--brand-text)}.pen-toolbar__ruler-btn.is-active{color:var(--brand-accent)}.pen-toolbar__ruler-btn.is-open{background:var(--brand-active)}.pen-toolbar__ruler-unit{display:flex;align-items:center;justify-content:center;height:36px;padding:0 4px;border:none;border-radius:0 8px 8px 0;background:transparent;color:var(--brand-text-muted);font-size:9px;font-weight:700;font-family:var(--font-body, sans-serif);letter-spacing:.04em;cursor:pointer;transition:background .15s,color .15s;min-width:20px}.pen-toolbar__ruler-unit:hover{background:var(--brand-active);color:var(--brand-accent)}.ruler-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 28px #00000073;padding:10px 12px;display:flex;align-items:center;gap:8px;z-index:200;white-space:nowrap}.ruler-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.ruler-strip__label{font-size:10px;font-weight:700;font-family:var(--font-body, sans-serif);color:var(--brand-text-muted);letter-spacing:.06em;text-transform:uppercase}.ruler-strip__btn{display:flex;align-items:center;justify-content:center;width:40px;height:36px;border:1.5px solid var(--brand-border);border-radius:7px;background:transparent;color:var(--brand-text-muted);font-size:12px;font-weight:600;font-family:var(--font-body, sans-serif);cursor:pointer;transition:background .12s,border-color .12s,color .12s}.ruler-strip__btn:hover{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-text)}.ruler-strip__btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:#fff}.pen-toolbar__canvas-group{position:relative;display:flex;align-items:center}.pen-toolbar__canvas-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-muted);cursor:pointer;transition:background .15s,color .15s;padding:0}.pen-toolbar__canvas-btn:hover{background:var(--brand-active);color:var(--brand-text)}.pen-toolbar__canvas-btn.is-active{color:var(--brand-accent)}.pen-toolbar__canvas-btn.is-open{background:var(--brand-active)}.canvas-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #00000073;padding:10px 12px;display:flex;flex-direction:column;gap:7px;z-index:200;min-width:210px;white-space:nowrap;animation:canvas-strip-in .12s ease both}@keyframes canvas-strip-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.canvas-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.canvas-strip__section-label{font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-accent);padding-bottom:1px}.canvas-strip__sep{height:1px;background:var(--brand-border);margin:2px 0}.canvas-strip__pan-btn{display:flex;align-items:center;gap:7px;padding:6px 10px;border:1.5px solid var(--brand-border);border-radius:7px;background:transparent;color:var(--brand-text-muted);font-size:11px;font-weight:600;font-family:var(--font-body, sans-serif);cursor:pointer;width:100%;transition:background .12s,border-color .12s,color .12s}.canvas-strip__pan-btn:hover{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-text)}.canvas-strip__pan-btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:#fff}.sticky-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:10px;box-shadow:0 8px 28px #00000073;display:flex;align-items:center;gap:5px;padding:6px 10px;white-space:nowrap;z-index:200;animation:strip-in .14s ease}.sticky-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.sticky-strip__label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fbbf2499;margin-right:2px}.sticky-strip__dot{width:22px;height:22px;border-radius:50%;background:var(--dot, #fff);border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:transform .1s,border-color .1s}.sticky-strip__dot.is-active{border-color:#fbbf24e6;transform:scale(1.2)}.sticky-strip__dot:hover{transform:scale(1.12)}.sticky-strip__custom{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1.5px dashed var(--brand-border);cursor:pointer;position:relative;overflow:hidden}.sticky-strip__custom input[type=color]{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.sticky-strip__custom-icon{font-size:13px;color:var(--brand-text-muted);line-height:1;pointer-events:none}.stamp-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #00000073;display:flex;flex-direction:column;gap:6px;padding:10px 12px;width:min(320px,90vw);z-index:200;animation:strip-in .14s ease}.stamp-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.stamp-strip__tabs{display:flex;gap:4px;border-bottom:1px solid var(--brand-border);padding-bottom:8px}.stamp-strip__tab{flex:1;min-height:36px;padding:4px 6px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-muted);font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s;touch-action:manipulation}.stamp-strip__tab.is-active{background:var(--brand-accent);color:#fff}.stamp-strip__tab:hover:not(.is-active){background:var(--brand-active)}.stamp-strip__grid{display:flex;flex-wrap:wrap;gap:4px;max-height:148px;overflow-y:auto;padding:3px}.stamp-strip__emoji{width:36px;height:36px;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;border:2px solid transparent;border-radius:8px;background:transparent;cursor:pointer;transition:background .1s,transform .1s,border-color .1s;touch-action:manipulation;flex-shrink:0}.stamp-strip__emoji:hover{background:var(--brand-active);transform:scale(1.15)}.stamp-strip__emoji.is-active{border-color:var(--brand-accent);background:var(--brand-active);transform:scale(1.1)}.stamp-strip__sizes{display:flex;align-items:center;gap:6px;border-top:1px solid var(--brand-border);padding-top:10px;margin-top:2px}.stamp-strip__label{font-size:11px;color:var(--brand-text-muted);margin-right:2px}.stamp-strip__size-btn{min-height:32px;padding:4px 14px;border:1.5px solid var(--brand-border);border-radius:8px;background:transparent;color:var(--brand-text);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,color .12s;touch-action:manipulation}.stamp-strip__size-btn:hover{background:var(--brand-active)}.stamp-strip__size-btn.is-active{background:var(--brand-accent);border-color:var(--brand-accent);color:var(--brand-active-text)}.pen-toolbar--pill{position:absolute;bottom:20px;left:50%;right:auto;width:auto;height:auto;transform:translate(-50%);padding:6px 10px;border-radius:var(--radius-pill);border:1px solid var(--brand-border);overflow:visible;box-shadow:0 4px 24px #00000073,0 2px 8px #0000004d}.pen-toolbar--pill .pen-toolbar__group{background:transparent;border:none;padding:0;gap:2px}.pen-toolbar--pill .pen-toolbar__tool-btn{width:36px;height:36px;gap:0;flex-direction:row}.pen-toolbar--pill .pen-toolbar__tool-btn:after{display:none}.pen-toolbar__style-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--brand-border);border-radius:6px;background:var(--brand-hover);color:var(--brand-text-muted);font-size:13px;cursor:pointer;flex-shrink:0;transition:background .12s,color .12s,transform .12s;margin-left:4px}.pen-toolbar__style-toggle:hover{background:var(--brand-hover);color:var(--brand-accent);transform:scale(1.1)}.pen-toolbar--pill .pen-toolbar__style-toggle{margin-left:4px;margin-right:6px}@media(max-width:767px){.pen-toolbar{display:none!important}}.mobile-fab{position:fixed;bottom:70px;right:16px;z-index:95;display:flex;align-items:center;gap:6px;padding:0 14px 0 10px;height:48px;border-radius:var(--radius-pill);background:var(--brand-bg);border:1.5px solid var(--brand-border);color:var(--brand-text);box-shadow:0 4px 20px #00000047,0 2px 6px #00000026;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease}.mobile-fab:active{transform:scale(.94);box-shadow:0 2px 8px #0003}.mobile-fab--open{box-shadow:0 2px 8px #0000002e}.mobile-fab__icon{font-size:22px;line-height:1;display:flex;align-items:center}.mobile-fab__icon svg{width:22px;height:22px}.mobile-fab__caret{font-size:10px;opacity:.6;line-height:1}.mobile-sheet-backdrop{position:fixed;inset:0;z-index:96;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-sheet{position:fixed;bottom:56px;left:0;right:0;z-index:97;background:var(--brand-bg-deep, var(--brand-bg));border-radius:20px 20px 0 0;border-top:1px solid var(--brand-border);box-shadow:0 -8px 40px #00000038;max-height:calc(75vh - 56px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:env(safe-area-inset-bottom,12px);animation:mobile-sheet-in .22s cubic-bezier(.22,1,.36,1) both}@keyframes mobile-sheet-in{0%{transform:translateY(100%);opacity:.6}to{transform:translateY(0);opacity:1}}.mobile-sheet__handle{width:40px;height:4px;border-radius:2px;background:var(--brand-border);margin:10px auto 4px;flex-shrink:0}.mobile-sheet__section{padding:10px 16px 12px;border-bottom:1px solid var(--brand-border)}.mobile-sheet__section:last-child{border-bottom:none}.mobile-sheet__section-label{font-family:var(--font-body);font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--brand-text-muted);margin-bottom:8px}.mobile-sheet__tool-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.mobile-sheet__tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px 8px;border-radius:10px;border:1.5px solid var(--brand-border);background:var(--brand-active);color:var(--brand-text-sub);cursor:pointer;transition:background .1s,border-color .1s,color .1s;-webkit-tap-highlight-color:transparent;min-height:60px}.mobile-sheet__tool-btn:active{background:var(--brand-border)}.mobile-sheet__tool-btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-active-text);box-shadow:0 0 0 2px var(--brand-accent)}.mobile-sheet__tool-icon{font-size:22px;line-height:1;display:flex;align-items:center}.mobile-sheet__tool-icon.is-text{font-family:var(--font);font-size:16px;font-weight:800}.mobile-sheet__tool-icon svg{width:22px;height:22px}.mobile-sheet__tool-label{font-family:var(--font-body);font-size:9px;font-weight:700;color:inherit;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.mobile-sheet__swatches{display:flex;flex-wrap:wrap;gap:8px}.mobile-sheet__swatch{width:30px;height:30px;border-radius:50%;border:2px solid transparent;background:var(--dot, #000);cursor:pointer;transition:transform 80ms ease,box-shadow 80ms ease;-webkit-tap-highlight-color:transparent;flex-shrink:0}.mobile-sheet__swatch:active{transform:scale(.88)}.mobile-sheet__swatch.is-active{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--brand-accent)}.mobile-sheet__swatch--none{background:var(--brand-active)!important;border:1.5px solid var(--brand-border);display:flex;align-items:center;justify-content:center;color:var(--brand-text-muted)}.mobile-sheet__swatch--none.is-active{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--brand-accent)}.mobile-sheet__swatch-custom{width:30px;height:30px;border-radius:50%;border:1.5px dashed var(--brand-border);background:var(--brand-active);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--brand-text-muted);cursor:pointer;overflow:hidden;position:relative;flex-shrink:0}.mobile-sheet__swatch-custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}.mobile-sheet__slider-row{display:flex;align-items:center;gap:10px}.mobile-sheet__slider{flex:1;height:4px;accent-color:var(--brand-accent);cursor:pointer}.mobile-sheet__btn-row{display:flex;flex-wrap:wrap;gap:7px}.mobile-sheet__mode-btn{padding:8px 16px;border-radius:var(--radius-pill);border:1.5px solid var(--brand-border);background:var(--brand-active);color:var(--brand-text-sub);font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;transition:background .1s,border-color .1s,color .1s;-webkit-tap-highlight-color:transparent;min-height:38px}.mobile-sheet__mode-btn:active{background:var(--brand-border)}.mobile-sheet__mode-btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-active-text);box-shadow:0 0 0 2px var(--brand-accent)}.mobile-sheet__shape-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.mobile-sheet__shape-btn{display:flex;align-items:center;justify-content:center;height:42px;border-radius:8px;border:1.5px solid var(--brand-border);background:var(--brand-active);color:var(--brand-text-sub);cursor:pointer;transition:background .1s,border-color .1s;-webkit-tap-highlight-color:transparent}.mobile-sheet__shape-btn.is-active{background:var(--brand-active);border-color:var(--brand-accent);color:var(--brand-active-text);box-shadow:0 0 0 2px var(--brand-accent)}.mobile-sheet__section--actions{display:flex;gap:8px;border-bottom:none}.mobile-sheet__action-btn{flex:1;padding:12px 8px;border-radius:var(--radius);border:1.5px solid var(--brand-border);background:var(--brand-active);color:var(--brand-text);font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;transition:background .1s,opacity .1s;-webkit-tap-highlight-color:transparent}.mobile-sheet__action-btn:active{background:var(--brand-border)}.mobile-sheet__action-btn:disabled{opacity:.35;cursor:not-allowed}.mobile-sheet__action-btn--clear{border-color:#ef444459;color:var(--brand-accent)}.mobile-sheet__action-btn--clear:active{background:var(--brand-hover)}@media(min-width:768px){.pen-toolbar--fab-mode{display:none!important}}.desktop-fab{position:fixed;bottom:24px;right:24px;z-index:95;display:flex;align-items:center;gap:6px;padding:0 14px 0 10px;height:44px;border-radius:var(--radius-pill);background:var(--brand-bg);border:1.5px solid var(--brand-border);color:var(--brand-text);box-shadow:0 4px 20px #00000047,0 2px 6px #00000026;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .12s ease,box-shadow .12s ease}.desktop-fab:hover{transform:scale(1.04);box-shadow:0 6px 24px #00000052}.desktop-fab--open{background:var(--brand-accent, #a78bfa);border-color:var(--brand-accent, #a78bfa);color:#fff}.desktop-fab__icon{font-size:20px;line-height:1;display:flex;align-items:center}.desktop-fab__caret{font-size:11px;opacity:.7}.desktop-fab-backdrop{position:fixed;inset:0;z-index:94;background:transparent}.desktop-fab-popover{position:fixed;bottom:76px;right:24px;z-index:96;width:240px;max-height:calc(100vh - 120px);overflow-y:auto;overflow-x:hidden;background:var(--brand-bg-deep, var(--brand-bg));border:1px solid var(--brand-border);border-radius:14px;box-shadow:0 8px 40px #00000038,0 2px 8px #0000001a;padding:8px 0 6px;scrollbar-width:thin;animation:fab-pop-in .15s cubic-bezier(.16,1,.3,1) both}@keyframes fab-pop-in{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.fab-pop__section{padding:6px 12px}.fab-pop__section--actions{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px 12px}.fab-pop__label{font-family:var(--font);font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-text-muted);margin-bottom:6px}.fab-pop__divider{height:1px;background:var(--brand-border);margin:4px 0}.fab-pop__tool-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.fab-pop__tool-btn{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border:none;border-radius:8px;background:transparent;cursor:pointer;transition:background .1s,transform 80ms;color:var(--brand-text)}.fab-pop__tool-btn:hover{background:var(--brand-active);transform:scale(1.08)}.fab-pop__tool-btn.is-active{background:var(--brand-hover);color:var(--brand-accent, #a78bfa);box-shadow:0 0 0 1.5px var(--brand-accent, #a78bfa)}.fab-pop__tool-icon{font-size:17px;line-height:1}.fab-pop__tool-icon.is-text{font-size:13px;font-weight:900;font-family:var(--font)}.fab-pop__swatches{display:flex;flex-wrap:wrap;gap:5px}.fab-pop__swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;background:var(--dot);cursor:pointer;transition:transform 80ms,border-color 80ms}.fab-pop__swatch:hover{transform:scale(1.15)}.fab-pop__swatch.is-active{border-color:var(--brand-accent, #a78bfa);transform:scale(1.1)}.fab-pop__swatch-custom{width:22px;height:22px;border-radius:50%;border:2px dashed var(--brand-border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;color:var(--brand-text-muted);overflow:hidden;transition:border-color .1s}.fab-pop__swatch-custom input[type=color]{position:absolute;opacity:0;width:1px;height:1px}.fab-pop__slider{width:100%;margin:4px 0 0;accent-color:var(--brand-accent)}.fab-pop__btn-row{display:flex;gap:6px}.fab-pop__mode-btn{flex:1;padding:5px 0;border:1px solid var(--brand-border);border-radius:var(--radius-sm, 6px);background:transparent;color:var(--brand-text-sub);font-size:11px;font-weight:700;cursor:pointer;transition:background .1s,color .1s}.fab-pop__mode-btn:hover{background:var(--brand-active)}.fab-pop__mode-btn.is-active{background:var(--brand-accent);color:#fff;border-color:var(--brand-accent)}.fab-pop__shape-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.fab-pop__shape-btn{display:flex;align-items:center;justify-content:center;aspect-ratio:1;border:1px solid var(--brand-border);border-radius:6px;background:transparent;cursor:pointer;color:var(--brand-text-sub);transition:background .1s;padding:4px}.fab-pop__shape-btn:hover{background:var(--brand-active)}.fab-pop__shape-btn.is-active{background:var(--brand-hover);border-color:var(--brand-accent, #a78bfa);color:var(--brand-accent, #a78bfa)}.fab-pop__action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;border:1px solid var(--brand-border);border-radius:var(--radius-sm, 6px);background:transparent;color:var(--brand-text-sub);cursor:pointer;text-align:center;transition:background .1s,color .1s}.fab-pop__action-icon{font-size:16px;line-height:1}.fab-pop__action-label{font-size:9px;font-weight:700;line-height:1;white-space:nowrap}.fab-pop__action-btn:hover{background:var(--brand-active)}.fab-pop__action-btn:disabled{opacity:.3;cursor:not-allowed}.fab-pop__action-btn--clear:hover{background:var(--brand-hover);color:var(--brand-accent);border-color:var(--brand-border)}.fab-pop__action-btn--mode{color:var(--brand-text-muted)}.maths-strip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:14px;box-shadow:0 8px 32px #0000008c;padding:10px 12px;display:flex;flex-direction:column;gap:8px;z-index:200;width:min(300px,88vw);white-space:normal;animation:maths-strip-in .13s cubic-bezier(.34,1.4,.64,1) both}@keyframes maths-strip-in{0%{opacity:0;transform:translate(-50%) translateY(6px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.maths-strip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.maths-strip--inline{position:static;transform:none;box-shadow:none;border:none;background:transparent;padding:0;width:100%;border-radius:0;animation:none}.maths-strip--inline:after{display:none}.maths-strip__tools{display:grid;grid-template-columns:1fr 1fr;gap:6px}.maths-strip__tool-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:52px;padding:8px 6px;border:1.5px solid rgba(217,119,6,.25);border-radius:10px;background:transparent;color:#fbbf248c;cursor:pointer;font-family:var(--font-body);transition:background .12s,border-color .12s,color .12s,transform 80ms;-webkit-tap-highlight-color:transparent}.maths-strip__tool-btn:hover{background:var(--brand-active);border-color:#d97706b3;color:var(--brand-accent);transform:scale(1.03)}.maths-strip__tool-btn.is-active{background:var(--brand-active);border-color:#d97706;color:var(--brand-accent)}.maths-strip__tool-btn.is-blue{color:#60a5fa8c;border-color:#2563eb40}.maths-strip__tool-btn.is-blue:hover{background:#2563eb26;border-color:#2563ebb3;color:#60a5fa}.maths-strip__tool-btn.is-blue.is-active{background:#2563eb38;border-color:#2563eb;color:#93c5fd}.maths-strip__tool-btn.is-indigo{color:#818cf88c;border-color:#6366f140}.maths-strip__tool-btn.is-indigo:hover{background:#6366f126;border-color:#6366f1b3;color:#818cf8}.maths-strip__tool-btn.is-indigo.is-active{background:#6366f138;border-color:#6366f1;color:#a5b4fc}.maths-strip__tool-btn.is-amber{color:#fbbf248c;border-color:#d9770640}.maths-strip__tool-btn.is-amber:hover{background:#d9770626;border-color:#d97706b3;color:#fbbf24}.maths-strip__tool-btn.is-teal{color:#2dd4bf8c;border-color:#0d948840}.maths-strip__tool-btn.is-teal:hover{background:#0d948826;border-color:#0d9488b3;color:#2dd4bf}.maths-strip__tool-btn.is-teal.is-active{background:#0d948838;border-color:#0d9488;color:#5eead4}.maths-strip__tool-btn.is-green{color:#4ade808c;border-color:#16a34a40}.maths-strip__tool-btn.is-green:hover{background:#16a34a26;border-color:#16a34ab3;color:#4ade80}.maths-strip__tool-btn.is-green.is-active{background:#16a34a38;border-color:#16a34a;color:#86efac}.maths-strip__tool-btn.is-purple{color:#c084fc8c;border-color:#7c3aed40}.maths-strip__tool-btn.is-purple:hover{background:#7c3aed26;border-color:#7c3aedb3;color:#c084fc}.maths-strip__tool-btn.is-purple.is-active{background:#7c3aed38;border-color:#7c3aed;color:#d8b4fe}.maths-strip__tool-icon{font-size:22px;line-height:1;display:flex;align-items:center}.maths-strip__tool-icon.is-text{font-size:18px;font-family:var(--font-body)}.maths-strip__tool-label{font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;line-height:1;white-space:nowrap}.maths-strip__hint{margin:0;font-size:11px;color:#fbbf2473;font-family:var(--font-body);text-align:center;font-style:italic;padding:2px 0 0}.maths-strip__sep{height:1px;background:#d9770640;margin:0 -2px}.maths-strip__tabs{display:flex;gap:4px}.maths-strip__tab{flex:1;min-height:34px;padding:4px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-sub);font-size:10px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent}.maths-strip__tab.is-active{background:var(--amber);color:#fff}.maths-strip__tab:hover:not(.is-active){background:var(--modal-surface2)}.maths-strip__emoji-grid{display:flex;flex-wrap:wrap;gap:3px;max-height:140px;overflow-y:auto;padding:2px}.maths-strip__emoji{width:34px;height:34px;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;border:2px solid transparent;border-radius:8px;background:transparent;cursor:pointer;flex-shrink:0;transition:background .1s,transform .1s,border-color .1s;-webkit-tap-highlight-color:transparent}.maths-strip__emoji:hover{background:var(--modal-surface2);transform:scale(1.15)}.maths-strip__emoji.is-active{border-color:var(--amber);background:var(--amber-l);transform:scale(1.08)}.maths-strip__sizes{display:flex;align-items:center;gap:6px;border-top:1px solid var(--brand-border);padding-top:8px}.maths-strip__size-label{font-size:10px;font-weight:600;color:var(--brand-text-muted);font-family:var(--font-body);margin-right:2px}.maths-strip__size-btn{flex:1;min-height:32px;padding:4px 0;border:1.5px solid var(--brand-border);border-radius:8px;background:transparent;color:var(--brand-text);font-size:11px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:background .12s,border-color .12s,color .12s;-webkit-tap-highlight-color:transparent}.maths-strip__size-btn:hover{background:var(--modal-surface2);border-color:var(--amber)}.maths-strip__size-btn.is-active{background:var(--amber);border-color:var(--amber);color:#fff}.mobile-sheet__tool-btn.is-amber{color:var(--amber)}.mobile-sheet__tool-btn.is-amber.is-active{background:var(--amber-l);border-color:var(--amber);color:var(--amber);box-shadow:0 0 0 2px var(--amber)}.fab-pop__tool-btn.is-amber{color:var(--amber)}.fab-pop__tool-btn.is-amber.is-active{background:var(--amber-l);color:var(--amber);box-shadow:0 0 0 1.5px var(--amber)}.marker-palette{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);z-index:50;display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:12px;box-shadow:0 8px 32px #0000008c;white-space:nowrap;min-width:max-content;animation:picker-pop .14s cubic-bezier(.34,1.56,.64,1) both}.marker-palette:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--brand-bg-deep, var(--brand-bg));border-right:1.5px solid var(--brand-border);border-bottom:1.5px solid var(--brand-border)}.marker-palette__label{font-size:10px;font-weight:700;color:var(--brand-text-muted);letter-spacing:.07em;text-transform:uppercase}.marker-palette__swatches{display:flex;gap:6px;align-items:center}.marker-palette__swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;background:var(--dot);cursor:pointer;padding:0;flex-shrink:0;outline:1.5px solid rgba(132,204,22,.2);outline-offset:1px;transition:transform .12s ease-out,border-color .12s ease-out,box-shadow .12s ease-out;background-image:linear-gradient(45deg,#1a2a00 25%,transparent 25%),linear-gradient(-45deg,#1a2a00 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a2a00 75%),linear-gradient(-45deg,transparent 75%,#1a2a00 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0px;background-color:var(--dot)}.marker-palette__swatch:hover{transform:scale(1.15);outline-color:#84cc1680}.marker-palette__swatch.is-active{border-color:#84cc16;outline:none;box-shadow:0 0 0 2px #0d1a00,0 0 0 4px #84cc16;transform:scale(1.1)}.marker-palette__custom{position:relative;display:flex;align-items:center;gap:8px;cursor:pointer;padding-top:10px;border-top:1px solid rgba(132,204,22,.2)}.marker-palette__custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0}.marker-palette__custom-swatch{width:26px;height:26px;border-radius:6px;border:1.5px solid rgba(132,204,22,.3);flex-shrink:0}.marker-palette__custom-label{font-size:12px;font-weight:500;color:#a3e63580}.mobile-sheet__swatch.is-highlight,.fab-pop__swatch.is-highlight{background-image:linear-gradient(45deg,#ccc 25%,transparent 25%),linear-gradient(-45deg,#ccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ccc 75%),linear-gradient(-45deg,transparent 75%,#ccc 75%);background-size:6px 6px;background-position:0 0,0 3px,3px -3px,-3px 0px;background-color:var(--dot)}.pen-toolbar__undo-wrap{position:relative;display:inline-flex}.pen-toolbar__sync-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%;background:var(--amber, #D97706);box-shadow:0 0 0 2px var(--modal-bg, #fff);pointer-events:none;animation:sync-dot-pulse 1.2s ease-in-out infinite}@keyframes sync-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}.pen-toolbar__resources-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-width:52px;padding:0 10px;height:42px;border:none;border-radius:var(--radius-sm, 6px);background:transparent;cursor:pointer;color:var(--brand-text-sub);transition:background .12s ease-out,color .12s,transform .12s ease-out;flex-shrink:0}.pen-toolbar__resources-btn:hover{background:var(--brand-hover);color:var(--brand-text);transform:scale(1.05)}.pen-toolbar__resources-btn:active{transform:scale(.97)}.pen-toolbar__resources-label{font-size:8px;font-weight:600;font-family:var(--font-body, sans-serif);color:var(--brand-text-muted);text-transform:uppercase;letter-spacing:.4px;line-height:1;white-space:nowrap;pointer-events:none}.pen-toolbar--pill .pen-toolbar__resources-btn{width:36px;height:36px;min-width:36px;padding:0;gap:0;flex-direction:row}.pen-toolbar--pill .pen-toolbar__resources-label{display:none}.fab-pop__action-btn--resources{color:var(--brand-text-sub)}.fab-pop__action-btn--resources:hover{background:var(--brand-active);color:var(--brand-text);border-color:var(--brand-border)}.fab-pop__action-btn--resources .fab-pop__action-icon{display:flex;align-items:center;justify-content:center}.mobile-sheet__action-btn--resources{display:flex;align-items:center;gap:5px;color:var(--brand-text-sub)}.mobile-sheet__action-btn--resources:active{background:var(--brand-border)}.zoom-controls{position:fixed;bottom:calc(var(--toolbar-h) + 16px);right:24px;z-index:60;display:flex;align-items:center;gap:2px;padding:4px 8px;background:var(--brand-bg-deep);border:1px solid var(--brand-border);border-radius:var(--radius-pill, 999px);box-shadow:0 4px 24px #0006,0 2px 8px #0000004d;pointer-events:all;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .2s ease-in-out,border-color .2s ease-in-out}.zoom-controls__btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm, 6px);background:transparent;color:var(--brand-text-sub);font-size:16px;line-height:1;cursor:pointer;transition:background .12s ease-out,transform .12s ease-out,color .12s;padding:0}.zoom-controls__btn:hover{background:var(--brand-hover);color:var(--brand-text);transform:scale(1.08)}.zoom-controls__btn--fit{font-size:20px;color:var(--brand-text-muted)}.zoom-controls__btn--fit:hover{color:var(--brand-accent);background:var(--brand-hover)}.zoom-controls__level{min-width:52px;height:32px;padding:0 6px;border:none;border-radius:var(--radius-sm, 6px);background:transparent;color:var(--brand-text-muted);font-size:12px;font-weight:700;font-family:var(--font-body, sans-serif);cursor:pointer;text-align:center;transition:background .12s,color .12s;letter-spacing:.02em;font-variant-numeric:tabular-nums}.zoom-controls__divider{width:1px;height:20px;background:var(--brand-border);margin:0 4px;flex-shrink:0;border-radius:1px}@media(max-width:767px){.zoom-controls{bottom:12px;right:12px;padding:3px 6px}.zoom-controls__btn{min-width:36px;min-height:36px;font-size:11px}}@media(min-width:768px){[data-toolbar-fab] .zoom-controls{bottom:24px;right:108px}}.ruler-overlay{position:absolute;z-index:15;pointer-events:none;display:block}.ruler-overlay--horizontal{width:100%;height:24px}.ruler-overlay--vertical{width:24px;height:100%}.compass-overlay{position:absolute;inset:0;z-index:20;pointer-events:none}.compass-overlay__svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}.compass-overlay__guide-circle{fill:none;stroke:var(--teal);stroke-width:1;stroke-dasharray:6 4;opacity:.45}.compass-overlay__arc-preview{fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;opacity:.75}.compass-overlay__arm{stroke:var(--teal);stroke-width:1.8;stroke-linecap:round}.compass-overlay__radius-label{fill:var(--text-muted);font-size:10px;font-family:var(--font-body);font-weight:600;letter-spacing:.02em;pointer-events:none;-webkit-user-select:none;user-select:none}.compass-overlay__hit{fill:transparent;stroke:none;pointer-events:all;-webkit-tap-highlight-color:transparent}.compass-overlay__pivot{fill:var(--modal-bg);stroke:var(--teal);stroke-width:2;pointer-events:none}.compass-overlay__pivot-dot{fill:var(--teal);pointer-events:none}.compass-overlay__tip{fill:var(--modal-bg);stroke:var(--teal);stroke-width:2;pointer-events:none;transition:fill .1s,stroke .1s}.compass-overlay__tip.is-draw{fill:var(--teal);stroke:var(--teal)}.compass-overlay__pencil-tick{stroke:var(--teal);stroke-width:2;stroke-linecap:round;pointer-events:none}.compass-overlay__mode-btn{position:absolute;display:flex;align-items:center;gap:5px;height:32px;padding:0 10px;border-radius:10px;border:1.5px solid var(--border2);background:var(--modal-bg);color:var(--text-sub);font-size:10px;font-weight:700;font-family:var(--font-body);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;pointer-events:all;box-shadow:var(--shadow-lg);white-space:nowrap;transition:background .1s,border-color .1s,color .1s;-webkit-tap-highlight-color:transparent;min-width:44px}.compass-overlay__mode-btn:hover{border-color:var(--teal);color:var(--teal)}.compass-overlay__mode-btn.is-draw{background:var(--teal-l);border-color:var(--teal);color:var(--teal)}.compass-overlay__mode-label{line-height:1}.protractor-overlay{position:absolute;inset:0;z-index:20;pointer-events:none}.protractor-overlay__svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}.protractor-overlay__body{fill:var(--green-l);opacity:.55}.protractor-overlay__arc{fill:none;stroke:var(--green);stroke-width:2}.protractor-overlay__baseline{stroke:var(--green);stroke-width:1.5;stroke-linecap:round}.protractor-overlay__tick{stroke:var(--green);stroke-width:.8;opacity:.5}.protractor-overlay__tick.is-minor{stroke-width:1;opacity:.7}.protractor-overlay__tick.is-major{stroke-width:1.5;opacity:1}.protractor-overlay__tick-label{fill:var(--text-sub);font-size:9px;font-family:var(--font-body);font-weight:600;pointer-events:none;-webkit-user-select:none;user-select:none}.protractor-overlay__marker-line{stroke:var(--rose);stroke-width:1.8;stroke-linecap:round;stroke-dasharray:5 3}.protractor-overlay__marker-label{fill:var(--rose);font-size:13px;font-family:var(--font-body);font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none}.protractor-overlay__hit{fill:transparent;stroke:none;pointer-events:all;-webkit-tap-highlight-color:transparent}.protractor-overlay__centre-dot{fill:var(--modal-bg);stroke:var(--green);stroke-width:2;pointer-events:none}.protractor-overlay__centre-dot-inner{fill:var(--green);pointer-events:none}.protractor-overlay__rotate-handle{fill:var(--modal-bg);stroke:var(--green);stroke-width:2;pointer-events:none}.protractor-overlay__marker-handle{fill:var(--rose);stroke:var(--modal-bg);stroke-width:2;pointer-events:none}.protractor-overlay__controls{position:absolute;display:flex;align-items:center;gap:4px;pointer-events:all}.protractor-overlay__mode-btn{height:32px;min-width:44px;padding:0 10px;border-radius:8px;border:1.5px solid var(--border2);background:var(--modal-bg);color:var(--text-sub);font-size:10px;font-weight:700;font-family:var(--font-body);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;box-shadow:var(--shadow-lg);transition:background .1s,border-color .1s,color .1s;-webkit-tap-highlight-color:transparent}.protractor-overlay__mode-btn:hover{border-color:var(--green);color:var(--green)}.protractor-overlay__mode-btn.is-active{background:var(--green-l);border-color:var(--green);color:var(--green)}.protractor-overlay__trace-btn{height:32px;min-width:44px;padding:0 12px;border-radius:8px;border:1.5px solid var(--green);background:var(--green);color:var(--modal-bg);font-size:11px;font-weight:700;font-family:var(--font-body);letter-spacing:.03em;cursor:pointer;box-shadow:var(--shadow-lg);transition:opacity .1s;-webkit-tap-highlight-color:transparent}.protractor-overlay__trace-btn:hover{opacity:.85}.curtain-overlay{position:absolute;top:0;left:0;right:0;bottom:var(--toolbar-h, 56px);z-index:25;pointer-events:none;overflow:hidden}[data-toolbar-pill] .curtain-overlay,[data-toolbar-fab] .curtain-overlay,[data-fullscreen] .curtain-overlay,[data-perspective=student] .curtain-overlay{bottom:0}[data-toolbar-pill] .curtain-overlay{z-index:55}.curtain-overlay__panel{position:absolute;transition:none}.curtain-overlay__handle{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:44px;height:64px;border-radius:12px;background:var(--modal-bg);border:2px solid var(--blue);box-shadow:var(--shadow-lg);color:var(--blue);cursor:ew-resize;pointer-events:all;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:none;z-index:2}.curtain-overlay__handle.is-vert{width:64px;height:44px;cursor:ns-resize;flex-direction:row}.curtain-overlay__handle-grip{display:flex;align-items:center;justify-content:center;opacity:.7}.curtain-overlay__handle-pct{font-size:10px;font-weight:700;font-family:var(--font-body);line-height:1;opacity:.85}.curtain-overlay__controls{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:14px;background:var(--modal-bg);border:1.5px solid var(--border2);box-shadow:var(--shadow-lg);pointer-events:all;white-space:nowrap;z-index:3;flex-wrap:wrap;max-width:calc(100vw - 32px)}.curtain-overlay__controls-group{display:flex;align-items:center;gap:4px}.curtain-overlay__controls-label{font-size:9px;font-weight:700;font-family:var(--font-body);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:2px}.curtain-overlay__divider{width:1px;height:24px;background:var(--border2);flex-shrink:0}.curtain-overlay__icon-btn{width:30px;height:30px;border-radius:7px;border:1.5px solid var(--border2);background:transparent;color:var(--text-sub);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,border-color .1s,color .1s;-webkit-tap-highlight-color:transparent}.curtain-overlay__icon-btn:hover{border-color:var(--blue);color:var(--blue)}.curtain-overlay__icon-btn.is-active{background:var(--blue-l);border-color:var(--blue);color:var(--blue)}.curtain-overlay__swatches{display:flex;align-items:center;gap:4px;background:var(--modal-surface2);border:1.5px solid var(--border2);border-radius:8px;padding:3px 5px}.curtain-overlay__swatch{width:22px;height:22px;border-radius:50%;border:2px solid rgba(0,0,0,.18);cursor:pointer;padding:0;outline:none;transition:transform .1s,border-color .1s,box-shadow .1s;box-shadow:inset 0 0 0 1px #ffffff26,0 1px 3px #00000040}.curtain-overlay__swatch:hover{transform:scale(1.18);box-shadow:0 0 0 2px var(--blue),0 1px 3px #00000040}.curtain-overlay__swatch.is-active{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue);transform:scale(1.18)}.curtain-overlay__swatch--custom{background:var(--modal-bg);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-sub);cursor:pointer;position:relative;overflow:hidden;border:2px dashed var(--border2);border-radius:50%}.curtain-overlay__swatch--custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0}.curtain-overlay__opacity-slider{width:80px;accent-color:var(--blue);cursor:pointer}.curtain-overlay__opacity-val{font-size:10px;font-weight:700;font-family:var(--font-body);color:var(--text-sub);min-width:28px}.curtain-overlay__close-btn{width:30px;height:30px;border-radius:7px;border:1.5px solid var(--border2);background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s,border-color .1s;-webkit-tap-highlight-color:transparent;margin-left:2px}.curtain-overlay__close-btn:hover{background:var(--danger-l, #fce7ea);color:var(--danger, #e11d48);border-color:var(--danger, #e11d48)}.spotlight-overlay{position:absolute;top:0;left:0;right:0;bottom:var(--toolbar-h, 56px);z-index:25;pointer-events:none;overflow:hidden}[data-toolbar-pill] .spotlight-overlay,[data-toolbar-fab] .spotlight-overlay,[data-fullscreen] .spotlight-overlay,[data-perspective=student] .spotlight-overlay{bottom:0}[data-toolbar-pill] .spotlight-overlay{z-index:55}.spotlight-overlay__svg{position:absolute;inset:0;display:block;pointer-events:none}.spotlight-overlay__handle{position:absolute;border-radius:50%;border:2.5px solid rgba(255,255,255,.55);box-shadow:0 0 0 1px #0000004d,inset 0 0 0 1px #ffffff14;cursor:move;pointer-events:all;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:none;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.spotlight-overlay__handle:focus-visible{outline:2px solid var(--indigo);outline-offset:3px}.spotlight-overlay__handle-icon{color:#ffffffb3;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .15s}.spotlight-overlay__handle:hover .spotlight-overlay__handle-icon,.spotlight-overlay__handle:focus .spotlight-overlay__handle-icon{opacity:1}.spotlight-overlay__controls{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:14px;background:var(--modal-bg);border:1.5px solid var(--border2);box-shadow:var(--shadow-lg);pointer-events:all;white-space:nowrap;z-index:3;flex-wrap:wrap;max-width:calc(100vw - 32px)}.spotlight-overlay__controls-group{display:flex;align-items:center;gap:4px}.spotlight-overlay__controls-label{font-size:9px;font-weight:700;font-family:var(--font-body);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:2px}.spotlight-overlay__divider{width:1px;height:24px;background:var(--border2);flex-shrink:0}.spotlight-overlay__icon-btn{width:36px;height:36px;min-width:36px;border-radius:8px;border:1.5px solid var(--border2);background:transparent;color:var(--text-sub);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,border-color .1s,color .1s;-webkit-tap-highlight-color:transparent;padding:0}.spotlight-overlay__icon-btn:hover{border-color:var(--indigo);color:var(--indigo)}.spotlight-overlay__icon-btn.is-active{background:var(--purple-l);border-color:var(--indigo);color:var(--indigo)}.spotlight-overlay__size-slider{width:100px;accent-color:var(--indigo);cursor:pointer}.spotlight-overlay__size-val{font-size:10px;font-weight:700;font-family:var(--font-body);color:var(--text-sub);min-width:36px}.spotlight-overlay__close-btn{width:30px;height:30px;border-radius:7px;border:1.5px solid var(--border2);background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s,border-color .1s;-webkit-tap-highlight-color:transparent;margin-left:2px}.spotlight-overlay__close-btn:hover{background:var(--danger-l, #fce7ea);color:var(--rose, #e11d48);border-color:var(--rose, #e11d48)}@media(max-width:480px){.spotlight-overlay__size-slider{width:60px}.spotlight-overlay__controls{gap:4px;padding:7px 8px}}.drawing-canvas-wrapper{position:absolute;inset:0;overflow:hidden;touch-action:none;overscroll-behavior:none}@media(max-width:767px){.drawing-canvas-wrapper{overflow:visible;touch-action:manipulation}}.drawing-canvas-grid{display:block;width:100%;height:100%;position:absolute;inset:0;pointer-events:none;z-index:0;image-rendering:crisp-edges;image-rendering:pixelated;will-change:contents}.drawing-canvas{display:block;width:100%;height:100%;position:absolute;inset:0;z-index:1;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;will-change:transform;pointer-events:all}.drawing-text-input{position:absolute;background:transparent;border:none;border-bottom:2px solid currentColor;outline:none;padding:0 2px;font-family:var(--font-body, "Nunito Sans", sans-serif);font-weight:600;line-height:1.2;min-width:80px;width:auto;max-width:calc(100% - 24px);z-index:10;caret-color:currentColor}.drawing-text-input::placeholder{color:#94a3b899;font-weight:400}.dc-layer-picker-backdrop{position:absolute;inset:0;z-index:70;background:transparent}.dc-layer-picker{position:absolute;z-index:71;min-width:180px;max-height:min(280px,60vh);display:flex;flex-direction:column;background:var(--surface, #fff);border:1px solid var(--border, #e2e8f0);border-radius:10px;box-shadow:0 8px 24px #00000024,0 2px 6px #00000014;padding:6px 0;overflow:hidden;animation:dc-picker-in .12s ease}@keyframes dc-picker-in{0%{opacity:0;transform:scale(.96) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.dc-layer-picker__items{overflow-y:auto;overscroll-behavior:contain;flex:1;-webkit-overflow-scrolling:touch}.dc-layer-picker__header-row{display:flex;align-items:center;padding:4px 8px 6px 12px;border-bottom:1px solid var(--border, #e2e8f0);margin-bottom:4px;gap:4px}.dc-layer-picker__title{flex:1;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted, #94a3b8)}.dc-layer-picker__add-btn{width:26px;height:26px;border-radius:6px;border:1px solid var(--border, #e2e8f0);background:none;color:var(--teal, #0D9488);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 80ms;flex-shrink:0}.dc-layer-picker__add-btn:hover{background:color-mix(in srgb,var(--teal, #0D9488) 12%,transparent)}.dc-layer-picker__show-all{width:100%;padding:6px 12px;background:none;border:none;cursor:pointer;font-size:11px;font-weight:600;color:var(--text-muted, #94a3b8);text-align:left;border-top:1px solid var(--border, #e2e8f0);transition:color 80ms}.dc-layer-picker__show-all:hover{color:var(--text, #1e293b)}.dc-layer-picker__add-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-top:1px solid var(--border, #e2e8f0)}.dc-layer-picker__add-input{flex:1;height:32px;padding:0 8px;border:1px solid var(--border, #e2e8f0);border-radius:6px;font-size:13px;background:var(--surface2, #f8fafc);color:var(--text, #1e293b);outline:none;min-width:0}.dc-layer-picker__add-input:focus{border-color:var(--teal, #0D9488);box-shadow:0 0 0 2px color-mix(in srgb,var(--teal, #0D9488) 20%,transparent)}.dc-layer-picker__add-confirm{height:32px;padding:0 10px;border-radius:6px;border:none;background:var(--teal, #0D9488);color:#fff;font-size:12px;font-weight:600;cursor:pointer;flex-shrink:0;transition:opacity 80ms}.dc-layer-picker__add-confirm:disabled{opacity:.4;cursor:not-allowed}.dc-layer-picker__item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dc-layer-picker__item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--text, #1e293b);text-align:left;min-height:44px;transition:background 80ms;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.dc-layer-picker__item:hover{background:var(--brand-hover)}.dc-layer-picker__item--active{color:var(--teal, #0D9488)}.dc-layer-picker__dot{width:8px;height:8px;border-radius:50%;background:var(--border, #cbd5e1);flex-shrink:0}.dc-layer-picker__item--active .dc-layer-picker__dot{background:var(--teal, #0D9488)}.dc-layer-picker__badge{margin-left:auto;font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--radius-pill)}.dc-layer-picker__badge--current{color:var(--teal, #0D9488);background:color-mix(in srgb,var(--teal, #0D9488) 14%,transparent)}.dc-sel-toolbar{position:absolute;transform:translate(-50%);display:flex;flex-direction:column;gap:0;background:var(--brand-bg-deep, var(--brand-bg));border:1px solid var(--brand-border);border-radius:14px;box-shadow:0 4px 20px #0000001c,0 1px 4px #00000012;padding:5px;pointer-events:all;z-index:65;-webkit-user-select:none;user-select:none;animation:dc-toolbar-in .14s cubic-bezier(.34,1.56,.64,1);min-width:200px;max-width:min(360px,95vw);overflow-x:hidden}.dc-sel-toolbar:not(.dc-sel-toolbar--shapes){flex-direction:row;align-items:center;flex-wrap:wrap;min-width:unset}@keyframes dc-toolbar-in{0%{opacity:0;transform:translate(-50%,6px) scale(.94)}to{opacity:1;transform:translate(-50%) scale(1)}}.dc-sel-toolbar--above{transform:translate(-50%,-100%);animation:dc-toolbar-in-above .14s cubic-bezier(.34,1.56,.64,1)}@keyframes dc-toolbar-in-above{0%{opacity:0;transform:translate(-50%,calc(-100% - 6px)) scale(.94)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.dc-sel-toolbar__row{display:flex;align-items:center;flex-wrap:wrap;gap:2px}.dc-sel-toolbar__divider{height:1px;background:var(--brand-border);margin:5px 2px}.dc-sel-toolbar__btn{display:flex;align-items:center;gap:5px;padding:6px 11px;border:none;background:transparent;border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;color:var(--brand-text);transition:background 80ms,color 80ms;min-height:44px;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.dc-sel-toolbar__btn:hover{background:var(--brand-hover)}.dc-sel-toolbar__btn--locked{color:var(--brand-accent);background:var(--brand-hover)}.dc-sel-toolbar__btn--locked:hover{background:var(--brand-active)}.dc-sel-toolbar__btn--copy{color:var(--brand-text-sub);transition:background 80ms,color 80ms,transform 80ms}.dc-sel-toolbar__btn--copy:hover{background:var(--brand-hover)}.dc-sel-toolbar__btn--copy.is-copied{background:var(--brand-active);color:var(--brand-accent);transform:scale(.96)}.dc-sel-toolbar__btn--cut{color:var(--brand-text);transition:background 80ms,color 80ms}.dc-sel-toolbar__btn--cut:hover{background:var(--brand-hover);color:var(--brand-text)}.dc-sel-toolbar__btn--delete{color:var(--brand-text);transition:background 80ms,color 80ms}.dc-sel-toolbar__btn--delete:hover{background:var(--brand-hover);color:var(--brand-accent)}.dc-sel-toolbar__btn--grid{color:var(--brand-text);transition:background 80ms,color 80ms}.dc-sel-toolbar__btn--grid:hover{background:var(--brand-hover);color:var(--brand-accent)}.grid-dup-dialog{position:absolute;z-index:80}.dc-sel-toolbar__sep{width:1px;height:22px;background:var(--brand-border);flex-shrink:0;margin:0 1px}.dc-sel-toolbar__color-row{display:flex;align-items:center;gap:6px;padding:3px 6px}.dc-sel-toolbar__color-label{font-size:10px;font-weight:600;color:var(--brand-text-muted);min-width:36px;letter-spacing:.03em;text-transform:uppercase}.dc-sel-toolbar__swatches{display:flex;align-items:center;gap:3px;flex-wrap:wrap}.dc-sel-toolbar__swatch{width:17px;height:17px;border-radius:50%;background:var(--sw, #ccc);border:2px solid transparent;cursor:pointer;padding:0;flex-shrink:0;transition:transform 80ms,border-color 80ms;display:flex;align-items:center;justify-content:center}.dc-sel-toolbar__swatch:hover{transform:scale(1.18)}.dc-sel-toolbar__swatch.is-active{border-color:var(--brand-accent);transform:scale(1.1)}.dc-sel-toolbar__swatch--none{background:var(--brand-active);border-color:var(--brand-border)}.dc-sel-toolbar__swatch--none.is-active{border-color:var(--brand-accent)}.dc-sel-toolbar__swatch-custom{position:relative;width:17px;height:17px;cursor:pointer;flex-shrink:0}.dc-sel-toolbar__swatch-custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0}.dc-sel-toolbar__swatch-custom span{display:flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;border:1.5px dashed var(--brand-border);font-size:11px;color:var(--brand-text-muted);line-height:1;pointer-events:none}.dc-sel-toolbar__opacity-row{display:flex;align-items:center;gap:6px;padding:4px 6px 3px}.dc-sel-toolbar__opacity-slider{flex:1;height:4px;accent-color:var(--brand-accent);cursor:pointer;min-width:80px}.dc-sel-toolbar__opacity-pct{font-size:11px;color:var(--brand-text-muted);min-width:28px;text-align:right;font-variant-numeric:tabular-nums}.dc-sel-toolbar--above{transform:translate(-50%,-100%)}.sticky-editor{position:absolute;background:var(--sticky-bg, #FEF08A);border-radius:8px;box-shadow:0 4px 20px #00000038,0 1px 4px #0000001f;display:flex;flex-direction:column;overflow:hidden;z-index:90;min-width:240px}.sticky-editor__header{display:flex;align-items:center;gap:5px;padding:6px 8px 4px;background:#0000001a}.sticky-editor__dot{width:18px;height:18px;border-radius:50%;background:var(--dot, #fff);border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:transform .1s,border-color .1s}.sticky-editor__dot.is-active{border-color:#00000073;transform:scale(1.2)}.sticky-editor__dot:hover{transform:scale(1.15)}.sticky-editor__close{background:transparent;border:none;cursor:pointer;color:#00000080;font-size:14px;line-height:1;padding:2px 4px;border-radius:4px}.sticky-editor__close:hover{background:#0000001f}.sticky-editor__fmt{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#00000012;border-top:1px solid rgba(0,0,0,.07);flex-wrap:wrap}.sticky-editor__select{background:#ffffff8c;border:1px solid rgba(0,0,0,.18);border-radius:4px;font-size:11px;padding:2px 4px;cursor:pointer;color:#1e293b;height:24px}.sticky-editor__select--size{width:46px}.sticky-editor__select:focus{outline:none;border-color:#00000059}.sticky-editor__fmt-btn{background:#ffffff8c;border:1px solid rgba(0,0,0,.18);border-radius:4px;font-size:12px;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1e293b;flex-shrink:0;transition:background .1s,border-color .1s}.sticky-editor__fmt-btn.is-active{background:#0000002e;border-color:#00000059}.sticky-editor__fmt-btn:hover{background:#0000001f}.sticky-editor__tc-wrap{display:flex;align-items:center;gap:3px;margin-left:2px}.sticky-editor__tc-dot{width:16px;height:16px;border-radius:50%;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:transform .1s,border-color .1s}.sticky-editor__tc-dot.is-active{border-color:#00000080;transform:scale(1.2)}.sticky-editor__tc-dot:hover{transform:scale(1.15)}.sticky-editor__textarea{flex:1;background:transparent;border:none;outline:none;resize:none;padding:10px 12px;font-size:15px;font-family:Nunito Sans,sans-serif;color:#1e293b;min-height:90px;line-height:1.5}.sticky-editor__save{background:#0000001a;border:none;cursor:pointer;padding:6px 12px;font-size:12px;font-family:inherit;color:#000000a6;text-align:right;transition:background .12s;display:flex;align-items:center;justify-content:flex-end;gap:6px}.sticky-editor__save:hover{background:#0000002b}.sticky-editor__save kbd{background:#0000001f;border-radius:3px;padding:1px 4px;font-size:10px;font-family:inherit}.nl-config-dialog{position:absolute;z-index:90;background:var(--surface);border:1.5px solid var(--border2);border-radius:16px;box-shadow:var(--shadow-lg);width:252px;display:flex;flex-direction:column;overflow:hidden;font-family:var(--font-body)}.nl-config-dialog:before{content:"";display:block;height:3px;background:var(--amber);flex-shrink:0}.nl-config-dialog__inner{display:flex;flex-direction:column;gap:12px;padding:14px 14px 12px}.nl-config-dialog__title{font-size:14px;font-weight:800;font-family:var(--font);color:var(--text);letter-spacing:-.01em;line-height:1.2}.nl-config-dialog__subtitle{font-size:11px;color:var(--text-muted);margin-top:-8px;line-height:1.4}.nl-config-dialog__row{display:flex;align-items:center;gap:8px}.nl-config-dialog__row label{font-size:11px;font-weight:600;color:var(--text-sub);min-width:28px;flex-shrink:0;text-transform:uppercase;letter-spacing:.05em}.nl-config-dialog__input{flex:1;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font-body);padding:6px 8px;color:var(--text);outline:none;min-width:0;transition:border-color .12s}.nl-config-dialog__input:focus{border-color:var(--amber);background:var(--surface)}.nl-config-dialog__seg{display:flex;gap:4px;flex:1}.nl-config-dialog__seg-btn{flex:1;padding:6px 4px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text-sub);font-size:11px;font-weight:700;font-family:var(--font-body);cursor:pointer;text-align:center;transition:background .1s,border-color .1s,color .1s;text-transform:uppercase;letter-spacing:.04em}.nl-config-dialog__seg-btn:hover{border-color:var(--amber);color:var(--amber)}.nl-config-dialog__seg-btn.is-active{background:var(--amber);border-color:var(--amber);color:#fff}.nl-config-dialog__footer{display:flex;gap:6px;justify-content:flex-end;padding:10px 14px 12px;border-top:1px solid var(--border);margin-top:-2px}.nl-config-dialog__btn{border:none;border-radius:9px;padding:7px 16px;font-size:12px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:background .1s,opacity .1s;min-height:34px;white-space:nowrap;letter-spacing:.02em}.nl-config-dialog__btn--cancel{background:var(--surface2);color:var(--text-sub);border:1.5px solid var(--border)}.nl-config-dialog__btn--cancel:hover{background:var(--surface);border-color:var(--border2)}.nl-config-dialog__btn--place{background:var(--amber);color:#fff}.latex-eq-dialog{width:420px;max-width:calc(100vw - 20px)}.latex-eq-dialog__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:-4px}.latex-eq-dialog__close{width:22px;height:22px;border-radius:50%;border:none;background:transparent;color:var(--rose);font-size:13px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;opacity:.7;transition:opacity .1s,background .1s}.latex-eq-dialog__close:hover{opacity:1;background:color-mix(in srgb,var(--rose) 12%,transparent)}.latex-eq-dialog__tabs{display:flex;gap:4px;flex-wrap:wrap}.latex-eq-dialog__tab{height:24px;padding:0 10px;border-radius:6px;border:1.5px solid var(--border);background:transparent;color:var(--text-sub);font-size:11px;font-weight:700;font-family:var(--font-body);cursor:pointer;white-space:nowrap;transition:border-color .1s,background .1s,color .1s;letter-spacing:.04em;text-transform:uppercase}.latex-eq-dialog__tab--active{border-color:var(--amber);background:var(--amber-l);color:var(--amber)}.latex-eq-dialog__sym-grid{display:flex;flex-wrap:wrap;gap:3px;padding:7px 6px;background:var(--modal-surface2);border-radius:10px;min-height:60px}.latex-eq-dialog__sym-btn{min-width:32px;min-height:32px;padding:0 5px;border:1.5px solid var(--border);border-radius:7px;background:var(--modal-bg);color:var(--text);font-size:13px;font-family:serif;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 80ms,border-color 80ms,color 80ms;line-height:1}.latex-eq-dialog__sym-btn:hover{background:var(--amber-l);border-color:var(--amber);color:var(--amber)}.latex-eq-dialog__input-wrap{position:relative;display:flex;flex-direction:column;gap:4px}.latex-eq-dialog__pal-label{font-size:11px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-body)}.latex-eq-dialog__input{width:100%;box-sizing:border-box;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;font-size:12px;font-family:Courier New,monospace;padding:7px 10px 24px;color:var(--text);outline:none;resize:vertical;min-height:58px;transition:border-color .12s;line-height:1.5}.latex-eq-dialog__input:focus{border-color:var(--amber);background:var(--surface)}.latex-eq-dialog__clear{position:absolute;right:7px;bottom:7px;height:17px;padding:0 6px;border-radius:4px;border:none;background:transparent;color:var(--rose);font-size:11px;font-weight:700;font-family:var(--font-body);cursor:pointer;opacity:.7;transition:opacity .1s}.latex-eq-dialog__clear:hover{opacity:1}.latex-eq-dialog__preview{min-height:48px;background:var(--modal-surface2);border:1.5px dashed var(--border2);border-radius:10px;padding:8px 12px;display:flex;align-items:center;justify-content:center;overflow:auto;text-align:center;color:var(--text);font-size:15px}.latex-eq-dialog__preview svg{max-width:100%;height:auto}.latex-eq-dialog__examples{display:flex;flex-direction:column;gap:5px;padding-top:2px;border-top:1px solid var(--border)}.latex-eq-dialog__examples-row{display:flex;flex-wrap:wrap;gap:4px}.latex-eq-dialog__example-btn{height:22px;padding:0 8px;border:1.5px solid var(--border);border-radius:6px;background:var(--modal-surface2);color:var(--text-sub);font-size:11px;font-weight:600;font-family:var(--font-body);cursor:pointer;white-space:nowrap;transition:border-color .1s,color .1s,background .1s}.latex-eq-dialog__example-btn:hover{border-color:var(--amber);color:var(--amber);background:var(--amber-l)}.latex-eq-dialog__size-row{display:flex;align-items:center;gap:8px}.dc-resources-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:9px;font-size:13px;font-weight:600;background:#341e7a;color:#fff;border:none;cursor:pointer;transition:background .18s,transform .1s;white-space:nowrap;letter-spacing:-.01em}.dc-resources-btn:hover{background:#4a2d9c}.dc-resources-btn:active{transform:scale(.96)}.dc-resources-btn__count{background:#ffffff2e;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700;min-width:20px;text-align:center}.dc-resources-btn.is-open{background:#231560;box-shadow:inset 0 1px 4px #00000040}.rp-panel{--rp-purple-900: #231560;--rp-purple-800: #341e7a;--rp-purple-700: #4a2d9c;--rp-purple-600: #6040b8;--rp-purple-light: #ede9f9;--rp-purple-muted: #c4b8e8;--rp-accent: #22c55e;--rp-accent-hover: #16a34a;--rp-danger: #ef4444;--rp-text: #1e1b4b;--rp-text-muted: #6b7280;--rp-border: rgba(255,255,255,.12);--rp-card-border: #e5e1f5;--rp-panel-width: 780px;--rp-sidebar-w: 200px;--rp-header-h: 80px;--rp-radius: 12px;--rp-radius-sm: 7px;--rp-shadow: 0 0 0 1px rgba(0,0,0,.06), 0 20px 60px rgba(35,21,96,.28);--rp-transition: cubic-bezier(.32, .72, 0, 1)}.rp-backdrop{position:fixed;inset:0;background:#0f0a2873;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1100;opacity:0;pointer-events:none;transition:opacity .3s ease}.rp-backdrop--visible{opacity:1;pointer-events:auto}.rp-panel{position:fixed;top:0;right:0;height:100dvh;width:min(var(--rp-panel-width),96vw);background:#f7f5fd;box-shadow:var(--rp-shadow);z-index:1101;display:flex;flex-direction:column;transform:translate(100%);transition:transform .4s var(--rp-transition);overflow:hidden}.rp-panel--open{transform:translate(0)}.rp-header{display:flex;align-items:center;gap:14px;padding:18px 20px 18px 22px;background:linear-gradient(135deg,var(--rp-purple-900) 0%,var(--rp-purple-800) 100%);min-height:var(--rp-header-h);flex-shrink:0;position:relative}.rp-header:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.rp-header__icon{width:46px;height:46px;border-radius:12px;background:#ffffff24;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rp-header__text{flex:1;min-width:0}.rp-header__title{margin:0 0 2px;font-size:20px;font-weight:700;color:#fff;letter-spacing:-.02em}.rp-header__subtitle{margin:0;font-size:12.5px;color:#fff9;line-height:1.4}.rp-header__close{width:36px;height:36px;border-radius:10px;background:#ffffff1f;border:1px solid rgba(255,255,255,.16);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .18s;z-index:1}.rp-header__close:hover{background:#ffffff38}.rp-body{flex:1;min-height:0;display:flex;overflow:hidden}.rp-sidebar{width:var(--rp-sidebar-w);flex-shrink:0;background:var(--rp-purple-800);display:flex;flex-direction:column;padding:12px 0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.rp-sidebar__heading{display:flex;align-items:center;justify-content:space-between;padding:0 14px 8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff73}.rp-sidebar__add-btn{background:none;border:none;color:#ffffff8c;cursor:pointer;padding:3px;border-radius:5px;display:flex;align-items:center;transition:color .15s,background .15s}.rp-sidebar__add-btn:hover{color:#fff;background:#ffffff1a}.rp-sidebar__folder{display:flex;align-items:center;gap:7px;width:100%;padding:7px 14px;background:none;border:none;color:#ffffffb8;font-size:13px;text-align:left;cursor:pointer;border-radius:0;transition:background .15s,color .15s;position:relative}.rp-sidebar__folder:hover{background:#ffffff14;color:#fff}.rp-sidebar__folder.is-active{background:#ffffff24;color:#fff;font-weight:600}.rp-sidebar__folder.is-active:before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:3px;border-radius:0 3px 3px 0;background:var(--rp-accent)}.rp-sidebar__folder-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rp-sidebar__folder-count{font-size:11px;color:#fff6;font-weight:500;margin-left:auto;background:#ffffff1a;border-radius:10px;padding:1px 7px}.rp-sidebar__folder-delete{background:none;border:none;color:#ffffff4d;cursor:pointer;padding:2px;border-radius:4px;display:flex;opacity:0;transition:opacity .15s,color .15s}.rp-sidebar__folder:hover .rp-sidebar__folder-delete{opacity:1}.rp-sidebar__folder-delete:hover{color:var(--rp-danger)}.rp-sidebar__folder-chevron{color:#ffffff59;display:flex;flex-shrink:0}.rp-sidebar__rename-input{flex:1;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:5px;padding:2px 6px;font-size:13px;color:#fff;outline:none;min-width:0}.rp-sidebar__rename-input::placeholder{color:#fff6}.rp-sidebar__new-folder{display:flex;align-items:center;gap:7px;padding:5px 14px;color:#fff9}.rp-sidebar__divider{height:1px;background:#ffffff14;margin:10px 14px}.rp-sidebar__root-drop{padding:6px 14px;font-size:11px;color:#ffffff4d;text-align:center;border:1px dashed rgba(255,255,255,.15);border-radius:6px;margin:0 14px;cursor:default;transition:border-color .15s,color .15s}.rp-sidebar__root-drop:hover{border-color:#ffffff4d;color:#ffffff80}.rp-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.rp-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 16px;border-bottom:1px solid var(--rp-card-border);background:#fff;flex-shrink:0}.rp-toolbar__left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.rp-toolbar__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.rp-search{display:flex;align-items:center;gap:7px;background:#f3f0fb;border:1px solid var(--rp-card-border);border-radius:var(--rp-radius-sm);padding:0 10px;flex:1;max-width:220px;color:var(--rp-text-muted);transition:border-color .18s,box-shadow .18s}.rp-search:focus-within{border-color:var(--rp-purple-600);box-shadow:0 0 0 3px #6040b81f;color:var(--rp-text)}.rp-search__input{border:none;background:none;outline:none;font-size:13px;color:var(--rp-text);flex:1;padding:7px 0;min-width:0}.rp-search__input::placeholder{color:var(--rp-text-muted)}.rp-search__clear{background:none;border:none;color:var(--rp-text-muted);cursor:pointer;display:flex;padding:2px}.rp-filters{display:flex;gap:4px}.rp-filter-btn{padding:5px 10px;border-radius:6px;font-size:11.5px;font-weight:600;border:1px solid var(--rp-card-border);background:#fff;color:var(--rp-text-muted);cursor:pointer;transition:all .15s}.rp-filter-btn:hover{border-color:var(--rp-purple-600);color:var(--rp-purple-700)}.rp-filter-btn.is-active{background:var(--rp-purple-light);border-color:var(--rp-purple-600);color:var(--rp-purple-800)}.rp-toolbar__upload-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--rp-purple-800);color:#fff;border:none;border-radius:var(--rp-radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background .18s,transform .1s;white-space:nowrap}.rp-toolbar__upload-btn:hover{background:var(--rp-purple-700)}.rp-toolbar__upload-btn:active{transform:scale(.97)}.rp-toolbar__delete-btn{display:flex;align-items:center;gap:6px;padding:7px 12px;background:#fff0f0;color:var(--rp-danger);border:1px solid #fca5a5;border-radius:var(--rp-radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background .18s}.rp-toolbar__delete-btn:hover{background:#fee2e2}.rp-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#faf9fe;border-bottom:1px solid var(--rp-card-border);flex-shrink:0}.rp-section-header__left{display:flex;align-items:center;gap:8px}.rp-section-header__title{font-size:13px;font-weight:700;color:var(--rp-text)}.rp-section-header__count{font-size:12px;color:var(--rp-text-muted);background:var(--rp-purple-light);padding:1px 8px;border-radius:10px}.rp-section-header__clear{background:none;border:none;font-size:12px;color:var(--rp-purple-700);cursor:pointer;font-weight:500}.rp-section-header__clear:hover{text-decoration:underline}.rp-content{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--rp-purple-muted) transparent;padding:16px;position:relative}.rp-content--drag{background:#f0ecfd}.rp-drag-overlay{position:absolute;inset:16px;border:2px dashed var(--rp-purple-600);border-radius:var(--rp-radius);background:#ede9f9eb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;font-size:15px;font-weight:600;color:var(--rp-purple-700);z-index:10;pointer-events:none}.rp-drag-overlay svg{width:32px;height:32px}.rp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;text-align:center}.rp-empty__icon{margin-bottom:6px;opacity:.85}.rp-empty__title{font-size:16px;font-weight:700;color:var(--rp-text);margin:0}.rp-empty__sub{font-size:13px;color:var(--rp-text-muted);margin:0;line-height:1.6}.rp-empty__cta{display:flex;align-items:center;gap:7px;margin-top:8px;padding:9px 18px;background:var(--rp-purple-800);color:#fff;border:none;border-radius:var(--rp-radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .18s}.rp-empty__cta:hover{background:var(--rp-purple-700)}.rp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.rp-card{border-radius:var(--rp-radius);background:#fff;border:2px solid transparent;box-shadow:0 1px 4px #23156012;overflow:hidden;cursor:pointer;transition:box-shadow .18s,border-color .18s,transform .18s;position:relative}.rp-card:hover{box-shadow:0 4px 16px #23156024;transform:translateY(-2px)}.rp-card--selected{border-color:var(--rp-purple-600);box-shadow:0 0 0 3px #6040b826}.rp-card__thumb{position:relative;height:110px;background:var(--rp-purple-light);overflow:hidden}.rp-card__thumb-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .22s}.rp-card:hover .rp-card__thumb-img{transform:scale(1.04)}.rp-card__thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--rp-purple-700)}.rp-card__thumb-placeholder svg{width:36px;height:36px;opacity:.6}.rp-card__checkbox{position:absolute;top:7px;left:7px;z-index:3;cursor:pointer}.rp-card__checkbox input{display:none}.rp-card__actions{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;gap:6px;padding:8px;background:linear-gradient(to top,rgba(35,21,96,.72) 0%,transparent 60%);opacity:0;transition:opacity .18s}.rp-card:hover .rp-card__actions{opacity:1}.rp-card__action-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:background .15s,transform .1s}.rp-card__action-btn:active{transform:scale(.94)}.rp-card__action-btn--place{background:var(--rp-accent);color:#fff;flex:1}.rp-card__action-btn--place:hover{background:var(--rp-accent-hover)}.rp-card__action-btn--delete{background:#ef4444e6;color:#fff;padding:5px 8px}.rp-card__action-btn--delete:hover{background:var(--rp-danger)}.rp-badge{position:absolute;top:7px;right:7px;font-size:9.5px;font-weight:800;letter-spacing:.05em;padding:2px 6px;border-radius:4px;z-index:2}.rp-badge--img{background:#dbeafe;color:#1d4ed8}.rp-badge--pdf{background:#fee2e2;color:#b91c1c}.rp-badge--ppt{background:#fef3c7;color:#92400e}.rp-card__info{padding:8px 9px;display:flex;flex-direction:column;gap:2px}.rp-card__name{font-size:12px;font-weight:600;color:var(--rp-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.rp-card__size{font-size:10.5px;color:var(--rp-text-muted)}.rp-checkbox{display:inline-flex;align-items:center;cursor:pointer}.rp-checkbox input{display:none}.rp-checkbox__box{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--rp-card-border);background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s;color:#fff;flex-shrink:0}.rp-checkbox input:checked+.rp-checkbox__box{background:var(--rp-purple-700);border-color:var(--rp-purple-700)}.rp-checkbox__box--card{width:18px;height:18px;border-radius:5px;border:2px solid rgba(255,255,255,.8);background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 1px 4px #0003}.rp-card--selected .rp-checkbox__box--card,.rp-card__checkbox input:checked+.rp-checkbox__box--card{background:var(--rp-purple-700);border-color:#fff}.rp-footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;font-size:11.5px;color:var(--rp-text-muted);border-top:1px solid var(--rp-card-border);background:#fff}@media(max-width:600px){.rp-panel{--rp-sidebar-w: 0px;width:100vw}.rp-sidebar{display:none}.rp-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.rp-content::-webkit-scrollbar{width:5px}.rp-content::-webkit-scrollbar-track{background:transparent}.rp-content::-webkit-scrollbar-thumb{background:var(--rp-purple-muted);border-radius:10px}.rp-sidebar::-webkit-scrollbar{width:3px}.rp-sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:10px}.rp-toolbar__place-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--rp-accent);color:#fff;border:none;border-radius:var(--rp-radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background .18s,transform .1s;white-space:nowrap}.rp-toolbar__place-btn:hover{background:var(--rp-accent-hover)}.rp-toolbar__place-btn:active{transform:scale(.97)}.rp-page-modal-overlay{position:absolute;inset:0;z-index:1200;background:#0f0a288c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px}.rp-page-modal{background:#fff;border-radius:16px;box-shadow:0 24px 80px #23156052;display:flex;flex-direction:column;width:100%;max-width:680px;max-height:86vh;overflow:hidden}.rp-page-modal--loading{align-items:center;justify-content:center;gap:16px;padding:48px 24px;min-height:180px}.rp-loading-spinner{width:36px;height:36px;border:3px solid var(--rp-purple-light);border-top-color:var(--rp-purple-700);border-radius:50%;animation:rp-spin .75s linear infinite}@keyframes rp-spin{to{transform:rotate(360deg)}}.rp-loading-text{font-size:14px;font-weight:600;color:var(--rp-purple-800);margin:0}.rp-page-modal__header{display:flex;align-items:center;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--rp-card-border);flex-shrink:0}.rp-page-modal__header-icon{font-size:26px;line-height:1;flex-shrink:0}.rp-page-modal__header-text{flex:1;min-width:0}.rp-page-modal__title{font-size:16px;font-weight:700;color:var(--rp-text);line-height:1.2}.rp-page-modal__sub{font-size:12px;color:var(--rp-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.rp-page-modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f3f0fb;border:none;border-radius:8px;color:var(--rp-text-muted);cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.rp-page-modal__close:hover{background:var(--rp-purple-light);color:var(--rp-purple-800)}.rp-page-modal__toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#faf9fe;border-bottom:1px solid var(--rp-card-border);flex-shrink:0;gap:12px}.rp-page-modal__count{font-size:12.5px;font-weight:600;color:var(--rp-purple-800)}.rp-page-modal__toolbar-actions{display:flex;gap:6px}.rp-page-modal__sel-btn{background:none;border:1px solid var(--rp-card-border);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;color:var(--rp-purple-700);cursor:pointer;transition:background .15s,border-color .15s}.rp-page-modal__sel-btn:hover{background:var(--rp-purple-light);border-color:var(--rp-purple-600)}.rp-page-modal__grid{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;scrollbar-width:thin;scrollbar-color:var(--rp-purple-muted) transparent}.rp-page-modal__grid::-webkit-scrollbar{width:5px}.rp-page-modal__grid::-webkit-scrollbar-thumb{background:var(--rp-purple-muted);border-radius:10px}.rp-page-thumb{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;border-radius:10px;padding:6px;transition:background .15s;-webkit-user-select:none;user-select:none}.rp-page-thumb:hover{background:var(--rp-purple-light)}.rp-page-thumb--selected{background:#6040b81a}.rp-page-thumb__img-wrap{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:7px;overflow:hidden;border:2px solid transparent;transition:border-color .15s,box-shadow .15s;background:var(--rp-purple-light)}.rp-page-thumb--selected .rp-page-thumb__img-wrap{border-color:var(--rp-purple-600);box-shadow:0 0 0 3px #6040b833}.rp-page-thumb__img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.rp-page-thumb__check{position:absolute;top:5px;right:5px;width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.8);background:#ffffff40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;color:#fff}.rp-page-thumb__check--on{background:var(--rp-purple-700);border-color:#fff}.rp-page-thumb__label{font-size:11px;font-weight:500;color:var(--rp-text-muted);text-align:center}.rp-page-thumb--selected .rp-page-thumb__label{color:var(--rp-purple-800);font-weight:700}.rp-page-modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--rp-card-border);flex-shrink:0;background:#faf9fe}.rp-page-modal__cancel{padding:8px 18px;background:none;border:1px solid var(--rp-card-border);border-radius:8px;font-size:13.5px;font-weight:500;color:var(--rp-text-muted);cursor:pointer;transition:background .15s,border-color .15s}.rp-page-modal__cancel:hover{background:#f3f0fb;border-color:var(--rp-purple-muted)}.rp-page-modal__confirm{padding:8px 20px;background:var(--rp-purple-800);color:#fff;border:none;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .18s,transform .1s}.rp-page-modal__confirm:hover:not(:disabled){background:var(--rp-purple-700)}.rp-page-modal__confirm:active:not(:disabled){transform:scale(.97)}.rp-page-modal__confirm:disabled{opacity:.45;cursor:not-allowed}@media(max-width:600px){.rp-page-modal{max-width:100%;max-height:92vh;border-radius:12px}.rp-page-modal__grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.text-tool-editor{position:absolute;z-index:200;display:flex;flex-direction:column;min-width:280px;max-width:480px;background:var(--modal-surface2);border:1.5px solid var(--border2, #cbd5e1);border-radius:10px;box-shadow:0 4px 20px #0000001f;overflow:hidden;pointer-events:all}.text-tool-editor__toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:4px 6px;background:var(--modal-surface2);border-bottom:1px solid var(--border, #e2e8f0)}.text-tool-editor__btn{display:flex;align-items:center;justify-content:center;min-width:32px;min-height:32px;padding:0 6px;background:transparent;border:1.5px solid transparent;border-radius:6px;color:var(--wb-fg, #1e293b);font-size:14px;cursor:pointer;transition:background .12s,border-color .12s;touch-action:manipulation}.text-tool-editor__btn:hover{background:var(--wb-hover, #f1f5f9)}.text-tool-editor__btn.is-active{background:var(--wb-active-bg, #eff6ff);border-color:var(--wb-accent, #2563eb);color:var(--wb-accent, #2563eb)}.text-tool-editor__btn--commit{color:#059669;font-weight:700;font-size:16px}.text-tool-editor__btn--commit:hover{background:#ecfdf5}.text-tool-editor__select{height:32px;padding:0 6px;background:var(--modal-surface2);border:1.5px solid var(--border, #e2e8f0);border-radius:6px;color:var(--wb-fg, #1e293b);font-size:13px;cursor:pointer;outline:none;max-width:90px}.text-tool-editor__select--size{max-width:58px}.text-tool-editor__select:focus{border-color:var(--wb-accent, #2563eb)}.text-tool-editor__divider{width:1px;height:20px;background:var(--border, #e2e8f0);margin:0 3px;flex-shrink:0}.text-tool-editor__content{min-width:200px;min-height:44px;max-height:240px;padding:8px 10px;outline:none;overflow-y:auto;line-height:1.4;word-break:break-word;white-space:pre-wrap;caret-color:var(--wb-accent, #2563eb)}.text-tool-editor__content:empty:before{content:attr(data-placeholder);color:#94a3b8;pointer-events:none}.text-tool-editor__content a{color:var(--wb-accent, #2563eb);text-decoration:underline}.presence-overlay{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:60}.presence-cursor{position:absolute;top:0;left:0;display:flex;align-items:flex-start;gap:4px;transform:translate(var(--pc-x, 0px),var(--pc-y, 0px));transition:transform 60ms linear;will-change:transform}.presence-cursor__arrow{flex-shrink:0;filter:drop-shadow(0 1px 3px rgba(0,0,0,.35))}.presence-cursor__label{margin-top:1px;padding:2px 8px;border-radius:10px;background:var(--pc-col, #3498DB);color:#fff;font-size:11px;font-weight:600;font-family:system-ui,-apple-system,sans-serif;line-height:16px;white-space:nowrap;box-shadow:0 1px 4px #00000040;animation:presence-fade-in .15s ease}@keyframes presence-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.annotation-layer{position:absolute;inset:0;pointer-events:none;z-index:48;overflow:hidden}.annotation-layer__placing-banner{position:absolute;top:12px;left:50%;transform:translate(-50%);background:var(--teal, #0d9488);color:#fff;font-size:13px;font-weight:600;padding:7px 18px;border-radius:var(--radius-pill);white-space:nowrap;box-shadow:0 2px 12px #00000040;pointer-events:none;animation:ann-banner-in .15s ease-out}@keyframes ann-banner-in{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ann-pin{position:absolute;transform:translate(-50%,-100%);pointer-events:auto;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50% 50% 50% 0;transform:translate(-50%,-100%) rotate(-45deg);background:var(--teal, #0d9488);border:2.5px solid #fff;box-shadow:0 2px 8px #0000004d;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease;z-index:1}.ann-pin:hover{transform:translate(-50%,-108%) rotate(-45deg) scale(1.12);box-shadow:0 4px 14px #00000061}.ann-pin--active{background:var(--blue, #2563eb);transform:translate(-50%,-110%) rotate(-45deg) scale(1.15);box-shadow:0 4px 16px #2563eb80;border-color:#fff}.ann-pin--resolved{background:var(--modal-surface2);border-color:var(--border, #cbd5e1);opacity:.65}.ann-pin--resolved:hover{opacity:.85}.ann-pin__icon{display:block;transform:rotate(45deg);font-size:15px;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.2))}.ann-pin__badge{position:absolute;top:-6px;right:-6px;transform:rotate(45deg);background:var(--modal-bg);color:var(--text, #1e293b);font-size:11px;font-weight:700;line-height:1;min-width:16px;height:16px;padding:0 3px;border-radius:var(--radius-pill);border:1.5px solid var(--teal, #0d9488);display:flex;align-items:center;justify-content:center;pointer-events:none}.ann-pin--active .ann-pin__badge{border-color:var(--blue, #2563eb)}.playback-bar{position:absolute;bottom:90px;left:50%;transform:translate(-50%);z-index:150;display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:999px;white-space:nowrap;background:var(--color-surface, #ffffff);border:1.5px solid var(--color-border, #e2e8f0);box-shadow:0 4px 20px #0000001f,0 1px 4px #0000000f;font-family:var(--font-ui, "Nunito Sans", sans-serif);font-size:13px;color:var(--color-text, #1e293b);animation:pb-slidein .22s cubic-bezier(.34,1.56,.64,1) both}@keyframes pb-slidein{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.playback-bar--playing{border-color:#6366f1;box-shadow:0 4px 20px #6366f12e,0 1px 4px #6366f11a}.playback-bar__label{display:flex;align-items:center;gap:6px;flex-shrink:0}.playback-bar__icon{font-size:14px}.playback-bar__title{font-weight:600;font-size:13px;color:var(--color-text-secondary, #475569)}.playback-bar--playing .playback-bar__title{color:#6366f1}.playback-bar__progress-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:120px;max-width:240px}.playback-bar__progress-track{flex:1;height:5px;border-radius:999px;background:var(--color-border, #e2e8f0);overflow:hidden}.playback-bar__progress-fill{height:100%;border-radius:999px;background:#6366f1;transition:width .15s linear}.playback-bar__time{display:flex;align-items:center;gap:2px;font-size:12px;font-variant-numeric:tabular-nums;color:var(--color-text-secondary, #64748b);flex-shrink:0}.playback-bar__time-sep{margin:0 1px;opacity:.5}.playback-bar__speeds{display:flex;gap:3px;flex-shrink:0}.playback-bar__speed-btn{padding:3px 8px;border-radius:var(--radius-pill);border:1.5px solid var(--color-border, #e2e8f0);background:transparent;font-size:12px;font-weight:600;color:var(--color-text-secondary, #64748b);cursor:pointer;transition:background .12s,color .12s,border-color .12s;line-height:1}.playback-bar__speed-btn:hover{background:var(--color-hover, #f1f5f9);border-color:#94a3b8}.playback-bar__speed-btn--active{background:#6366f1;border-color:#6366f1;color:#fff}.playback-bar__action{flex-shrink:0;padding:6px 14px;border-radius:var(--radius-pill);border:none;font-size:13px;font-weight:700;cursor:pointer;transition:background .12s,transform .1s;line-height:1}.playback-bar__action:active{transform:scale(.96)}.playback-bar__action--play{background:#6366f1;color:#fff}.playback-bar__action--play:hover{background:#4f46e5}.playback-bar__action--stop{background:#fee2e2;color:#dc2626}.playback-bar__action--stop:hover{background:#fecaca}.playback-bar__dismiss{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:none;background:transparent;font-size:13px;color:var(--color-text-secondary, #94a3b8);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:2px;transition:background .12s,color .12s;line-height:1}.playback-bar__dismiss:hover{background:var(--color-hover, #f1f5f9);color:var(--color-text, #1e293b)}@font-face{font-display:block;font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2) format("woff2"),url(/assets/KaTeX_AMS-Regular-DMm9YOAa.woff) format("woff"),url(/assets/KaTeX_AMS-Regular-DRggAlZN.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff) format("woff"),url(/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff) format("woff"),url(/assets/KaTeX_Fraktur-Regular-CB_wures.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-Cx986IdX.woff2) format("woff2"),url(/assets/KaTeX_Main-Bold-Jm3AIy58.woff) format("woff"),url(/assets/KaTeX_Main-Bold-waoOVXN0.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2) format("woff2"),url(/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff) format("woff"),url(/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2) format("woff2"),url(/assets/KaTeX_Main-Italic-BMLOBm91.woff) format("woff"),url(/assets/KaTeX_Main-Italic-3WenGoN9.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-B22Nviop.woff2) format("woff2"),url(/assets/KaTeX_Main-Regular-Dr94JaBh.woff) format("woff"),url(/assets/KaTeX_Main-Regular-ypZvNtVU.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2) format("woff2"),url(/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff) format("woff"),url(/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-t53AETM-.woff2) format("woff2"),url(/assets/KaTeX_Math-Italic-DA0__PXp.woff) format("woff"),url(/assets/KaTeX_Math-Italic-flOr_0UB.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff) format("woff"),url(/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff) format("woff"),url(/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff) format("woff"),url(/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-D3wIWfF6.woff2) format("woff2"),url(/assets/KaTeX_Script-Regular-D5yQViql.woff) format("woff"),url(/assets/KaTeX_Script-Regular-C5JkGWo-.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2) format("woff2"),url(/assets/KaTeX_Size1-Regular-C195tn64.woff) format("woff"),url(/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2) format("woff2"),url(/assets/KaTeX_Size2-Regular-oD1tc_U0.woff) format("woff"),url(/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA4oAA4AAAAAHbQAAA3TAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAABmAAgRQIDgmcDBEICo1oijYBNgIkA14LMgAEIAWJAAeBHAyBHBvbGiMRdnO0IkRRkiYDgr9KsJ1NUAf2kILNxgUmgqIgq1P89vcbIcmsQbRps3vCcXdYOKSWEPEKgZgQkprQQsxIXUgq0DqpGKmIvrgkeVGtEQD9DzAO29fM9jYhxZEsL2FeURH2JN4MIcTdO049NCVdxQ/w9NrSYFEBKTDKpLKfNkCGDc1RwjZLQcm3vqJ2UW9Xfa3tgAHz6ivp6vgC2yD4/6352ndnN0X0TL7seypkjZlMsjmZnf0Mm5Q+JykRWQBKCVCVPbARPXWyQtb5VgLB6Biq7/Uixcj2WGqdI8tGSgkuRG+t910GKP2D7AQH0DB9FMDW/obJZ8giFI3Wg8Cvevz0M+5m0rTh7XDBlvo9Y4vm13EXmfttwI4mBo1EG15fxJhUiCLbiiyCf/ZA6MFAhg3pGIZGdGIVjtPn6UcMk9A/UUr9PhoNsCENw1APAq0gpH73e+M+0ueyHbabc3vkbcdtzcf/fiy+NxQEjf9ud/ELBHAXJ0nk4z+MXH2Ev/kWyV4k7SkvpPc9Qr38F6RPWnM9cN6DJ0AdD1BhtgABtmoRoFCvPsBAumNm6soZG2Gk5GyVTo2sJncSyp0jQTYoR6WDvTwaaEcHsxHfvuWhHA3a6bN7twRKtcGok6NsCi7jYRrM2jExsUFMxMQYuJbMhuWNOumEJy9hi29Dmg5zMp/A5+hhPG19j1vBrq8JTLr8ki5VLPmG/PynJHVul440bxg5xuymHUFPBshC+nA9I1FmwbRBTNHAcik3Oae0cxKoI3MOriM42UrPe51nsaGxJ+WfXubAsP84aabUlQSJ1IiE0iPETLUU4CATgfXSCSpuRFRmCGbO+wSpAnzaeaCYW1VNEysRtuXCEL1kUFUbbtMv3Tilt/1c11jt3Q5bbMa84cpWipp8Elw3MZhOHsOlwwVUQM3lAR35JiFQbaYCRnMF2lxAWoOg2gyoIV4PouX8HytNIfLhqpJtXB4vjiViUI8IJ7bkC4ikkQvKksnOTKICwnqWSZ9YS5f0WCxmpgjbIq7EJcM4aI2nmhLNY2JIUgOjXZFWBHb+x5oh6cwb0Tv1ackHdKi0I9OO2wE9aogIOn540CCCziyhN+IaejtgAONKznHlHyutPrHGwCx9S6B8kfS4Mfi4Eyv7OU730bT1SCBjt834cXsf43zVjPUqqJjgrjeGnBxSG4aYAKFuVbeCfkDIjAqMb6yLNIbCuvXhMH2/+k2vkNpkORhR59N1CkzoOENvneIosjYmuTxlhUzaGEJQ/iWqx4dmwpmKjrwTiTGTCVozNAYqk/zXOndWxuWSmJkQpJw3pK5KX6QrLt5LATMqpmPAQhkhK6PUjzHUn7E0gHE0kPE0iKkolgkUx9SZmVAdDgpffdyJKg3k7VmzYGCwVXGz/tXmkOIp+vcWs+EMuhhvN0h9uhfzWJziBQmCREGSIFmQIkgVpAnSBRmC//6hkLZwaVhwxlrJSOdqlFtOYxlau9F2QN5Y98xmIAsiM1HVp2VFX+DHHGg6Ecjh3vmqtidX3qHI2qycTk/iwxSt5UzTmEP92ZBnEWTk4Mx8Mpl78ZDokxg/KWb+Q0QkvdKVmq3TMW+RXEgrsziSAfNXFMhDc60N5N9jQzjfO0kBKpUZl0ZmwJ41j/B9Hz6wmRaJB84niNmQrzp9eSlQCDDzazGDdVi3P36VZQ+Jy4f9UBNp+3zTjqI4abaFAm+GShVaXlsGdF3FYzZcDI6cori4kMxUECl9IjJZpzkvitAoxKue+90pDMvcKRxLl53TmOKCmV/xRolNKSqqUxc6LStOETmFOiLZZptlZepcKiAzteG8PEdpnQpbOMNcMsR4RR2Bs0cKFEvSmIjAFcnarqwUL4lDhHmnVkwu1IwshbiCcgvOheZuYyOteufZZwlcTlLgnZ3o/WcYdzZHW/WGaqaVfmTZ1aWCceJjkbZqsfbkOtcFlUZM/jy+hXHDbaUobWqqXaeWobbLO99yG5N3U4wxco0rQGGcOLASFMXeJoham8M+/x6O2WywK2l4HGbq1CoUyC/IZikQhdq3SiuNrvAEj0AVu9x2x3lp/xWzahaxidezFVtdcb5uEnzyl0ZmYiuKI0exvCd4Xc9CV1KB0db00z92wDPde0kukbvZIWN6jUWFTmPIC/Y4UPCm8UfDTFZpZNon1qLFTkBhxzB+FjQRA2Q/YRJT8pQigslMaUpFyAG8TMlXigiqmAZX4xgijKjRlGpLE0GdplRfCaJo0JQaSxNBk6ZmMzcya0FmrcisDdn0Q3HI2sWSppYigmlM1XT/kLQZSNpMJG0WkjYbSZuDpM1F0uYhFc1HxU4m1QJjDK6iL0S5uSj5rgXc3RejEigtcRBtqYPQsiTskmO5vosV+q4VGIKbOkDg0jtRrq+Em1YloaTFar3EGr1EUC8R0kus1Uus00usL97ABr2BjXoDm/QGNhuWtMVBKOwg/i78lT7hBsAvDmwHc/ao3vmUbBmhjeYySZNWvGkfZAgISDSaDo1SVpzGDsAEkF8B+gEapViUoZgUWXcRIGFZNm6gWbAKk0bp0k1MHG9fLYtV4iS2SmLEQFARzRcnf9PUS0LVn05/J9MiRRBU3v2IrvW974v4N00L7ZMk0wXP1409CHo/an8zTRHD3eSJ6m8D4YMkZNl3M79sqeuAsr/m3f+8/yl7A50aiAEJgeBeMWzu7ui9UfUBCe2TIqZIoOd/3/udRBOQidQZUERzb2/VwZN1H/Sju82ew2H2Wfr6qvfVf3hqwDvAIpkQVFy4B9Pe9e4/XvPeceu7h3dvO56iJPf0+A6cqA2ip18ER+iFgggiuOkvj24bby0N9j2UHIkgqIt+sVgfodC4YghLSMjSZbH0VR/6dMDrYJeKHilKTemt6v6kvzvn3/RrdWtr0GoN/xL+Sex/cPYLUpepx9cz/D46UPU5KXgAQa+NDps1v6J3xP1i2HtaDB0M9aX2deA7SYff//+gUCovMmIK/qfsFcOk+4Y5ZN97XlG6zebqtMbKgeRFi51vnxTQYBUik2rS/Cn6PC8ADR8FGxsRPB82dzfND90gIcshOcYUkfjherBz53odpm6TP8txlwOZ71xmfHHOvq053qFF/MRlS3jP0ELudrf2OeN8DHvp6ZceLe8qKYvWz/7yp0u4dKPfli3CYq0O13Ih71mylJ80tOi10On8wi+F4+LWgDPeJ30msSQt9/vkmHq9/Lvo2b461mP801v3W4xTcs6CbvF9UDdrSt+A8OUbpSh55qAUFXWznBBfdeJ8a4d7ugT5tvxUza3h9m4H7ptTqiG4z0g5dc0X29OcGlhpGFMpQo9ytTS+NViZpNdvU4kWx+LKxNY10kQ1yqGXrhe4/1nvP7E+nd5A92TtaRplbHSqoIdOqtRWti+fkB5/n1+/VvCmz12pG1kpQWsfi1ftlBobm0bpngs16CHkbIwdLnParxtTV3QYRlfJ0KFskH7pdN/YDn+yRuSd7sNH3aO0DYPggk6uWuXrfOc+fa3VTxFVvKaNxHsiHmsXyCLIE5yuOeN3/Jdf8HBL/5M6shjyhxHx9BjB1O0+4NLOnjLLSxwO7ukN4jMbOIcD879KLSi6Pk61Oqm2377n8079PXEEQ7cy7OKEC9nbpet118fxweTafpt69x/Bt8UqGzNQt7aelpc44dn5cqhwf71+qKp/Zf/+a0zcizOUWpl/iBcSXip0pplkatCchoH5c5aUM8I7/dWxAej8WicPL1URFZ9BDJelUwEwTkGqUhgSlydVes95YdXvhh9Gfz/aeFWvgVb4tuLbcv4+wLdutVZv/cUonwBD/6eDlE0aSiKK/uoH3+J1wDE/jMVqY2ysGufN84oIXB0sPzy8ollX/LegY74DgJXJR57sn+VGza0x3DnuIgABFM15LmajjjsNlYj+JEZGbuRYcAMOWxFkPN2w6Wd46xo4gVWQR/X4lyI/R6K/YK0110GzudPRW7Y+UOBGTfNNzHeYT0fiH0taunBpq9HEW8OKSaBGj21L0MqenEmNRWBAWDWAk4CpNoEZJ2tTaPFgbQYj8HxtFilErs3BTRwT8uO1NXQaWfIotchmPkAF5mMBAliEmZiOGVgCG9LgRzpscMAOOwowlT3JhusdazXGSC/hxR3UlmWVwWHpOIKheqONvjyhSiTHIkVUco5bnji8m//zL7PKaT1Vl5I6UE609f+gkr6MZKVyKc7zJRmCahLsdlyA5fdQkRSan9LgnnLEyGSkaKJCJog0wAgvepWBt80+1yKln1bMVtCljfNWDueKLsWwaEbBSfSPTEmVRsUcYYMnEjcjeyCZzBXK9E9BYBXLKjOSpUDR+nEV3TFSUdQaz+ot98QxgXwx0GQ+EEUAKB2qZPkQQ0GqFD8UPFMqyaCHM24BZmSGic9EYMagKizOw9Hz50DMrDLrqqLkTAhplMictiCAx5S3BIUQdeJeLnBy2CNtMfz6cV4u8XKoFZQesbf9YZiIERiHjaNodDW6LgcirX/mPnJIkBGDUpTBhSa0EIr38D5hCIszhCM8URGBqImoWjpvpt1ebu/v3Gl3qJfMnNM+9V+kiRFyROTPHQWOcs1dNW94/ukKMPZBvDi55i5CttdeJz84DLngLqjcdwEZ87bFFR8CIG35OAkDVN6VRDZ7aq67NteYqZ2lpT8oYB2CytoBd6VuAx4WgiAsnuj3WohG+LugzXiQRDeM3XYXlULv4dp5VFYC) format("woff2"),url(/assets/KaTeX_Size3-Regular-CTq5MqoE.woff) format("woff"),url(/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2) format("woff2"),url(/assets/KaTeX_Size4-Regular-BF-4gkZK.woff) format("woff"),url(/assets/KaTeX_Size4-Regular-DWFBv043.ttf) format("truetype")}@font-face{font-display:block;font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2) format("woff2"),url(/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff) format("woff"),url(/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf) format("truetype")}.katex{font: 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.38"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:-webkit-min-content;width:-moz-min-content;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .smash{display:inline;line-height:0}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex svg{fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.wem-backdrop{position:fixed;inset:0;background:#00000059;z-index:300;opacity:0;transition:opacity .14s ease;pointer-events:none}.wem-backdrop.is-open{opacity:1;pointer-events:auto}@keyframes wem-fade-in{0%{opacity:0}to{opacity:1}}.wem{position:fixed;top:50%;left:50%;width:420px;max-width:calc(100vw - 32px);max-height:calc(100vh - 48px);overflow-y:auto;background:var(--modal-bg);border:1.5px solid var(--brand-border);border-radius:16px;box-shadow:0 24px 64px #0000002e,0 4px 16px #00000014;z-index:301;display:flex;flex-direction:column;opacity:0;transform:translate(-50%,-48%) scale(.96);transition:opacity .16s cubic-bezier(.34,1.36,.64,1),transform .16s cubic-bezier(.34,1.36,.64,1);pointer-events:none}.wem.is-open{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}@keyframes wem-slide-in{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.wem__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0}.wem__title-row{display:flex;align-items:center;gap:10px}.wem__title-icon{font-size:18px;width:34px;height:34px;background:var(--brand-hover);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--brand-text);font-style:normal}.wem__title{font-size:17px;font-weight:700;color:var(--brand-text);margin:0}.wem__close{width:32px;height:32px;border:none;background:transparent;color:var(--brand-text-sub);font-size:16px;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .1s}.wem__close:hover{background:#ffffff1f;color:var(--brand-text)}.wem__section{padding:16px 20px;border-bottom:1px solid var(--border, #f1f5f9)}.wem__section:last-of-type{border-bottom:none}.wem__section--row{display:flex;align-items:center;justify-content:space-between;gap:16px}.wem__section-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text2, #64748b);margin:0 0 10px}.wem__section-sub{font-size:12px;color:var(--text2, #94a3b8);margin:2px 0 0}.wem__formats{display:flex;flex-direction:column;gap:6px}.wem__fmt-btn{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);cursor:pointer;text-align:left;transition:border-color .1s,background .1s;min-height:52px}.wem__fmt-btn:hover{background:color-mix(in srgb,var(--teal, #0d9488) 5%,var(--modal-surface2));border-color:color-mix(in srgb,var(--teal, #0d9488) 30%,var(--border, #e2e8f0))}.wem__fmt-btn--active{background:color-mix(in srgb,var(--teal, #0d9488) 8%,transparent);border-color:var(--teal, #0d9488)}.wem__fmt-icon{font-size:20px;flex-shrink:0;width:28px;text-align:center}.wem__fmt-label{font-size:14px;font-weight:600;color:var(--text, #1e293b);flex:1}.wem__fmt-sub{font-size:11px;color:var(--text2, #94a3b8);white-space:nowrap}.wem__scale-row{display:flex;gap:8px}.wem__scale-btn{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px 8px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);cursor:pointer;transition:border-color .1s,background .1s;min-height:56px}.wem__scale-btn:hover{border-color:color-mix(in srgb,var(--teal, #0d9488) 40%,var(--border))}.wem__scale-btn--active{background:color-mix(in srgb,var(--teal, #0d9488) 8%,transparent);border-color:var(--teal, #0d9488)}.wem__scale-mult{font-size:18px;font-weight:800;color:var(--text, #1e293b);line-height:1}.wem__scale-sub{font-size:11px;color:var(--text2, #94a3b8);margin-top:4px;text-align:center}.wem__toggle-info{flex:1}.wem__toggle-info .wem__section-label{margin-bottom:0}.wem__toggle{width:44px;height:26px;border-radius:var(--radius-pill);border:none;background:var(--border, #cbd5e1);cursor:pointer;position:relative;flex-shrink:0;transition:background .16s;padding:0}.wem__toggle--on{background:var(--teal, #0d9488)}.wem__toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0000002e;transition:transform .16s cubic-bezier(.34,1.3,.64,1)}.wem__toggle--on .wem__toggle-knob{transform:translate(18px)}.wem__quality-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.wem__quality-value{font-size:13px;font-weight:700;color:var(--teal, #0d9488)}.wem__slider{width:100%;accent-color:var(--teal, #0d9488);height:4px;cursor:pointer}.wem__slider-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text2, #94a3b8);margin-top:6px}.wem__footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--border, #e2e8f0);flex-shrink:0}.wem__cancel-btn{flex:1;padding:10px 16px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:transparent;color:var(--text2, #64748b);font-size:14px;font-weight:600;cursor:pointer;transition:background .1s;min-height:44px}.wem__cancel-btn:hover{background:var(--modal-surface2)}.wem__export-btn{flex:2;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;border:none;background:var(--teal, #0d9488);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .12s;min-height:44px}.wem__export-btn:hover{opacity:.88}.wem__export-btn:disabled{opacity:.5;cursor:not-allowed}.wem__optional{font-weight:400;text-transform:none;letter-spacing:0;font-size:11px;color:var(--text2, #94a3b8)}.wem__filename{width:100%;box-sizing:border-box;padding:9px 12px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);color:var(--text, #1e293b);font-size:14px;outline:none;transition:border-color .12s}.wem__filename::placeholder{color:var(--text2, #94a3b8)}.wem__filename:focus{border-color:var(--teal, #0d9488);background:var(--modal-bg)}.wem__notice{display:flex;align-items:center;gap:8px;margin:0 20px 4px;padding:10px 14px;background:color-mix(in srgb,var(--teal, #0d9488) 8%,transparent);border:1.5px solid color-mix(in srgb,var(--teal, #0d9488) 25%,transparent);border-radius:10px;font-size:12.5px;color:var(--text, #1e293b);line-height:1.45}.wem__notice-icon{font-size:15px;flex-shrink:0;color:var(--teal, #0d9488);font-weight:700}.wem__pagesize-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.wem__ps-btn{padding:8px 6px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);font-size:12.5px;font-weight:600;color:var(--text, #1e293b);cursor:pointer;transition:border-color .1s,background .1s;white-space:nowrap;text-align:center}.wem__ps-btn:hover{border-color:color-mix(in srgb,var(--teal, #0d9488) 40%,var(--border))}.wem__ps-btn--active{background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent);border-color:var(--teal, #0d9488);color:var(--teal, #0d9488)}.wem__orient-toggle{display:flex;gap:6px;margin-top:8px}.wem__orient-pill{flex:1;padding:7px 10px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);font-size:12.5px;font-weight:600;color:var(--text2, #64748b);cursor:pointer;transition:border-color .1s,background .1s}.wem__orient-pill--active{background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent);border-color:var(--teal, #0d9488);color:var(--teal, #0d9488)}.wem__ps-note{margin:8px 0 0;font-size:11.5px;color:var(--text2, #64748b);font-style:italic}.wem__spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:wem-spin .7s linear infinite;flex-shrink:0}@keyframes wem-spin{to{transform:rotate(360deg)}}.wem__scope-row{display:flex;gap:6px;margin-bottom:10px}.wem__scope-pill{flex:1;padding:7px 10px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);font-size:12.5px;font-weight:600;color:var(--text-sub, #64748b);cursor:pointer;transition:border-color .12s ease,background .12s ease,color .12s ease;white-space:nowrap}.wem__scope-pill:hover{border-color:color-mix(in srgb,var(--teal, #0d9488) 40%,var(--border));color:var(--text, #1e293b)}.wem__scope-pill--active{background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent);border-color:var(--teal, #0d9488);color:var(--teal, #0d9488)}.wem__current-page{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--modal-surface2);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;animation:wem-fade-in .12s ease}.wem__pg-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1.5px solid rgba(0,0,0,.08)}.wem__pg-num{font-size:11px;font-weight:800;letter-spacing:.06em;color:var(--teal, #0d9488);min-width:14px;text-align:center}.wem__pg-name{font-size:13px;font-weight:500;color:var(--text, #1e293b);flex:1}.wem__all-pages{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--modal-surface2);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;animation:wem-fade-in .12s ease}.wem__all-pages-dots{display:flex;align-items:center;gap:4px;flex-shrink:0}.wem__all-pages-more{font-size:11px;font-weight:700;color:var(--text-muted, #94a3b8)}.wem__all-pages-label{font-size:12px;color:var(--text-sub, #64748b);font-style:italic}.wem__page-chooser{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;scrollbar-width:thin;border-radius:10px;animation:wem-fade-in .12s ease}.wem__page-chooser::-webkit-scrollbar{width:4px}.wem__page-chooser::-webkit-scrollbar-track{background:transparent}.wem__page-chooser::-webkit-scrollbar-thumb{background:var(--border, #e2e8f0);border-radius:var(--radius-pill)}.wem__page-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;border:1.5px solid var(--border, #e2e8f0);background:var(--modal-surface2);cursor:pointer;text-align:left;transition:border-color .1s ease,background .1s ease;min-height:40px}.wem__page-item:hover{border-color:color-mix(in srgb,var(--teal, #0d9488) 35%,var(--border))}.wem__page-item--checked{background:color-mix(in srgb,var(--teal, #0d9488) 7%,transparent);border-color:var(--teal, #0d9488)}.wem__page-item__stripe{width:4px;height:22px;border-radius:2px;flex-shrink:0;opacity:.7}.wem__page-item--checked .wem__page-item__stripe{opacity:1}.wem__page-item__num{font-size:11px;font-weight:800;letter-spacing:.05em;color:var(--text-muted, #94a3b8);min-width:16px;text-align:center;transition:color .1s ease}.wem__page-item--checked .wem__page-item__num{color:var(--teal, #0d9488)}.wem__page-item__name{font-size:13px;font-weight:500;color:var(--text, #1e293b);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wem__page-item__check{flex-shrink:0;width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border2, #cbd5e1);background:var(--modal-bg);display:flex;align-items:center;justify-content:center;transition:border-color .12s ease,background .12s ease}.wem__page-item__check.is-checked{border-color:var(--teal, #0d9488);background:var(--teal, #0d9488);color:#fff}.wem__chooser-count{font-size:11.5px;color:var(--text-sub, #64748b);font-style:italic;margin:2px 0 0 4px;padding:0}.layer-panel{position:absolute;top:0;right:0;bottom:0;width:var(--layer-panel-w);max-width:calc(100vw - 72px);background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:-4px 0 24px #0000001a;z-index:310;display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none;opacity:0;transform:translate(16px);transition:opacity .18s cubic-bezier(.4,0,.2,1),transform .18s cubic-bezier(.4,0,.2,1);pointer-events:none}.layer-panel.is-open{opacity:1;transform:translate(0);pointer-events:auto}@keyframes layer-panel-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.layer-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;border-bottom:1px solid var(--brand-border);background:var(--brand-bg);flex-shrink:0;gap:12px}.layer-panel__title-row{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.layer-panel__header-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--brand-hover);color:var(--brand-text);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.layer-panel__icon{font-size:20px;flex-shrink:0}.layer-panel__title-text{display:flex;flex-direction:column;gap:2px;min-width:0}.layer-panel__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0;font-family:var(--font-body, sans-serif);line-height:1.3}.layer-panel__subtitle{font-size:12px;color:var(--brand-text-sub);font-family:var(--font-body, sans-serif);margin:0}.layer-panel__count{background:#ffffff2e;color:var(--brand-text);font-size:11px;font-weight:700;padding:1px 7px;border-radius:var(--radius-pill);min-width:20px;text-align:center;font-family:var(--font-body, sans-serif)}.layer-panel__header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.layer-panel__group-btn,.layer-panel__merge-btn{display:flex;align-items:center;height:30px;padding:0 10px;border-radius:8px;font-size:12px;font-weight:700;font-family:var(--font-body, sans-serif);cursor:pointer;white-space:nowrap;transition:background .12s}.layer-panel__group-btn{border:1.5px solid rgba(255,255,255,.3);background:#ffffff14;color:var(--brand-text)}.layer-panel__group-btn:hover{background:#ffffff29}.layer-panel__merge-btn{border:1.5px solid rgba(255,255,255,.3);background:#ffffff14;color:var(--brand-text)}.layer-panel__merge-btn:hover{background:#ffffff29}.layer-panel__add{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--brand-text);font-size:20px;cursor:pointer;transition:background .12s}.layer-panel__add:hover{background:#ffffff1f}.layer-panel__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--brand-text-sub);font-size:14px;cursor:pointer;transition:background .12s,color .12s}.layer-panel__close:hover{background:#ffffff1f;color:var(--brand-text)}.layer-panel__hint{padding:6px 14px;font-size:12px;font-family:var(--font-body, sans-serif);color:var(--teal, #0d9488);background:var(--teal-xl, #f0fdfa);border-bottom:1px solid var(--border, #e2e8f0);text-align:center;flex-shrink:0}.layer-panel__list{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.layer-panel__footer{padding:10px 14px;border-top:1px solid var(--border, #e2e8f0);background:var(--modal-surface2);font-size:11px;color:var(--text-muted, #94a3b8);font-family:var(--font-body, sans-serif);text-align:center;flex-shrink:0}.layer-row{display:flex;flex-direction:column;min-height:48px;padding:4px 10px;cursor:pointer;border-bottom:1px solid var(--border, #f1f5f9);transition:background .1s}.layer-row:last-child{border-bottom:none}.layer-row.is-active{background:var(--teal-xl, #f0fdfa);border-left:3px solid var(--teal, #0d9488);padding-left:7px}.layer-row.is-locked{background:#fffbeb}.layer-row.is-active.is-locked{background:color-mix(in srgb,#f0fdfa 60%,#fffbeb 40%)}.layer-row.is-selected{background:#eff6ff;border-left:3px solid #3b82f6;padding-left:7px}.layer-row.is-active.is-selected{background:color-mix(in srgb,#f0fdfa 50%,#eff6ff 50%);border-left:3px solid var(--teal, #0d9488)}.layer-row.is-group{background:var(--modal-surface2)}.layer-row.is-group.is-active{background:var(--teal-xl, #f0fdfa)}.layer-row.is-child{background:#fcfcfd}.layer-row.is-child:hover{background:var(--modal-surface2)}.layer-row__strip{display:flex;align-items:center;gap:4px;min-height:40px}.layer-row__collapse{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;background:transparent;font-size:11px;color:var(--text-muted, #94a3b8);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s}.layer-row__collapse:hover{background:var(--modal-surface2);color:var(--text, #1e293b)}.layer-row__child-indent{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:11px;color:var(--text-muted, #cbd5e1);flex-shrink:0;pointer-events:none}.layer-row__eye,.layer-row__lock{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;font-size:15px;cursor:pointer;flex-shrink:0;transition:background .12s,opacity .12s}.layer-row__eye:hover,.layer-row__lock:hover{background:var(--modal-surface2)}.layer-row__eye.is-hidden{opacity:.4}.layer-row__lock{opacity:.45}.layer-row__lock:hover{opacity:1}.layer-row__lock.is-locked{opacity:1;color:#d97706;background:#fef3c7}.layer-row__lock.is-locked:hover{background:#fde68a}.layer-row__name{flex:1;min-width:0;font-size:13px;font-weight:500;font-family:var(--font-body, sans-serif);color:var(--text, #1e293b);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-row.is-active .layer-row__name{color:var(--teal, #0d9488);font-weight:600}.layer-row.is-group .layer-row__name{font-weight:600}.layer-row.is-locked .layer-row__name{opacity:.55;font-style:italic}.layer-row.is-active.is-locked .layer-row__name{opacity:.7}.layer-row__rename-input{width:100%;font-size:13px;font-family:var(--font-body, sans-serif);color:var(--text, #1e293b);border:1.5px solid var(--teal, #0d9488);border-radius:4px;padding:2px 4px;outline:none;background:var(--modal-bg)}.layer-row__blend-badge{font-size:11px;font-weight:600;font-family:var(--font-body, sans-serif);color:var(--teal, #0d9488);background:var(--teal-xl, #f0fdfa);border:1px solid var(--teal, #0d9488);border-radius:4px;padding:1px 5px;white-space:nowrap;flex-shrink:0;opacity:.75;pointer-events:none}.layer-row__stroke-count{font-size:11px;font-weight:700;font-family:var(--font-body, sans-serif);color:var(--text-3, #94a3b8);background:var(--modal-surface2);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:0 6px;white-space:nowrap;flex-shrink:0;min-width:18px;text-align:center;margin-left:4px;pointer-events:none}.layer-row.is-active .layer-row__stroke-count{color:var(--teal, #0d9488);background:var(--teal-xl, #f0fdfa);border-color:var(--teal, #0d9488)}.layer-row__actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.layer-row__btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted, #94a3b8);font-size:13px;cursor:pointer;transition:background .12s,color .12s;padding:0}.layer-row__btn:hover{background:var(--modal-surface2);color:var(--text, #1e293b)}.layer-row__btn--delete:hover{background:#fee2e2;color:#dc2626}.layer-row__btn--ungroup{font-size:14px;color:var(--teal, #0d9488)}.layer-row__btn--ungroup:hover{background:var(--teal-xl, #f0fdfa);color:var(--teal, #0d9488)}.layer-row__btn--merge{font-size:12px;color:#7c3aed}.layer-row__btn--merge:hover{background:#f5f3ff;color:#6d28d9}.layer-row__btn:disabled{opacity:.3;cursor:not-allowed}.layer-row__btn:disabled:hover{background:transparent;color:var(--text-muted, #94a3b8)}.layer-row__blend-row{display:flex;align-items:center;gap:8px;padding:4px 2px 2px}.layer-row__blend-label{font-size:11px;font-weight:600;font-family:var(--font-body, sans-serif);color:var(--text-muted, #94a3b8);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;cursor:default}.layer-row__blend-select{flex:1;min-width:0;height:32px;font-size:12px;font-family:var(--font-body, sans-serif);color:var(--text, #1e293b);background:var(--modal-bg);border:1.5px solid var(--border, #e2e8f0);border-radius:8px;padding:0 8px;cursor:pointer;outline:none;transition:border-color .12s;appearance:auto}.layer-row__blend-select:focus,.layer-row__blend-select:hover{border-color:var(--teal, #0d9488)}.layer-row.is-locked .layer-row__blend-select{opacity:.6;pointer-events:none}.layer-row__filter-strip{padding:4px 2px 6px;border-top:1px solid var(--border, #e2e8f0);display:flex;flex-direction:column;gap:6px;margin-top:2px}.layer-row__filter-row{display:flex;align-items:center;gap:8px}.layer-row__filter-label{font-size:11px;font-weight:600;color:var(--text-secondary, #64748b);width:64px;flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.layer-row__filter-slider{flex:1;height:4px;accent-color:var(--teal, #0d9488);cursor:pointer;min-width:0}.layer-row__filter-value{font-size:11px;color:var(--text-secondary, #64748b);width:36px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.layer-row__filter-remove{background:none;border:none;cursor:pointer;color:var(--text-secondary, #64748b);font-size:16px;line-height:1;padding:0 2px;opacity:.55;flex-shrink:0;transition:opacity .12s,color .12s}.layer-row__filter-remove:hover{opacity:1;color:var(--danger, #ef4444)}.layer-row__filter-add-row{margin-top:2px}.layer-row__filter-add-btn{background:none;border:1.5px dashed var(--border, #cbd5e1);border-radius:6px;color:var(--text-secondary, #64748b);font-size:11px;padding:5px 10px;cursor:pointer;width:100%;text-align:left;transition:border-color .12s,color .12s}.layer-row__filter-add-btn:hover{border-color:var(--teal, #0d9488);color:var(--teal, #0d9488)}.layer-row__filter-picker{display:flex;flex-wrap:wrap;gap:4px}.layer-row__filter-pick-btn{background:var(--modal-surface2);border:1px solid var(--border, #e2e8f0);border-radius:6px;color:var(--text, #1e293b);font-size:11px;padding:5px 10px;cursor:pointer;min-height:32px;transition:background .12s,color .12s}.layer-row__filter-pick-btn:hover{background:var(--teal, #0d9488);color:#fff;border-color:var(--teal, #0d9488)}.layer-row__filter-pick-btn--cancel{color:var(--text-secondary, #64748b)}.layer-row__filter-pick-btn--cancel:hover{background:var(--modal-surface2);color:var(--text, #1e293b);border-color:var(--border, #e2e8f0)}@media(max-width:600px){.layer-panel{width:100%;max-width:100%;left:0;border-left:none;border-top:1px solid var(--border, #e2e8f0);top:auto;height:60vh;animation:layer-panel-up .2s cubic-bezier(.4,0,.2,1)}@keyframes layer-panel-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.layer-row__btn{width:32px;height:32px}}@media(max-width:767px){.layer-panel{position:fixed;top:var(--topbar-h, 60px);right:0;bottom:56px;width:100vw;max-width:100vw;z-index:200}}.global-library{position:fixed;inset:0;z-index:1200;pointer-events:none;font-family:var(--font-body, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif)}.global-library__backdrop{position:absolute;inset:0;background:#0f172a47;opacity:0;transition:opacity .22s ease}.global-library__drawer{position:absolute;top:0;right:0;height:100dvh;width:min(1120px,calc(100vw - var(--rail-w, 72px)));background:linear-gradient(180deg,#f8f7ff,#fff 46%,#f9fafb);border-left:1px solid rgba(124,58,237,.18);box-shadow:-34px 0 80px #0f172a38;transform:translate(104%);transition:transform .28s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;overflow:hidden}.global-library.is-open{pointer-events:auto}.global-library.is-open .global-library__backdrop{opacity:1}.global-library.is-open .global-library__drawer{transform:translate(0)}.global-library__header{position:relative;padding:24px 28px 20px;color:#fff;background:radial-gradient(circle at 8% 0%,rgba(255,255,255,.18),transparent 32%),linear-gradient(135deg,#24145f,#3b247c 46%,#1f3d6d);display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-shrink:0}.global-library__title-block{display:flex;align-items:flex-start;gap:14px;min-width:0}.global-library__icon{width:48px;height:48px;border-radius:17px;background:#ffffff29;border:1px solid rgba(255,255,255,.24);display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #ffffff2e;font-size:22px;flex:0 0 auto}.global-library__header h2{margin:0;font-size:clamp(22px,2vw,31px);letter-spacing:-.03em;line-height:1.05;font-weight:900}.global-library__header p{margin:7px 0 0;color:#ffffffd1;font-size:13px;line-height:1.5;max-width:720px}.global-library__close{width:42px;height:42px;border:1px solid rgba(255,255,255,.24);background:#ffffff1f;color:#fff;border-radius:14px;font-size:28px;line-height:1;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease}.global-library__close:hover,.global-library__close:focus-visible{transform:translateY(-1px) scale(1.04);background:#fff3;border-color:#ffffff6b;outline:none}.global-library__search-row{padding:18px 28px 12px;display:flex;gap:12px;align-items:center;background:#fffffff0;border-bottom:1px solid rgba(124,58,237,.1);flex-shrink:0}.global-library__search-wrap{flex:1;min-width:0;height:48px;border:1px solid rgba(124,58,237,.18);border-radius:18px;background:#fff;box-shadow:0 12px 28px #0f172a0d;display:flex;align-items:center;gap:10px;padding:0 16px}.global-library__search-wrap span{color:#7c3aed;font-size:18px}.global-library__search-wrap input{border:0;outline:none;flex:1;min-width:0;font:inherit;font-size:14px;font-weight:650;color:#111827;background:transparent}.global-library__search-wrap input::placeholder{color:#8b92a6;font-weight:600}.global-library__filter-toggle{display:none;height:44px;padding:0 16px;border:1px solid rgba(124,58,237,.2);border-radius:15px;background:#fff;color:#4c1d95;font-weight:850;cursor:pointer}.global-library__filters{padding:12px 28px 20px;background:#fffffff0;display:grid;grid-template-columns:repeat(6,minmax(0,1fr)) auto;gap:12px;align-items:start;border-bottom:1px solid rgba(124,58,237,.1);flex-shrink:0}.global-library__filter{display:grid;gap:5px;min-width:0}.global-library__filter span{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#7a8399;line-height:1.2;padding-left:3px}.global-library__filter select,.global-library__sort select{min-width:0;width:100%;height:42px;border:1px solid rgba(124,58,237,.16);border-radius:14px;background:#fff;color:#1f2937;font-size:12px;font-weight:750;padding:0 36px 0 14px;outline:none;line-height:42px;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#7c3aed 50%),linear-gradient(135deg,#7c3aed 50%,transparent 50%);background-position:calc(100% - 18px) 18px,calc(100% - 13px) 18px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.global-library__filter select:focus-visible,.global-library__sort select:focus-visible{border-color:#7c3aed6b;box-shadow:0 0 0 4px #7c3aed1a}.global-library__reset{height:42px;padding:0 16px;border-radius:13px;border:1px solid rgba(124,58,237,.16);background:#f7f4ff;color:#5b21b6;font-weight:850;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease}.global-library__reset:hover,.global-library__reset:focus-visible{transform:translateY(-1px);box-shadow:0 10px 22px #7c3aed1f;outline:none}.global-library__body{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,390px);gap:18px;padding:20px 24px 24px;overflow:hidden}.global-library__results,.global-library__preview{min-height:0;background:#ffffffeb;border:1px solid rgba(124,58,237,.12);border-radius:24px;box-shadow:0 18px 46px #0f172a14;overflow:hidden}.global-library__results{display:flex;flex-direction:column}.global-library__section-head{padding:18px 20px 12px;display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid rgba(124,58,237,.1);flex-shrink:0}.global-library__section-head h3,.global-library__preview h3,.global-library__assign-box h4{margin:0;color:#111827;font-weight:900;letter-spacing:-.025em}.global-library__section-head p,.global-library__assign-head p{margin:4px 0 0;color:#7a8399;font-size:12px;font-weight:650}.global-library__sort{display:grid;gap:5px;min-width:168px;flex:0 0 178px}.global-library__sort span{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#7a8399;line-height:1.2;padding-left:3px}.global-library__grid{flex:1;min-height:0;overflow:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;align-content:start}.global-library__card{text-align:left;border:1px solid rgba(124,58,237,.12);background:linear-gradient(180deg,#fff,#faf9ff);border-radius:20px;padding:14px;display:grid;gap:8px;cursor:pointer;min-height:172px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease;font:inherit;color:inherit}.global-library__card:hover,.global-library__card:focus-visible,.global-library__card.is-selected{transform:translateY(-2px);border-color:#7c3aed61;box-shadow:0 16px 34px #7c3aed26;background:linear-gradient(180deg,#fff,#f5f0ff);outline:none}.global-library__card.is-selected{border-color:#7c3aed9e;box-shadow:0 20px 40px #7c3aed33,inset 0 0 0 2px #7c3aed1a}.global-library__card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.global-library__activity-icon,.global-library__preview-icon{width:42px;height:42px;border-radius:15px;display:inline-flex;align-items:center;justify-content:center;background:#f1edff;border:1px solid rgba(124,58,237,.2);color:#5b21b6;font-size:19px;font-weight:900;flex:0 0 auto}.global-library__pill,.global-library__difficulty,.global-library__preview-meta span{display:inline-flex;align-items:center;width:fit-content;max-width:100%;border-radius:999px;border:1px solid rgba(124,58,237,.12);background:#f6f3ff;color:#5b21b6;padding:4px 8px;font-size:10px;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-library__card-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto}.global-library__select-chip{display:inline-flex;align-items:center;justify-content:center;min-height:26px;border-radius:999px;border:1px solid rgba(124,58,237,.18);background:#fff;color:#5b21b6;padding:5px 10px;font-size:10px;font-weight:900;white-space:nowrap;transition:background .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.global-library__card:hover .global-library__select-chip,.global-library__card:focus-visible .global-library__select-chip{transform:translateY(-1px);background:#ede9fe;border-color:#7c3aed52}.global-library__select-chip.is-selected{background:#7c3aed;border-color:#7c3aed;color:#fff;box-shadow:0 8px 18px #7c3aed38}.global-library__subject,.global-library__crumb{color:#7a8399;font-size:11px;font-weight:750;line-height:1.35}.global-library__card strong{color:#111827;font-size:14px;line-height:1.28;letter-spacing:-.015em}.global-library__crumb{min-height:30px}.global-library__preview{padding:20px;overflow:auto;display:flex;flex-direction:column;gap:16px}.global-library__preview-top{display:flex;align-items:flex-start;gap:14px}.global-library__preview-top span{color:#7a8399;font-size:12px;font-weight:800}.global-library__preview h3{margin-top:3px;font-size:21px;line-height:1.15}.global-library__preview-meta{display:flex;flex-wrap:wrap;gap:7px}.global-library__description{margin:0;color:#4b5563;font-size:13px;line-height:1.55;font-weight:600;background:#faf9ff;border:1px solid rgba(124,58,237,.1);border-radius:18px;padding:14px}.global-library__selection-hint{border-radius:16px;border:1px solid rgba(124,58,237,.16);background:linear-gradient(180deg,#f8f5ff,#fff);color:#4c1d95;padding:11px 13px;font-size:12px;line-height:1.45;font-weight:800}.global-library__assign-box{border-radius:20px;border:1px solid rgba(16,185,129,.18);background:linear-gradient(180deg,#f7fffb,#fff);padding:15px;display:grid;gap:12px}.global-library__assign-head{display:flex;justify-content:space-between;gap:12px}.global-library__assign-head h4{font-size:15px}.global-library__assign-head>span{color:#059669;font-size:11px;font-weight:850}.global-library__learners{display:flex;flex-wrap:wrap;gap:8px}.global-library__learner,.global-library__learner-empty{border-radius:999px;border:1px solid rgba(16,185,129,.2);background:#fff;color:#065f46;padding:8px 11px;font-size:12px;font-weight:850}.global-library__learner{display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:transform .14s ease,background .14s ease,border-color .14s ease}.global-library__learner:hover,.global-library__learner:focus-visible,.global-library__learner.is-selected{transform:translateY(-1px);background:#dcfce7;border-color:#10b98173;outline:none}.global-library__learner span{width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#10b9811a}.global-library__actions{margin-top:auto;display:grid;gap:10px}.global-library__primary,.global-library__secondary{height:46px;border-radius:16px;font-weight:900;font-size:13px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease}.global-library__primary{border:0;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;box-shadow:0 16px 32px #22c55e38}.global-library__secondary{border:1px solid rgba(124,58,237,.18);background:#f6f3ff;color:#5b21b6}.global-library__primary:hover:not(:disabled),.global-library__secondary:hover,.global-library__primary:focus-visible:not(:disabled),.global-library__secondary:focus-visible{transform:translateY(-1px);outline:none}.global-library__primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.global-library__toast,.global-library__error{margin:12px 16px 0;padding:11px 13px;border-radius:15px;font-size:12px;font-weight:800}.global-library__toast{color:#065f46;background:#dcfce7;border:1px solid rgba(16,185,129,.22)}.global-library__error{color:#991b1b;background:#fee2e2;border:1px solid rgba(239,68,68,.22)}.global-library__empty{margin:16px;min-height:160px;display:grid;align-content:center;justify-items:center;gap:6px;color:#7a8399;text-align:center;font-size:13px;font-weight:700;border:1px dashed rgba(124,58,237,.2);border-radius:20px;background:#faf9ff;padding:18px}.global-library__empty strong{color:#111827;font-size:15px}@media(max-width:720px){.global-library__section-head{flex-direction:column;align-items:stretch}.global-library__sort{width:100%;min-width:0;flex:none}}@media(max-width:1180px){.global-library__drawer{width:min(980px,calc(100vw - 56px))}.global-library__filters{grid-template-columns:repeat(3,minmax(0,1fr)) auto}.global-library__body{grid-template-columns:minmax(0,1fr) 340px}}@media(max-width:900px){.global-library__drawer{width:94vw}.global-library__header{padding:20px 20px 18px}.global-library__search-row{padding:14px 18px 12px}.global-library__filter-toggle{display:inline-flex;align-items:center;justify-content:center}.global-library__filters{display:none;padding:10px 18px 16px;grid-template-columns:repeat(2,minmax(0,1fr))}.global-library__filters.is-open{display:grid}.global-library__reset{grid-column:1 / -1}.global-library__body{grid-template-columns:1fr;overflow:auto;padding:16px 18px 20px}.global-library__results,.global-library__preview{overflow:visible}.global-library__grid{overflow:visible;max-height:none;grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}@media(max-width:767px){.global-library__drawer{width:100vw;border-left:0}.global-library__header h2{font-size:23px}.global-library__header p{font-size:12px}.global-library__icon{width:42px;height:42px;border-radius:14px}.global-library__search-row{align-items:stretch}.global-library__search-wrap{height:44px}.global-library__filters{grid-template-columns:1fr}.global-library__grid{grid-template-columns:1fr;padding:12px}.global-library__card{min-height:150px}.global-library__preview{padding:16px}.global-library__actions{position:sticky;bottom:0;background:linear-gradient(180deg,#ffffffc7,#fff 28%);padding-top:10px}}.global-library__start-overlay{position:absolute;inset:0;z-index:8;display:grid;place-items:center;padding:24px;background:#0f172a6b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.global-library__start-card{width:min(460px,100%);border-radius:28px;background:#fff;border:1px solid rgba(124,58,237,.18);box-shadow:0 30px 80px #0f172a47;padding:22px}.global-library__start-head{display:flex;align-items:flex-start;gap:13px;margin-bottom:16px}.global-library__start-head>span{width:42px;height:42px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ede9fe,#dcfce7);color:#5b21b6;font-weight:900;flex:0 0 auto}.global-library__start-head h3{margin:0 0 5px;color:#111827;font-size:20px;line-height:1.15}.global-library__start-head p{margin:0;color:#6b7280;font-size:13px;line-height:1.45}.global-library__start-list{display:grid;gap:9px;margin:16px 0 18px}.global-library__start-child{width:100%;border:1px solid rgba(124,58,237,.16);background:#f9fafb;color:#1f2937;border-radius:18px;min-height:48px;padding:10px 12px;display:flex;align-items:center;gap:10px;text-align:left;cursor:pointer;transition:transform .14s ease,background .14s ease,border-color .14s ease,box-shadow .14s ease}.global-library__start-child:hover,.global-library__start-child:focus-visible{transform:translateY(-1px);border-color:#7c3aed57;background:#f6f3ff;outline:none}.global-library__start-child.is-selected{background:#ecfdf5;border-color:#10b98175;box-shadow:0 12px 26px #10b9811f}.global-library__start-child span{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#7c3aed1a;color:#5b21b6;font-weight:900}.global-library__start-child.is-selected span{background:#10b98124;color:#047857}.global-library__start-child strong{font-size:14px}.global-library__start-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:767px){.global-library__start-overlay{align-items:end;padding:14px}.global-library__start-card{border-radius:24px;padding:18px}.global-library__start-actions{grid-template-columns:1fr}}.ws-studio{position:fixed;inset:0;z-index:1230;pointer-events:none;font-family:var(--font-body, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif)}.ws-studio__backdrop{position:absolute;inset:0;background:#0f172a4d;opacity:0;transition:opacity .22s ease}.ws-studio__drawer{position:absolute;top:0;right:0;width:min(1240px,calc(100vw - var(--rail-w, 72px)));height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:linear-gradient(180deg,#faf9ff,#fff 42%,#f9fafb);border-left:1px solid rgba(124,58,237,.18);box-shadow:-34px 0 90px #0f172a40;transform:translate(104%);transition:transform .3s cubic-bezier(.22,1,.36,1)}.ws-studio.is-open{pointer-events:auto}.ws-studio.is-open .ws-studio__backdrop{opacity:1}.ws-studio.is-open .ws-studio__drawer{transform:translate(0)}.ws-studio__header{flex-shrink:0;position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:24px 28px 20px;color:#fff;background:radial-gradient(circle at 9% 0%,rgba(255,255,255,.18),transparent 34%),linear-gradient(135deg,#27145f,#47288c 48%,#21476f)}.ws-studio__title-block{display:flex;align-items:flex-start;gap:14px;min-width:0}.ws-studio__title-icon{width:50px;height:50px;border-radius:18px;display:grid;place-items:center;background:#ffffff29;border:1px solid rgba(255,255,255,.24);box-shadow:inset 0 1px #ffffff2e;font-size:23px;flex:0 0 auto}.ws-studio__header h2{margin:0;font-size:clamp(23px,2.2vw,34px);line-height:1.05;letter-spacing:-.04em;font-weight:950}.ws-studio__header p{margin:8px 0 0;max-width:780px;color:#ffffffd6;font-size:13px;line-height:1.5;font-weight:600}.ws-studio__close{width:42px;height:42px;border:1px solid rgba(255,255,255,.24);border-radius:14px;background:#ffffff1f;color:#fff;font-size:28px;line-height:1;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease}.ws-studio__close:hover,.ws-studio__close:focus-visible{transform:translateY(-1px) scale(1.04);background:#fff3;border-color:#ffffff6b;outline:none}.ws-studio__tabs,.ws-studio__search-row,.ws-studio__filters,.ws-studio__upload-strip{flex-shrink:0;background:#fffffff5;border-bottom:1px solid rgba(124,58,237,.1)}.ws-studio__tabs{display:flex;gap:10px;padding:16px 28px 12px;overflow-x:auto}.ws-studio__tabs button{border:1px solid rgba(124,58,237,.16);background:#fff;color:#4c1d95;border-radius:999px;min-height:40px;padding:0 16px;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.ws-studio__tabs button:hover,.ws-studio__tabs button:focus-visible,.ws-studio__tabs button.is-active{transform:translateY(-1px);border-color:#7c3aed61;background:#f4f0ff;box-shadow:0 10px 22px #7c3aed1f;outline:none}.ws-studio__tabs button.is-active{background:linear-gradient(135deg,#7c3aed,#5b21b6);border-color:#7c3aed;color:#fff}.ws-studio__upload-strip{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 28px;background:linear-gradient(135deg,#fffbeb,#fff)}.ws-studio__upload-strip strong,.ws-studio__upload-strip span{display:block}.ws-studio__upload-strip strong{color:#92400e;font-size:13px;font-weight:950}.ws-studio__upload-strip span{margin-top:4px;color:#7a8399;font-size:12px;line-height:1.4;font-weight:700}.ws-studio__upload-strip button,.ws-studio__reset,.ws-studio__quiet,.ws-studio__remove-upload{border:1px solid rgba(124,58,237,.16);border-radius:14px;background:#f7f4ff;color:#5b21b6;font:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease}.ws-studio__upload-strip button{min-height:42px;padding:0 16px;white-space:nowrap}.ws-studio__upload-strip button:hover:not(:disabled),.ws-studio__reset:hover,.ws-studio__quiet:hover,.ws-studio__remove-upload:hover,.ws-studio__upload-strip button:focus-visible:not(:disabled),.ws-studio__reset:focus-visible,.ws-studio__quiet:focus-visible,.ws-studio__remove-upload:focus-visible{transform:translateY(-1px);box-shadow:0 10px 22px #7c3aed21;outline:none}.ws-studio__upload-strip button:disabled{opacity:.6;cursor:not-allowed}.ws-studio__search-row{display:flex;align-items:center;gap:12px;padding:16px 28px 12px}.ws-studio__search-wrap{flex:1;min-width:0;height:48px;border:1px solid rgba(124,58,237,.18);border-radius:18px;background:#fff;box-shadow:0 12px 28px #0f172a0d;display:flex;align-items:center;gap:10px;padding:0 16px}.ws-studio__search-wrap span{color:#7c3aed;font-size:18px}.ws-studio__search-wrap input{border:0;outline:none;flex:1;min-width:0;font:inherit;font-size:14px;font-weight:700;color:#111827;background:transparent}.ws-studio__search-wrap input::placeholder{color:#8b92a6;font-weight:600}.ws-studio__filter-toggle{display:none;min-height:44px;padding:0 16px;border:1px solid rgba(124,58,237,.2);border-radius:15px;background:#fff;color:#4c1d95;font:inherit;font-weight:900;cursor:pointer}.ws-studio__filters{padding:12px 28px 18px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:12px;align-items:end}.ws-studio__filter{display:grid;gap:6px;min-width:0}.ws-studio__filter span{color:#7a8399;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;padding-left:3px}.ws-studio__filter select{min-width:0;width:100%;height:42px;border:1px solid rgba(124,58,237,.16);border-radius:14px;background:#fff;color:#1f2937;font:inherit;font-size:12px;font-weight:800;padding:0 36px 0 14px;outline:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#7c3aed 50%),linear-gradient(135deg,#7c3aed 50%,transparent 50%);background-position:calc(100% - 18px) 18px,calc(100% - 13px) 18px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.ws-studio__filter select:focus-visible{border-color:#7c3aed6b;box-shadow:0 0 0 4px #7c3aed1a}.ws-studio__reset{height:42px;padding:0 16px}.ws-studio__body{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(370px,450px);gap:18px;padding:20px 24px 24px;overflow:hidden}.ws-studio__library,.ws-studio__preview{min-height:0;background:#ffffffed;border:1px solid rgba(124,58,237,.12);border-radius:24px;box-shadow:0 18px 46px #0f172a14;overflow:hidden}.ws-studio__library{display:flex;flex-direction:column}.ws-studio__section-head{flex-shrink:0;padding:18px 20px 12px;display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid rgba(124,58,237,.1)}.ws-studio__section-head h3,.ws-studio__preview h3,.ws-studio__assign-head h4{margin:0;color:#111827;font-weight:950;letter-spacing:-.025em}.ws-studio__section-head p,.ws-studio__preview-head p,.ws-studio__assign-head p{margin:5px 0 0;color:#7a8399;font-size:12px;line-height:1.45;font-weight:700}.ws-studio__quiet{align-self:flex-start;min-height:34px;padding:0 12px;background:#fff}.ws-studio__grid{flex:1;min-height:0;overflow:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;align-content:start}.ws-studio__card{min-height:184px;border:1px solid rgba(124,58,237,.12);border-radius:20px;background:linear-gradient(180deg,#fff,#faf9ff);padding:14px;display:grid;gap:9px;text-align:left;font:inherit;color:inherit;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.ws-studio__card:hover,.ws-studio__card:focus-visible,.ws-studio__card.is-selected{transform:translateY(-2px);border-color:#7c3aed6b;box-shadow:0 16px 34px #7c3aed26;background:linear-gradient(180deg,#fff,#f5f0ff);outline:none}.ws-studio__card.is-selected{border-color:#7c3aeda6;box-shadow:0 20px 40px #7c3aed33,inset 0 0 0 2px #7c3aed1a}.ws-studio__card-top,.ws-studio__card .ws-studio__meta,.ws-studio__preview-head,.ws-studio__assign-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ws-studio__card-icon{width:42px;height:42px;border-radius:15px;display:inline-flex;align-items:center;justify-content:center;background:#f1edff;border:1px solid rgba(124,58,237,.2);color:#5b21b6;font-size:19px;font-weight:900}.ws-studio__select-chip{min-height:26px;border-radius:999px;border:1px solid rgba(124,58,237,.18);background:#fff;color:#5b21b6;padding:5px 10px;font-size:10px;font-weight:950;white-space:nowrap}.ws-studio__select-chip.is-selected{background:#7c3aed;border-color:#7c3aed;color:#fff}.ws-studio__card strong{color:#111827;font-size:14px;line-height:1.28;letter-spacing:-.015em}.ws-studio__card p{margin:0;color:#6b7280;font-size:12px;line-height:1.45;font-weight:650}.ws-studio__meta{flex-wrap:wrap;margin-top:auto}.ws-studio__meta span,.ws-studio__preview-head>div>span{display:inline-flex;align-items:center;max-width:100%;border-radius:999px;border:1px solid rgba(124,58,237,.12);background:#f6f3ff;color:#5b21b6;padding:4px 8px;font-size:10px;font-weight:900;white-space:nowrap}.ws-studio__preview{padding:20px;display:flex;flex-direction:column;gap:14px;overflow:auto}.ws-studio__preview-head h3{margin-top:7px;font-size:22px;line-height:1.14}.ws-studio__remove-upload{min-height:34px;padding:0 12px;background:#fff7ed;color:#b45309;border-color:#f59e0b40;flex:0 0 auto}.ws-studio__paper-shell{position:relative;min-height:270px;height:clamp(270px,36vh,390px);border-radius:22px;background:linear-gradient(180deg,#f8f5ff,#fff);border:1px solid rgba(124,58,237,.12);padding:14px;overflow:hidden;display:flex;align-items:flex-start;justify-content:center}.ws-studio__paper-fit{width:760px;max-width:none;flex:0 0 auto;transform-origin:top center;transition:transform .18s ease;will-change:transform}.ws-studio-paper{width:760px;max-width:none;background:#fffef7;border:1px solid #e7dcc8;border-radius:22px;overflow:hidden;box-shadow:0 10px 30px #0f172a0f}.ws-studio-paper--advanced{background:#fff}.ws-studio-paper__header{display:flex;justify-content:space-between;gap:12px;padding:18px 20px;background:linear-gradient(135deg,#fff7ed,#fef3c7);border-bottom:2px solid #f59e0b}.ws-studio-paper--advanced .ws-studio-paper__header{background:linear-gradient(135deg,#f5f3ff,#ecfeff);border-bottom-color:#7c3aed}.ws-studio-paper__header p{margin:0 0 5px;color:#92400e;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.ws-studio-paper--advanced .ws-studio-paper__header p{color:#5b21b6}.ws-studio-paper__header h3{margin:0;color:#14532d;font-size:21px;line-height:1.15;letter-spacing:-.02em}.ws-studio-paper__identity{min-width:130px;display:grid;gap:7px;align-content:start;color:#5f513f;font-size:12px;font-weight:750}.ws-studio-paper__identity span{border-bottom:1px solid rgba(95,81,63,.25);padding-bottom:4px}.ws-studio-paper__objective{margin:16px 18px;border-left:5px solid #f59e0b;background:#eff6ff;border-radius:16px;padding:12px 14px;display:grid;gap:4px}.ws-studio-paper__objective strong{color:#1d4ed8;font-size:11px;text-transform:uppercase;letter-spacing:.08em}.ws-studio-paper__objective span,.ws-studio-paper__activity p{color:#374151;font-size:13px;line-height:1.5;font-weight:650}.ws-studio-paper__activity{padding:14px 18px 18px;border-top:1px solid #f0e5d8}.ws-studio-paper__activity h4{margin:0 0 10px;color:#b45309;font-size:15px}.ws-studio-paper--advanced .ws-studio-paper__activity h4{color:#5b21b6}.ws-studio__writing-lines{display:grid;gap:6px;margin-top:12px}.ws-studio__writing-lines span{display:block;height:28px;border-bottom:1px solid #d4c8b0}.ws-studio-paper__drawing-area{min-height:118px;border:2px dashed #f59e0b;border-radius:18px;background:#fff7ed;display:grid;place-items:center;color:#9a6724;font-size:13px;font-weight:800;text-align:center;padding:14px}.ws-studio-paper__upload-preview{margin:16px 18px 18px;min-height:260px;background:#f8fafc;border:1px dashed rgba(124,58,237,.22);border-radius:18px;display:grid;place-items:center;overflow:hidden}.ws-studio-paper__upload-preview img,.ws-studio-paper__upload-preview iframe{width:100%;height:100%;max-height:100%;object-fit:contain;border:0}.ws-studio-paper__upload-preview iframe{min-height:260px}.ws-studio-paper__footer{display:flex;justify-content:space-between;gap:12px;padding:13px 18px;background:#fffdf7;border-top:1px dashed #dfd1bb;color:#8b7a5b;font-size:11px;font-weight:800}.ws-studio__assign-box{border-radius:20px;border:1px solid rgba(16,185,129,.18);background:linear-gradient(180deg,#f7fffb,#fff);padding:15px;display:grid;gap:12px;scroll-margin:96px;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.ws-studio__assign-box.is-prompted{border-color:#f59e0b9e;background:linear-gradient(180deg,#fff7ed,#fff);box-shadow:0 0 0 5px #f59e0b24,0 18px 38px #f59e0b29}.ws-studio__assign-head h4{font-size:15px}.ws-studio__assign-head>span{color:#059669;font-size:11px;font-weight:900}.ws-studio__learners{display:flex;flex-wrap:wrap;gap:8px}.ws-studio__learner,.ws-studio__learner-empty{border-radius:999px;border:1px solid rgba(16,185,129,.2);background:#fff;color:#065f46;padding:8px 11px;font-size:12px;font-weight:900}.ws-studio__learner{display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:transform .14s ease,background .14s ease,border-color .14s ease}.ws-studio__learner:hover,.ws-studio__learner:focus-visible,.ws-studio__learner.is-selected{transform:translateY(-1px);background:#dcfce7;border-color:#10b98173;outline:none}.ws-studio__learner span{width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#10b9811a}.ws-studio__actions{position:static;bottom:auto;margin-top:8px;display:grid;gap:10px;background:linear-gradient(180deg,#ffffffb8,#fff 24%);padding-top:10px}.ws-studio__primary,.ws-studio__secondary{height:46px;border-radius:16px;font:inherit;font-size:13px;font-weight:950;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease}.ws-studio__primary{border:0;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;box-shadow:0 16px 32px #22c55e38}.ws-studio__primary--select{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 16px 32px #d9770638}.ws-studio__primary--start{background:linear-gradient(135deg,#16a34a,#22c55e);box-shadow:0 16px 32px #22c55e38}.ws-studio__secondary{border:1px solid rgba(124,58,237,.18);background:#f6f3ff;color:#5b21b6}.ws-studio__primary:hover:not(:disabled),.ws-studio__secondary:hover:not(:disabled),.ws-studio__primary:focus-visible:not(:disabled),.ws-studio__secondary:focus-visible:not(:disabled){transform:translateY(-1px);outline:none}.ws-studio__primary:disabled,.ws-studio__secondary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.ws-studio__toast,.ws-studio__error{margin:12px 16px 0;padding:11px 13px;border-radius:15px;font-size:12px;font-weight:850;line-height:1.45}.ws-studio__toast{color:#065f46;background:#dcfce7;border:1px solid rgba(16,185,129,.22)}.ws-studio__error{color:#991b1b;background:#fee2e2;border:1px solid rgba(239,68,68,.22)}.ws-studio__empty{margin:16px;min-height:160px;display:grid;align-content:center;justify-items:center;gap:6px;color:#7a8399;text-align:center;font-size:13px;font-weight:750;border:1px dashed rgba(124,58,237,.2);border-radius:20px;background:#faf9ff;padding:18px}.ws-studio__empty strong{color:#111827;font-size:15px}.ws-studio__empty--preview{min-height:360px;margin:0}.ws-studio__start-overlay{position:absolute;inset:0;z-index:8;display:grid;place-items:center;padding:24px;background:#0f172a6b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.ws-studio__start-card{width:min(480px,100%);border-radius:28px;background:#fff;border:1px solid rgba(124,58,237,.18);box-shadow:0 30px 80px #0f172a47;padding:22px}.ws-studio__start-head{display:flex;align-items:flex-start;gap:13px;margin-bottom:16px}.ws-studio__start-head>span{width:42px;height:42px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ede9fe,#dcfce7);color:#5b21b6;font-weight:900;flex:0 0 auto}.ws-studio__start-head h3{margin:0 0 5px;color:#111827;font-size:20px;line-height:1.15}.ws-studio__start-head p{margin:0;color:#6b7280;font-size:13px;line-height:1.45;font-weight:650}.ws-studio__start-list{display:grid;gap:9px;margin:16px 0 18px}.ws-studio__start-child{width:100%;border:1px solid rgba(124,58,237,.16);background:#f9fafb;color:#1f2937;border-radius:18px;min-height:48px;padding:10px 12px;display:flex;align-items:center;gap:10px;text-align:left;font:inherit;cursor:pointer;transition:transform .14s ease,background .14s ease,border-color .14s ease,box-shadow .14s ease}.ws-studio__start-child:hover,.ws-studio__start-child:focus-visible,.ws-studio__start-child.is-selected{transform:translateY(-1px);outline:none}.ws-studio__start-child.is-selected{background:#ecfdf5;border-color:#10b98175;box-shadow:0 12px 26px #10b9811f}.ws-studio__start-child span{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#7c3aed1a;color:#5b21b6;font-weight:900}.ws-studio__start-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:1180px){.ws-studio__drawer{width:min(1040px,calc(100vw - 56px))}.ws-studio__body{grid-template-columns:minmax(0,1fr) 390px}}@media(max-width:980px){.ws-studio__drawer{width:94vw}.ws-studio__filters{grid-template-columns:repeat(2,minmax(0,1fr))}.ws-studio__reset{grid-column:1 / -1}.ws-studio__body{grid-template-columns:1fr;overflow:auto}.ws-studio__library,.ws-studio__preview{overflow:visible}.ws-studio__grid{overflow:visible;max-height:none}.ws-studio__paper-shell{max-height:none;height:360px}}@media(max-width:767px){.ws-studio__drawer{width:100vw;border-left:0}.ws-studio__header{padding:20px 18px 18px}.ws-studio__header h2{font-size:23px}.ws-studio__title-icon{width:42px;height:42px;border-radius:14px}.ws-studio__tabs,.ws-studio__search-row,.ws-studio__filters,.ws-studio__upload-strip{padding-left:16px;padding-right:16px}.ws-studio__upload-strip{align-items:stretch;flex-direction:column}.ws-studio__filter-toggle{display:inline-flex;align-items:center;justify-content:center}.ws-studio__filters{display:none;grid-template-columns:1fr}.ws-studio__filters.is-open{display:grid}.ws-studio__body{padding:16px 14px 18px}.ws-studio__grid{grid-template-columns:1fr;padding:12px}.ws-studio__preview{padding:14px}.ws-studio__paper-fit,.ws-studio-paper{width:680px}.ws-studio-paper__header{flex-direction:column}.ws-studio__start-overlay{align-items:end;padding:14px}.ws-studio__start-card{border-radius:24px;padding:18px}.ws-studio__start-actions{grid-template-columns:1fr}}.worksheet-question-options{display:flex;flex-wrap:wrap;gap:7px;margin:8px 0}.worksheet-question-options span{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;border:1px solid rgba(124,58,237,.16);background:#f8f5ff;color:#4c1d95;padding:4px 10px;font-size:12px;font-weight:850}.ws-studio__card .ws-studio__db-badge{display:inline-flex;align-items:center;border-radius:999px;background:#eef2ff;color:#3730a3;padding:3px 8px;font-size:10px;font-weight:950;letter-spacing:.04em;text-transform:uppercase}@media(max-width:1100px){.ws-studio__drawer{left:0;right:0;width:100vw;max-width:none;border-left:0}.ws-studio__body{grid-template-columns:1fr;overflow:auto;padding:14px;gap:14px}.ws-studio__library,.ws-studio__preview{min-height:auto;overflow:visible;border-radius:20px}.ws-studio__grid{overflow:auto;max-height:46vh}.ws-studio__preview{display:block}.ws-studio__paper-shell{height:min(58vh,560px);max-height:none}.ws-studio__section-head,.ws-studio__preview-head{position:sticky;top:0;z-index:3;background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}}@media(max-width:640px){.ws-studio__body{padding:10px}.ws-studio__header{align-items:flex-start;gap:10px}.ws-studio__header h2{font-size:20px}.ws-studio__header p{font-size:12px}.ws-studio__filters{grid-template-columns:1fr}.ws-studio__tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.ws-studio__tab{white-space:nowrap}.ws-studio__grid{max-height:42vh}.ws-studio__assign-actions{grid-template-columns:1fr}}@media(max-width:1100px),(max-height:760px){.ws-studio__library,.ws-studio__preview{padding-bottom:18px}.ws-studio__assign-box{scroll-margin-top:120px;scroll-margin-bottom:180px}.ws-studio__learners{max-height:34vh;overflow-y:auto;padding:2px 2px 8px;-webkit-overflow-scrolling:touch}.ws-studio__actions{position:static;bottom:auto;margin-top:8px;padding:12px 0 0;background:#fff;border-top:1px solid rgba(226,232,240,.9);box-shadow:none}}@media(max-width:640px){.ws-studio__body{padding-bottom:28px}.ws-studio__assign-box{padding:14px;border-radius:18px}.ws-studio__learners{display:grid;grid-template-columns:1fr;gap:9px;max-height:38vh}.ws-studio__learner,.ws-studio__learner-empty{width:100%;justify-content:flex-start;min-height:44px;border-radius:14px;font-size:13px}.ws-studio__primary,.ws-studio__secondary{min-height:48px}}.ws-studio__empty--preview{min-height:420px;align-content:center;background:radial-gradient(circle at 50% 0%,rgba(124,58,237,.08),transparent 240px),linear-gradient(180deg,#fff,#faf9ff)}.ws-studio__empty--preview strong{font-size:18px}.ws-studio__empty--preview span{max-width:340px;line-height:1.55}.ws-studio__actions{position:static!important;bottom:auto!important;margin-top:10px!important;padding-top:12px!important;background:#fff!important;border-top:1px solid rgba(226,232,240,.9);box-shadow:none!important}.ws-studio__learners{scroll-margin-bottom:190px}@media(max-width:1100px){.ws-studio__preview{overflow:visible}.ws-studio__assign-box{scroll-margin-top:96px;scroll-margin-bottom:220px}}.ws-studio__attach-banner{flex-shrink:0;display:grid;gap:4px;padding:12px 28px;background:linear-gradient(135deg,#ecfdf5,#fff);border-bottom:1px solid rgba(16,185,129,.16);color:#065f46}.ws-studio__attach-banner strong{font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.07em}.ws-studio__attach-banner span{color:#047857;font-size:13px;font-weight:750;line-height:1.4}.ws-studio__attach-box{border-radius:20px;border:1px solid rgba(16,185,129,.18);background:linear-gradient(180deg,#f0fdf4,#fff);padding:15px;display:grid;gap:6px}.ws-studio__attach-box strong{color:#064e3b;font-size:14px;font-weight:950}.ws-studio__attach-box span{color:#047857;font-size:12px;line-height:1.45;font-weight:750}.ws-studio__quiet-label{display:inline-flex;align-items:center;cursor:default}.ws-studio.is-attach-mode .ws-studio__header{background:radial-gradient(circle at 10% 0%,rgba(255,255,255,.2),transparent 34%),linear-gradient(135deg,#064e3b,#047857 48%,#21476f)}.ws-studio__attach-banner{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;padding:14px 28px;background:radial-gradient(circle at 0% 0%,rgba(16,185,129,.12),transparent 240px),linear-gradient(135deg,#ecfdf5,#fff);border-bottom:1px solid rgba(16,185,129,.22)}.ws-studio__attach-banner-main{display:grid;gap:4px;min-width:0}.ws-studio__attach-banner-main strong{color:#065f46;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.ws-studio__attach-banner-main span{color:#047857;font-size:13px;font-weight:750;line-height:1.42}.ws-studio__attach-banner-main b{color:#064e3b}.ws-studio__attach-steps{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.ws-studio__attach-steps span{min-height:32px;display:inline-flex;align-items:center;gap:7px;padding:0 10px;border-radius:999px;background:#fff;border:1px solid rgba(16,185,129,.18);color:#065f46;font-size:11px;font-weight:850;white-space:nowrap}.ws-studio__attach-steps b{width:18px;height:18px;border-radius:999px;display:inline-grid;place-items:center;background:#10b981;color:#fff;font-size:10px;line-height:1}.ws-studio__attach-sticky-bar{position:sticky;top:0;z-index:40;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 28px;background:linear-gradient(135deg,#064e3b,#047857);color:#fff;box-shadow:0 12px 26px #064e3b33}.ws-studio__attach-sticky-bar div{min-width:0;display:grid;gap:3px}.ws-studio__attach-sticky-bar strong{font-size:13px;font-weight:950;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ws-studio__attach-sticky-bar span{color:#ffffffd1;font-size:12px;line-height:1.35;font-weight:750}.ws-studio__attach-sticky-bar button{min-height:40px;padding:0 15px;border:1px solid rgba(255,255,255,.26);border-radius:14px;background:#fff;color:#065f46;font:inherit;font-size:12px;font-weight:950;cursor:pointer;white-space:nowrap;box-shadow:0 10px 20px #00000024}.ws-studio__attach-sticky-bar button:disabled{opacity:.58;cursor:not-allowed;box-shadow:none}@media(max-width:900px){.ws-studio__attach-banner,.ws-studio__attach-sticky-bar{grid-template-columns:1fr;align-items:stretch;padding-left:16px;padding-right:16px}.ws-studio__attach-sticky-bar{display:grid}.ws-studio__attach-sticky-bar button{width:100%}.ws-studio__attach-steps{justify-content:flex-start}}.ws-studio__attach-action-group,.ws-studio__attach-preview-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;align-items:center}.ws-studio__attach-action-group button,.ws-studio__attach-preview-actions button{min-height:40px;padding:0 13px;border-radius:14px;border:1px solid rgba(6,78,59,.16);background:#fff;color:#065f46;font:inherit;font-size:12px;font-weight:950;cursor:pointer;white-space:nowrap;box-shadow:0 9px 18px #064e3b1a}.ws-studio__attach-action-group button.is-primary,.ws-studio__attach-preview-actions button:nth-child(2){background:linear-gradient(135deg,#10b981,#047857);color:#fff;border-color:#059669}.ws-studio__attach-action-group button:disabled,.ws-studio__attach-preview-actions button:disabled{opacity:.56;cursor:not-allowed;box-shadow:none}.ws-studio__attach-box .ws-studio__attach-preview-actions{justify-content:flex-start;margin-top:6px}@media(max-width:900px){.ws-studio__attach-action-group,.ws-studio__attach-preview-actions{display:grid;grid-template-columns:1fr;width:100%}.ws-studio__attach-action-group button,.ws-studio__attach-preview-actions button{width:100%;white-space:normal}}.ws-studio.is-attach-mode .ws-studio__drawer{overflow-y:auto!important;overflow-x:hidden!important}.ws-studio.is-attach-mode .ws-studio__title-icon{width:42px;height:42px;border-radius:15px;font-size:20px}.ws-studio.is-attach-mode .ws-studio__header h2{font-size:clamp(22px,2vw,30px)}.ws-studio.is-attach-mode .ws-studio__header p{margin-top:5px;font-size:12px;line-height:1.38}.ws-studio.is-attach-mode .ws-studio__close{width:40px;height:40px}.ws-studio.is-attach-mode .ws-studio__attach-banner-main strong{font-size:11px}.ws-studio.is-attach-mode .ws-studio__attach-banner-main span{font-size:12px}.ws-studio.is-attach-mode .ws-studio__attach-steps{gap:6px}.ws-studio.is-attach-mode .ws-studio__attach-steps span{min-height:28px;padding:0 9px;font-size:10px}.ws-studio.is-attach-mode .ws-studio__tabs{padding:10px 24px;gap:8px}.ws-studio.is-attach-mode .ws-studio__tabs button{min-height:36px;padding:0 13px;font-size:11px}.ws-studio.is-attach-mode .ws-studio__search-wrap{height:42px;border-radius:15px}.ws-studio.is-attach-mode .ws-studio__filters{padding:8px 24px 10px;grid-template-columns:repeat(4,minmax(150px,1fr)) auto;gap:10px}.ws-studio.is-attach-mode .ws-studio__filter{gap:4px}.ws-studio.is-attach-mode .ws-studio__filter span{font-size:9px}.ws-studio.is-attach-mode .ws-studio__filter select,.ws-studio.is-attach-mode .ws-studio__reset{height:38px;border-radius:13px;font-size:11px}.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar{position:static;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(460px,auto);align-items:center;padding:12px 24px;min-height:74px;gap:14px}.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar strong{font-size:12px}.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar span{font-size:11px;line-height:1.3}.ws-studio.is-attach-mode .ws-studio__attach-action-group{display:grid;grid-template-columns:repeat(3,minmax(130px,1fr));gap:8px;justify-content:stretch;width:100%}.ws-studio.is-attach-mode .ws-studio__attach-action-group button{min-height:38px;width:100%;padding:0 10px;white-space:normal;line-height:1.15;text-align:center}.ws-studio.is-attach-mode .ws-studio__body{flex:none!important;min-height:min(640px,calc(100dvh - 260px));display:grid;grid-template-columns:minmax(0,1.18fr) minmax(330px,.82fr);gap:16px;padding:18px 24px 24px;overflow:visible!important}.ws-studio.is-attach-mode .ws-studio__library,.ws-studio.is-attach-mode .ws-studio__preview{min-height:520px;overflow:hidden}.ws-studio.is-attach-mode .ws-studio__library{display:flex;flex-direction:column}.ws-studio.is-attach-mode .ws-studio__section-head{padding:14px 16px 10px}.ws-studio.is-attach-mode .ws-studio__section-head h3{font-size:20px}.ws-studio.is-attach-mode .ws-studio__section-head p{font-size:12px}.ws-studio.is-attach-mode .ws-studio__grid{flex:1;min-height:0;overflow-y:auto;padding:12px;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:10px}.ws-studio.is-attach-mode .ws-studio__card{min-height:136px;padding:12px;gap:7px;border-radius:18px}.ws-studio.is-attach-mode .ws-studio__card-icon{width:34px;height:34px;border-radius:12px;font-size:16px}.ws-studio.is-attach-mode .ws-studio__card strong{font-size:13px}.ws-studio.is-attach-mode .ws-studio__card p{font-size:11px;line-height:1.36}.ws-studio.is-attach-mode .ws-studio__meta span{font-size:9px;padding:3px 7px}.ws-studio.is-attach-mode .ws-studio__preview{padding:16px;overflow-y:auto}.ws-studio.is-attach-mode .ws-studio__empty--preview{min-height:100%;border-radius:20px}.ws-studio.is-attach-mode .ws-studio__paper-shell{height:clamp(260px,34vh,390px);min-height:260px}.ws-studio.is-attach-mode .ws-studio__attach-box{flex-shrink:0}@media(max-width:1180px){.ws-studio.is-attach-mode .ws-studio__attach-banner,.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar{grid-template-columns:1fr}.ws-studio.is-attach-mode .ws-studio__attach-action-group{grid-template-columns:repeat(3,minmax(0,1fr))}.ws-studio.is-attach-mode .ws-studio__body{grid-template-columns:1fr}.ws-studio.is-attach-mode .ws-studio__library,.ws-studio.is-attach-mode .ws-studio__preview{min-height:420px}}@media(max-width:900px){.ws-studio.is-attach-mode .ws-studio__header,.ws-studio.is-attach-mode .ws-studio__attach-banner,.ws-studio.is-attach-mode .ws-studio__tabs,.ws-studio.is-attach-mode .ws-studio__search-row,.ws-studio.is-attach-mode .ws-studio__filters,.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar,.ws-studio.is-attach-mode .ws-studio__body{padding-left:16px;padding-right:16px}.ws-studio.is-attach-mode .ws-studio__filters,.ws-studio.is-attach-mode .ws-studio__attach-action-group{grid-template-columns:1fr}}@media(max-height:760px)and (min-width:901px){.ws-studio.is-attach-mode .ws-studio__header{padding-top:12px;padding-bottom:10px}.ws-studio.is-attach-mode .ws-studio__header p{max-width:900px}.ws-studio.is-attach-mode .ws-studio__attach-banner,.ws-studio.is-attach-mode .ws-studio__tabs{padding-top:8px;padding-bottom:8px}.ws-studio.is-attach-mode .ws-studio__search-row{padding-top:8px;padding-bottom:6px}.ws-studio.is-attach-mode .ws-studio__filters{padding-top:6px;padding-bottom:8px}.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar{min-height:64px;padding-top:8px;padding-bottom:8px}.ws-studio.is-attach-mode .ws-studio__body{min-height:520px;padding-top:14px}}.ws-studio.is-attach-mode .ws-studio__attach-sticky-bar{display:none!important}.ws-studio.is-attach-mode .ws-studio__header{padding:16px 24px 14px}.ws-studio.is-attach-mode .ws-studio__attach-banner{grid-template-columns:minmax(0,1fr) auto;padding:10px 24px;gap:12px}.ws-studio.is-attach-mode .ws-studio__attach-toolbar{flex-shrink:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(390px,auto);align-items:center;gap:12px;padding:12px 24px 10px;background:#fffffffa;border-bottom:1px solid rgba(124,58,237,.1)}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-tabs{display:flex;gap:10px;overflow-x:auto;min-width:0}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-tabs button,.ws-studio.is-attach-mode .ws-studio__attach-toolbar-actions button{border:1px solid rgba(124,58,237,.16);border-radius:999px;min-height:42px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;font:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease,opacity .15s ease}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-tabs button{background:#fff;color:#4c1d95}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-tabs button.is-active,.ws-studio.is-attach-mode .ws-studio__attach-toolbar-tabs button:hover{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;border-color:#7c3aed;box-shadow:0 10px 20px #7c3aed29}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-actions button{background:linear-gradient(180deg,#ecfdf5,#d1fae5);color:#065f46;border-color:#10b98138;white-space:normal;line-height:1.15;text-align:center;min-height:46px;padding:8px 12px}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-actions button.is-primary{background:linear-gradient(135deg,#10b981,#047857);color:#fff;border-color:#059669}.ws-studio.is-attach-mode .ws-studio__attach-toolbar-actions button:disabled{opacity:.56;cursor:not-allowed;box-shadow:none}.ws-studio.is-attach-mode .ws-studio__search-row{padding:10px 24px 8px}.ws-studio.is-attach-mode .ws-studio__filters{padding:8px 24px 10px;grid-template-columns:repeat(4,minmax(145px,1fr)) auto}.ws-studio.is-attach-mode .ws-studio__attach-selection-note{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:0 24px 10px;background:#fffffffa;border-bottom:1px solid rgba(124,58,237,.08)}.ws-studio.is-attach-mode .ws-studio__attach-selection-note strong{color:#111827;font-size:13px;font-weight:950}.ws-studio.is-attach-mode .ws-studio__attach-selection-note span{color:#6b7280;font-size:12px;font-weight:700;line-height:1.4}.ws-studio.is-attach-mode .ws-studio__body{flex:1;min-height:0;padding:14px 24px 24px;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr);gap:18px;overflow:hidden}.ws-studio.is-attach-mode .ws-studio__library,.ws-studio.is-attach-mode .ws-studio__preview{min-height:0;height:100%}.ws-studio.is-attach-mode .ws-studio__section-head{padding:16px 18px 12px}.ws-studio.is-attach-mode .ws-studio__grid{padding:14px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.ws-studio.is-attach-mode .ws-studio__card{min-height:150px}.ws-studio.is-attach-mode .ws-studio__preview{display:flex;flex-direction:column}.ws-studio.is-attach-mode .ws-studio__preview-head{padding-bottom:8px}.ws-studio.is-attach-mode .ws-studio__paper-shell{height:clamp(280px,38vh,440px)}.ws-studio.is-attach-mode .ws-studio__attach-box{border-radius:18px}@media(max-width:1220px){.ws-studio.is-attach-mode .ws-studio__attach-toolbar{grid-template-columns:1fr}}@media(max-width:960px){.ws-studio.is-attach-mode .ws-studio__attach-toolbar-actions,.ws-studio.is-attach-mode .ws-studio__filters,.ws-studio.is-attach-mode .ws-studio__body{grid-template-columns:1fr}.ws-studio.is-attach-mode .ws-studio__attach-selection-note{align-items:flex-start;flex-direction:column}}.ws-studio.is-attach-mode .ws-studio__attach-selection-note{display:grid;grid-template-columns:minmax(220px,.75fr) minmax(0,1.25fr);align-items:start;gap:14px}.ws-studio__attach-tray{display:grid;gap:8px;max-height:150px;overflow-y:auto;padding:8px;border:1px solid rgba(16,185,129,.18);border-radius:16px;background:linear-gradient(180deg,#ecfdf5,#fff)}.ws-studio__attach-tray-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(135px,.55fr);gap:8px;align-items:center}.ws-studio__attach-tray-row span{min-width:0;color:#064e3b;font-size:12px;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ws-studio__attach-tray-row select{min-height:34px;border:1px solid rgba(16,185,129,.22);border-radius:12px;background:#fff;color:#065f46;font:inherit;font-size:11px;font-weight:850;padding:0 9px}.ws-studio.is-attach-mode .ws-studio__select-chip.is-selected{background:#10b981;border-color:#10b981;color:#fff}@media(max-width:960px){.ws-studio.is-attach-mode .ws-studio__attach-selection-note,.ws-studio__attach-tray-row{grid-template-columns:1fr}.ws-studio__attach-tray{max-height:220px}}.ws-studio.is-attach-mode .ws-studio__attach-selection-note{display:grid;grid-template-columns:minmax(240px,.8fr) minmax(0,1.2fr);align-items:center;gap:14px}.ws-studio__attach-selected-list{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end;min-width:0}.ws-studio__attach-selected-list span{max-width:210px;min-height:28px;display:inline-flex;align-items:center;border-radius:999px;padding:0 10px;background:#ecfdf5;border:1px solid rgba(16,185,129,.18);color:#065f46;font-size:11px;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ws-studio.is-attach-mode .ws-studio__attach-tray{display:none!important}.ws-studio__assign-box--attach{margin-top:0;border-color:#10b9812e;background:linear-gradient(180deg,#f0fdf9,#fff)}.ws-studio__assign-box--attach .ws-studio__assign-head h4{color:#065f46}.ws-studio__assign-box--attach .ws-studio__learners{max-height:118px;overflow-y:auto}@media(max-width:960px){.ws-studio.is-attach-mode .ws-studio__attach-selection-note{grid-template-columns:1fr}.ws-studio__attach-selected-list{justify-content:flex-start}}.worksheet-board{position:fixed;top:0;right:0;bottom:0;left:var(--rail-w, 72px);z-index:1220;display:flex;flex-direction:column;background:linear-gradient(180deg,#f8f7fffa,#fffffff5);font-family:var(--font-body, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);color:#111827}.worksheet-board-is-active .pen-toolbar,.worksheet-board-is-active .mobile-fab,.worksheet-board-is-active .desktop-fab,.worksheet-board-is-active .desktop-fab-popover,.worksheet-board-is-active .mobile-sheet,.worksheet-board-is-active .mobile-sheet-backdrop{display:none!important}.worksheet-board__toolbar{flex:0 0 auto;min-height:68px;padding:10px 16px 10px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;background:#fffffff5;border-bottom:1px solid rgba(124,58,237,.16);box-shadow:0 10px 30px #0f172a14;z-index:8}.worksheet-board__title{min-width:0}.worksheet-board__title strong{display:block;font-size:15px;font-weight:950;letter-spacing:-.02em}.worksheet-board__title span{display:block;margin-top:3px;color:#6b7280;font-size:12px;font-weight:750;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.worksheet-board__tools{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px}.worksheet-board__tools button{min-height:36px;border:1px solid rgba(124,58,237,.18);border-radius:12px;background:#fff;color:#5b21b6;padding:0 12px;font:inherit;font-size:12px;font-weight:900;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease}.worksheet-board__tools button:hover,.worksheet-board__tools button:focus-visible,.worksheet-board__tools button.is-active{transform:translateY(-1px);box-shadow:0 10px 22px #7c3aed1f;outline:none}.worksheet-board__tools button.is-active{background:#f5f0ff;border-color:#7c3aed61}.worksheet-board__zoom-label{min-width:46px;text-align:center;color:#4b5563;font-size:12px;font-weight:900;font-variant-numeric:tabular-nums}.worksheet-board__tools .worksheet-board__danger{color:#991b1b;background:#fff1f2;border-color:#ef444438}.worksheet-board__workspace{flex:1;min-height:0;position:relative;display:grid;grid-template-columns:minmax(0,1fr) 76px;background:linear-gradient(180deg,#f8fafc,#fff)}.worksheet-board__stage{min-height:0;overflow:auto;display:flex;scrollbar-gutter:stable both-edges;-webkit-overflow-scrolling:touch;justify-content:center;align-items:flex-start;padding:28px 18px 42px 28px;scroll-behavior:auto;overscroll-behavior:contain}.worksheet-board__paper-slot{position:relative;flex:0 0 auto}.worksheet-board__paper-wrap{width:1120px;transform-origin:top left;transition:transform .16s ease;will-change:transform}.worksheet-board__paper-surface{width:1120px;position:relative;background:transparent;touch-action:none}.worksheet-board__paper-surface--move{touch-action:pan-y pan-x}.worksheet-board-paper{width:100%;background:#fffef7;border:1px solid #e7dcc8;border-radius:14px;overflow:hidden;box-shadow:none}.worksheet-board-paper--advanced{background:#fff}.worksheet-board-paper__header{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:24px 28px;background:linear-gradient(135deg,#fff7ed,#fef3c7);border-bottom:2px solid #f59e0b}.worksheet-board-paper--advanced .worksheet-board-paper__header{background:linear-gradient(135deg,#f5f3ff,#ecfeff);border-bottom-color:#7c3aed}.worksheet-board-paper__header p{margin:0 0 7px;color:#92400e;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.worksheet-board-paper__header h2{margin:0;color:#14532d;font-size:clamp(25px,3vw,39px);line-height:1.08;letter-spacing:-.035em}.worksheet-board-paper__identity{min-width:min(100%,220px);display:grid;gap:10px;align-content:start;color:#5f513f;font-size:14px;font-weight:800}.worksheet-board-paper__identity span{border-bottom:1px solid rgba(95,81,63,.25);padding-bottom:6px}.worksheet-board-paper__objective{margin:22px 26px;border-left:6px solid #f59e0b;background:#eff6ff;border-radius:18px;padding:15px 17px;display:grid;gap:5px}.worksheet-board-paper__objective strong{color:#1d4ed8;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.worksheet-board-paper__objective span,.worksheet-board-paper__activity p{color:#374151;font-size:15px;line-height:1.55;font-weight:650}.worksheet-board-paper__activity{padding:18px 26px 24px;border-top:1px solid #f0e5d8}.worksheet-board-paper__activity h3{margin:0 0 10px;color:#b45309;font-size:18px}.worksheet-board-paper--advanced .worksheet-board-paper__activity h3{color:#5b21b6}.worksheet-board__writing-lines{display:grid;gap:8px;margin-top:16px}.worksheet-board__writing-lines span{display:block;height:38px;border-bottom:1px solid #d4c8b0}.worksheet-board-paper__drawing-area{min-height:168px;border:2px dashed #f59e0b;border-radius:22px;background:#fff7ed;display:grid;place-items:center;color:#9a6724;font-size:15px;font-weight:850;text-align:center;padding:18px}.worksheet-board-paper__upload-preview{margin:22px 26px 26px;min-height:620px;background:#f8fafc;border:1px dashed rgba(124,58,237,.22);border-radius:20px;display:grid;place-items:center;overflow:hidden}.worksheet-board-paper__upload-preview img,.worksheet-board-paper__upload-preview iframe{width:100%;height:100%;min-height:620px;max-height:min(78vh,1100px);object-fit:contain;border:0}.worksheet-board-paper__footer{display:flex;justify-content:space-between;gap:12px;padding:16px 26px;background:#fffdf7;border-top:1px dashed #dfd1bb;color:#8b7a5b;font-size:12px;font-weight:850}.worksheet-board__annotation-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:4;overflow:visible}.worksheet-board__path{vector-effect:non-scaling-stroke;filter:drop-shadow(0 1px 0 rgba(255,255,255,.55))}.worksheet-board__path--highlight{mix-blend-mode:multiply}.worksheet-board__path.is-selected,.worksheet-board__shape.is-selected{filter:drop-shadow(0 0 0 rgba(124,58,237,.1)) drop-shadow(0 0 7px rgba(124,58,237,.5))}.worksheet-board__shape{fill:none}.worksheet-board__text-annotation{position:absolute;z-index:5;max-width:520px;font-weight:850;line-height:1.25;white-space:pre-wrap;pointer-events:none;text-shadow:0 1px 0 rgba(255,255,255,.65);padding:2px 4px;border-radius:6px}.worksheet-board__text-annotation.is-selected{outline:2px dashed rgba(124,58,237,.72);outline-offset:3px;background:#ffffffad}.worksheet-board__text-draft{position:absolute;z-index:10;min-width:260px;background:#fff;border:1px solid rgba(124,58,237,.24);border-radius:14px;box-shadow:0 18px 42px #0f172a2e;padding:10px;pointer-events:auto}.worksheet-board__text-draft textarea{width:100%;min-height:74px;border:1px solid rgba(124,58,237,.16);border-radius:10px;padding:9px 10px;resize:vertical;font:inherit;font-size:16px;font-weight:700;color:#111827;outline:none}.worksheet-board__text-draft textarea:focus{border-color:#7c3aed7a;box-shadow:0 0 0 3px #7c3aed1a}.worksheet-board__text-draft div{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.worksheet-board__text-draft button{min-height:34px;padding:0 12px;border-radius:10px;border:1px solid rgba(124,58,237,.18);background:#f6f3ff;color:#5b21b6;font-weight:900;cursor:pointer}.worksheet-board__rail{position:sticky;top:0;align-self:stretch;z-index:9;width:76px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;overflow-y:auto;scrollbar-width:thin;background:linear-gradient(180deg,#24145f,#2e1b70 58%,#1f3d6d);border-left:1px solid rgba(124,58,237,.22);box-shadow:-12px 0 34px #0f172a1f}.worksheet-board__rail-group{width:100%;display:grid;gap:6px;justify-items:center;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.12)}.worksheet-board__rail-group:last-child{border-bottom:0}.worksheet-board__rail-btn{width:44px;height:44px;border:1px solid rgba(255,255,255,.16);border-radius:15px;background:#ffffff14;color:#ffffffc7;display:grid;place-items:center;font:inherit;cursor:pointer;transition:transform .14s ease,background .14s ease,border-color .14s ease,color .14s ease}.worksheet-board__rail-btn span{font-size:20px;line-height:1}.worksheet-board__rail-btn.is-text span{font-weight:950;font-size:19px}.worksheet-board__rail-btn:hover:not(:disabled),.worksheet-board__rail-btn:focus-visible:not(:disabled),.worksheet-board__rail-btn.is-active{transform:translateY(-1px);background:#ffffff2e;border-color:#ffffff57;color:#fff;outline:none}.worksheet-board__rail-btn.is-active{box-shadow:0 0 0 3px #a78bfa47}.worksheet-board__rail-btn:disabled{opacity:.36;cursor:not-allowed}.worksheet-board__rail-btn--danger:hover:not(:disabled){background:#ef44442e;border-color:#f8717173}.worksheet-board__rail-group--palette{grid-template-columns:repeat(2,1fr);gap:7px 5px}.worksheet-board__swatch{width:23px;height:23px;border-radius:999px;border:2px solid rgba(255,255,255,.38);background:var(--swatch);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.worksheet-board__swatch:hover,.worksheet-board__swatch:focus-visible,.worksheet-board__swatch.is-active{transform:scale(1.12);border-color:#fff;box-shadow:0 0 0 3px #ffffff2e;outline:none}.worksheet-board__rail-group--width{color:#ffffffb3;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.worksheet-board__rail-group--width input{width:50px;accent-color:#a78bfa}.worksheet-board__rail-group--width strong{color:#fff;font-size:10px;font-variant-numeric:tabular-nums}@media(max-width:900px){.worksheet-board__toolbar{align-items:flex-start;flex-direction:column}.worksheet-board__tools{justify-content:flex-start}.worksheet-board__workspace{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto}.worksheet-board__stage{padding:16px 14px 18px}.worksheet-board__rail{position:relative;width:100%;min-height:72px;flex-direction:row;justify-content:center;overflow-x:auto;padding:9px 12px calc(9px + env(safe-area-inset-bottom,0px));border-left:0;border-top:1px solid rgba(124,58,237,.22)}.worksheet-board__rail-group{width:auto;display:flex;border-bottom:0;border-right:1px solid rgba(255,255,255,.12);padding:0 10px 0 0}.worksheet-board__rail-group:last-child{border-right:0}.worksheet-board__rail-group--palette{display:flex}.worksheet-board__rail-group--width{min-width:112px}}@media(max-width:520px){.worksheet-board__tools button{min-height:34px;padding:0 9px;font-size:11px}.worksheet-board__rail-btn{width:42px;height:42px;border-radius:13px}}.worksheet-board__stage::-webkit-scrollbar{width:10px;height:10px}.worksheet-board__stage::-webkit-scrollbar-track{background:#7c3aed14;border-radius:999px}.worksheet-board__stage::-webkit-scrollbar-thumb{background:#7c3aed5c;border-radius:999px;border:2px solid rgba(255,255,255,.7)}.worksheet-board__stage::-webkit-scrollbar-thumb:hover{background:#7c3aed8f}.worksheet-board__paper-surface--move .worksheet-board__text-annotation.is-selected{cursor:grab}@media(max-width:767px){.worksheet-board{left:0}}.worksheet-question-passage{margin:10px 0 12px;padding:12px 14px;border-radius:14px;background:#f8fafc;border:1px solid rgba(148,163,184,.22);color:#334155;font-size:14px;line-height:1.65;font-weight:650}.worksheet-question-word-bank{margin:10px 0 12px;padding:10px 12px;border-radius:14px;background:#fff7ed;border:1px solid rgba(245,158,11,.22);display:grid;gap:4px}.worksheet-question-word-bank strong{color:#b45309;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.worksheet-question-word-bank span{color:#7c2d12;font-size:13px;line-height:1.5;font-weight:850}.worksheet-question-list{margin:12px 0 0;padding-left:22px;display:grid;gap:14px}.worksheet-question-list li{color:#334155;font-size:14px;line-height:1.5;font-weight:750}.worksheet-question-list li>span{display:block;margin-bottom:6px}.worksheet-question-list__item--inline{padding:8px 0 10px}.worksheet-question-list__item--inline .worksheet-question-prompt{display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:4px;min-height:34px}.worksheet-question-inline-blank{display:inline-block;width:clamp(92px,14vw,180px);height:1.55em;margin:0 5px;border-bottom:2px solid rgba(100,116,139,.38);transform:translateY(2px)}.worksheet-question-inline-blank--after{width:clamp(110px,16vw,210px);margin-left:10px}.worksheet-question-list__item--inline+.worksheet-question-list__item--inline{border-top:1px solid rgba(226,232,240,.72);padding-top:14px}@media(max-width:767px){.worksheet-question-inline-blank{width:min(42vw,150px)}}.worksheet-board__evidence-message{margin:10px 16px 0;padding:10px 12px;border-radius:14px;background:#fff7ed;border:1px solid rgba(245,158,11,.28);color:#7c2d12;font-size:13px;font-weight:750}.worksheet-board__evidence-panel{margin:10px 16px 0;padding:14px;border-radius:18px;border:1px solid rgba(148,163,184,.28);background:#fffffffa;box-shadow:0 18px 48px #0f172a1f;display:grid;gap:12px;position:relative;z-index:10}.worksheet-board__evidence-panel strong{color:#0f172a;font-size:15px}.worksheet-board__evidence-panel p{margin:4px 0 0;color:#64748b;font-size:13px}.worksheet-board__judgement-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.worksheet-board__judgement-grid button,.worksheet-board__evidence-actions button{border:1px solid rgba(148,163,184,.35);background:#fff;border-radius:999px;padding:9px 11px;font-weight:850;cursor:pointer}.worksheet-board__judgement-grid button.is-active{background:#0f172a;color:#fff;border-color:#0f172a}.worksheet-board__evidence-notes{display:grid;gap:6px;color:#334155;font-size:12px;font-weight:850}.worksheet-board__evidence-notes textarea{width:100%;border-radius:14px;border:1px solid rgba(148,163,184,.35);padding:10px 12px;resize:vertical;font:inherit}.worksheet-board__evidence-actions{display:flex;justify-content:flex-end;gap:8px}.worksheet-board__evidence-actions .is-primary{background:#0f172a;color:#fff;border-color:#0f172a}.worksheet-board{overflow:hidden;height:100dvh;max-height:100dvh}.worksheet-board__workspace{flex:1 1 auto;min-height:0;overflow:hidden}.worksheet-board__stage{height:100%;min-height:0;overflow:auto!important;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;padding-bottom:max(56px,env(safe-area-inset-bottom,0px) + 40px)}.worksheet-board__paper-surface--move{touch-action:pan-x pan-y}.worksheet-board__paper-surface--pen,.worksheet-board__paper-surface--highlighter,.worksheet-board__paper-surface--eraser,.worksheet-board__paper-surface--text,.worksheet-board__paper-surface--line,.worksheet-board__paper-surface--arrow,.worksheet-board__paper-surface--rectangle,.worksheet-board__paper-surface--circle{touch-action:none}@media(max-width:760px){.worksheet-board__judgement-grid{grid-template-columns:1fr}.worksheet-board__evidence-actions{display:grid;grid-template-columns:1fr}.worksheet-board__evidence-actions button,.worksheet-board__judgement-grid button{min-height:44px}}@media(max-width:900px){.worksheet-board__stage{padding-bottom:max(104px,env(safe-area-inset-bottom,0px) + 92px)}}.worksheet-board__tools{display:flex;align-items:center;gap:10px;margin-left:12px}.worksheet-board__icon-action{position:relative;width:46px;height:46px;min-width:46px;min-height:46px;padding:0;border-radius:999px;border:1px solid #e8dff7;background:#fff;color:#7c3aed;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px #7c3aed1f;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}.worksheet-board__icon-action:hover{transform:translateY(-1px);box-shadow:0 14px 28px #7c3aed29}.worksheet-board__icon-action:focus-visible{outline:2px solid rgba(124,58,237,.22);outline-offset:2px}.worksheet-board__icon-action span{font-size:18px;line-height:1}.worksheet-board__icon-action--save{background:#eefcf1;border-color:#d7f3df;color:#2f7d4a}.worksheet-board__icon-action--print{background:#f3ecff;border-color:#e4d7ff;color:#7c3aed}.worksheet-board__icon-action--quit{background:#eef4ff;border-color:#d8e5ff;color:#4f6fd6}.worksheet-board__icon-action--remove{background:#fff3f3;border-color:#ffd9d9;color:#c65353}.worksheet-board__icon-action:after{content:attr(aria-label);position:absolute;left:50%;bottom:-34px;transform:translate(-50%);background:#58487af5;color:#fff;font-size:12px;font-weight:600;line-height:1;white-space:nowrap;padding:8px 10px;border-radius:999px;opacity:0;pointer-events:none;box-shadow:0 10px 20px #0000001f;transition:opacity .16s ease,transform .16s ease;z-index:30}.worksheet-board__icon-action:hover:after,.worksheet-board__icon-action:focus-visible:after{opacity:1;transform:translate(-50%) translateY(2px)}@media(max-width:1100px){.worksheet-board__tools{gap:8px}.worksheet-board__icon-action{width:42px;height:42px;min-width:42px;min-height:42px}.worksheet-board__icon-action span{font-size:16px}}.worksheet-board__toolbar,.worksheet-board__tools,.worksheet-board__main-actions{position:relative;z-index:999999!important;overflow:visible!important}.worksheet-board__workspace,.worksheet-board__stage,.worksheet-board__paper-slot,.worksheet-board__paper-wrap,.worksheet-board__paper-surface{z-index:1}.worksheet-board__icon-action{position:relative;z-index:1000000!important;overflow:visible!important}.worksheet-board__icon-action em{display:none!important}.worksheet-board__icon-action:after{content:attr(aria-label);position:absolute;left:50%;top:-38px;bottom:auto;transform:translate(-50%);background:#58487afa;color:#fff;font-size:12px;font-weight:700;line-height:1;white-space:nowrap;padding:8px 10px;border-radius:999px;opacity:0;pointer-events:none;box-shadow:0 10px 22px #00000029;transition:opacity .16s ease,transform .16s ease;z-index:1000001!important}.worksheet-board__icon-action:hover:after,.worksheet-board__icon-action:focus-visible:after{opacity:1;transform:translate(-50%) translateY(-2px)}.worksheet-board__main-actions .worksheet-board__icon-action:last-child:after{left:auto;right:0;transform:translate(0)}.worksheet-board__main-actions .worksheet-board__icon-action:last-child:hover:after,.worksheet-board__main-actions .worksheet-board__icon-action:last-child:focus-visible:after{transform:translate(0) translateY(-2px)}.worksheet-board__main-actions .worksheet-board__icon-action:nth-last-child(2):after{left:auto;right:-8px;transform:translate(0)}.worksheet-board__main-actions .worksheet-board__icon-action:nth-last-child(2):hover:after,.worksheet-board__main-actions .worksheet-board__icon-action:nth-last-child(2):focus-visible:after{transform:translate(0) translateY(-2px)}.mention-picker{position:absolute;bottom:calc(100% + 6px);left:0;min-width:220px;max-width:300px;max-height:220px;overflow-y:auto;background:var(--modal-bg);border:1.5px solid var(--border, #e2e8f0);border-radius:10px;box-shadow:var(--shadow-lg, 0 8px 24px rgba(0,0,0,.14));z-index:200;animation:mention-in .12s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}@keyframes mention-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.mention-picker__header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text2, #94a3b8);padding:8px 12px 4px;flex-shrink:0}.mention-picker__item{display:flex;align-items:center;gap:9px;width:100%;padding:7px 12px;background:none;border:none;text-align:left;cursor:pointer;transition:background 80ms;min-height:44px}.mention-picker__item:hover,.mention-picker__item--active{background:color-mix(in srgb,var(--teal, #0d9488) 8%,transparent)}.mention-picker__item:last-child{border-radius:0 0 8px 8px}.mention-picker__avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--modal-surface2)}.mention-picker__name{font-size:13px;font-weight:500;color:var(--text, #1e293b);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-picker__highlight{color:var(--teal, #0d9488);font-weight:800}.mention-picker__role{font-size:10px;font-weight:600;color:var(--text2, #94a3b8);background:var(--modal-surface2);padding:1px 7px;border-radius:var(--radius-pill);flex-shrink:0}.mention-picker--empty{pointer-events:none}.mention-picker__no-results{display:block;font-size:12px;color:var(--text2, #94a3b8);padding:12px;text-align:center;font-style:italic}.mention-chip{display:inline;font-weight:700;color:var(--teal, #0d9488);background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent);padding:0 4px;border-radius:4px;font-size:inherit}.ann-panel{position:absolute;left:0;top:0;bottom:0;width:var(--ann-panel-w);max-width:calc(100vw - 80px);background:var(--modal-bg);border-right:1px solid var(--brand-border);box-shadow:var(--shadow-lg, 0 8px 30px rgba(0,0,0,.12));display:flex;flex-direction:column;z-index:30;overflow:hidden;opacity:0;transform:translate(-12px);transition:opacity .18s cubic-bezier(.4,0,.2,1),transform .18s cubic-bezier(.4,0,.2,1);pointer-events:none}.ann-panel.is-open{opacity:1;transform:translate(0);pointer-events:auto}@keyframes ann-panel-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.ann-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0;gap:12px}.ann-panel__title-row{display:flex;align-items:center;gap:14px}.ann-panel__header-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--brand-hover);color:var(--brand-text);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.ann-panel__icon{font-size:20px}.ann-panel__title-text{display:flex;flex-direction:column;gap:2px}.ann-panel__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0;line-height:1.3}.ann-panel__subtitle{font-size:12px;color:var(--brand-text-sub);margin:0}.ann-panel__count-badge{background:#ffffff2e;color:var(--brand-text);font-size:11px;font-weight:700;padding:1px 7px;border-radius:var(--radius-pill);min-width:20px;text-align:center}.ann-panel__header-actions{display:flex;align-items:center;gap:8px}.ann-panel__place-btn{font-size:13px;font-weight:600;padding:6px 14px;border-radius:8px;border:2px solid rgba(255,255,255,.35);background:transparent;color:var(--brand-text);cursor:pointer;transition:background .12s,color .12s;min-height:36px}.ann-panel__place-btn:hover{background:var(--brand-hover)}.ann-panel__place-btn--active{background:#ffffff2e;border-color:#ffffff8c}.ann-panel__close-btn{width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--brand-text-sub);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .12s}.ann-panel__close-btn:hover{background:var(--brand-hover);color:var(--brand-text)}.ann-panel__filters{display:flex;gap:0;padding:10px 16px 0;flex-shrink:0;border-bottom:1px solid var(--border, #e2e8f0)}.ann-panel__filter-tab{flex:1;padding:8px 0;background:none;border:none;border-bottom:2.5px solid transparent;font-size:13px;font-weight:600;color:var(--text2, #64748b);cursor:pointer;transition:color .12s,border-color .12s}.ann-panel__filter-tab:hover{color:var(--text, #1e293b)}.ann-panel__filter-tab--active{color:var(--teal, #0d9488);border-bottom-color:var(--teal, #0d9488)}.ann-panel__placing-hint{margin:10px 16px;padding:10px 14px;background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent);border:1.5px solid color-mix(in srgb,var(--teal, #0d9488) 30%,transparent);border-radius:10px;font-size:13px;color:var(--teal, #0d9488);font-weight:600;flex-shrink:0}.ann-panel__body{display:flex;flex:1;overflow:hidden}.ann-panel__list{width:220px;min-width:180px;flex-shrink:0;overflow-y:auto;border-right:1px solid var(--brand-border);padding:8px 0}.ann-panel__empty{padding:24px 16px;font-size:13px;color:var(--text2, #64748b);text-align:center;line-height:1.5}.ann-list-item{display:block;width:100%;padding:10px 14px;text-align:left;background:none;border:none;border-bottom:1px solid var(--border, #f1f5f9);cursor:pointer;transition:background .1s}.ann-list-item:hover{background:var(--modal-surface2)}.ann-list-item--active{background:color-mix(in srgb,var(--teal, #0d9488) 8%,transparent)}.ann-list-item--resolved{opacity:.6}.ann-list-item__row{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.ann-list-item__author{font-size:12px;font-weight:700;color:var(--text, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ann-list-item__time{font-size:11px;color:var(--text2, #94a3b8);flex-shrink:0;margin-left:4px}.ann-list-item__preview{font-size:12px;color:var(--text2, #64748b);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.ann-list-item__preview--empty{font-style:italic}.ann-list-item__meta{display:flex;align-items:center;gap:8px}.ann-list-item__thread-count{font-size:11px;color:var(--text2, #94a3b8)}.ann-list-item__resolved-badge{font-size:11px;font-weight:600;color:#16a34a;background:#dcfce7;padding:1px 6px;border-radius:var(--radius-pill)}.ann-thread{flex:1;display:flex;flex-direction:column;overflow:hidden}.ann-thread__header{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border, #e2e8f0);flex-shrink:0;flex-wrap:wrap}.ann-thread__author-chip{font-size:12px;font-weight:700;color:var(--teal, #0d9488);background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent);padding:2px 10px;border-radius:var(--radius-pill)}.ann-thread__date{font-size:11px;color:var(--text2, #94a3b8);flex:1}.ann-thread__actions{display:flex;gap:6px;margin-left:auto}.ann-thread__action-btn{font-size:12px;font-weight:600;padding:4px 10px;border-radius:6px;border:1.5px solid var(--border, #e2e8f0);background:transparent;cursor:pointer;transition:background .1s,color .1s;color:var(--text2, #64748b);min-height:30px}.ann-thread__action-btn:hover{background:var(--modal-surface2)}.ann-thread__action-btn--resolve{color:#16a34a;border-color:#16a34a}.ann-thread__action-btn--resolve:hover{background:#dcfce7}.ann-thread__action-btn--reopen{color:var(--teal, #0d9488);border-color:var(--teal, #0d9488)}.ann-thread__action-btn--reopen:hover{background:color-mix(in srgb,var(--teal, #0d9488) 10%,transparent)}.ann-thread__action-btn--delete{color:#dc2626;border-color:#dc2626}.ann-thread__action-btn--delete:hover{background:#fee2e2}.ann-thread__messages{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:12px}.ann-thread__empty{font-size:13px;color:var(--text2, #94a3b8);text-align:center;margin-top:24px;font-style:italic}.ann-comment__row{display:flex;align-items:center;gap:6px;margin-bottom:3px}.ann-comment__author{font-size:12px;font-weight:700;color:var(--text, #1e293b)}.ann-comment__time{font-size:11px;color:var(--text2, #94a3b8)}.ann-comment__edited{font-size:11px;color:var(--text2, #94a3b8);font-style:italic}.ann-comment__controls{display:flex;gap:2px;margin-left:auto;opacity:0;transition:opacity .1s}.ann-comment:hover .ann-comment__controls{opacity:1}.ann-comment__ctrl-btn{width:24px;height:24px;border:none;background:transparent;cursor:pointer;border-radius:4px;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .1s}.ann-comment__ctrl-btn:hover{background:var(--modal-surface2)}.ann-comment__text{font-size:13px;color:var(--text, #1e293b);margin:0;line-height:1.5;background:var(--modal-surface2);padding:8px 10px;border-radius:8px 8px 8px 2px;word-break:break-word}.ann-comment__edit-area{display:flex;flex-direction:column;gap:6px}.ann-comment__edit-input{width:100%;font-size:13px;padding:7px 9px;border:1.5px solid var(--teal, #0d9488);border-radius:8px;background:var(--modal-bg);color:var(--text, #1e293b);resize:none;font-family:inherit;outline:none;box-sizing:border-box}.ann-comment__edit-btns{display:flex;gap:6px}.ann-comment__edit-save{font-size:12px;font-weight:700;padding:4px 12px;background:var(--teal, #0d9488);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:opacity .12s}.ann-comment__edit-save:hover{opacity:.85}.ann-comment__edit-cancel{font-size:12px;padding:4px 12px;background:var(--modal-surface2);color:var(--text2, #64748b);border:none;border-radius:6px;cursor:pointer}.ann-thread__reply{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--border, #e2e8f0);flex-shrink:0;align-items:flex-end}.ann-thread__reply-input{flex:1;font-size:13px;padding:8px 10px;border:1.5px solid var(--border, #e2e8f0);border-radius:10px;background:var(--modal-surface2);color:var(--text, #1e293b);resize:none;font-family:inherit;outline:none;transition:border-color .12s}.ann-thread__reply-input:focus{border-color:var(--teal, #0d9488);background:var(--modal-bg)}.ann-thread__reply-btn{font-size:13px;font-weight:700;padding:8px 16px;background:var(--teal, #0d9488);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:opacity .12s;flex-shrink:0;min-height:38px}.ann-thread__reply-btn:hover{opacity:.85}.ann-thread__reply-btn:disabled{opacity:.4;cursor:not-allowed}.mention-textarea-wrap{position:relative;flex:1;display:flex;flex-direction:column}.ann-thread__reply .mention-textarea-wrap{flex:1}.mention-textarea-wrap textarea{width:100%}@media(max-width:767px){.ann-panel{position:fixed;top:var(--topbar-h, 60px);left:0;bottom:56px;width:100vw;max-width:100vw;z-index:200}}.brp-backdrop{position:fixed;inset:0;background:#0f172a59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;opacity:0;transition:opacity .18s ease-in-out;pointer-events:none}.brp-backdrop.is-open{opacity:1;pointer-events:auto}.brp{position:fixed;top:0;right:0;bottom:0;width:360px;max-width:100vw;background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:-4px 0 24px #0000001f;z-index:201;display:flex;flex-direction:column;transform:translate(100%);transition:transform .18s cubic-bezier(.4,0,.2,1);overflow:hidden}.brp.is-open{transform:translate(0)}.brp__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0;gap:12px}.brp__header-left{display:flex;align-items:center;gap:14px}.brp__header-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--brand-hover);color:var(--brand-text);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.brp__icon{font-size:18px}.brp__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0 0 2px;line-height:1.3}.brp__subtitle{font-size:12px;color:var(--brand-text-sub);margin:0}.brp__active-badge{font-size:11px;font-weight:600;color:#fff;background:var(--teal, #10B981);border-radius:10px;padding:2px 8px}.brp__close{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--brand-text-sub);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;margin-left:auto;flex-shrink:0}.brp__close:hover{background:#ffffff1f;color:var(--brand-text)}.brp__body{flex:1;overflow-y:auto;padding:14px 14px 24px;display:flex;flex-direction:column;gap:12px}.brp__in-room-banner{display:flex;align-items:center;justify-content:space-between;gap:8px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:10px;padding:10px 12px;font-size:12px;color:#065f46}.brp__leave-btn{font-size:12px;font-weight:600;color:#059669;background:transparent;border:1px solid #059669;border-radius:6px;padding:4px 10px;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s}.brp__leave-btn:hover{background:#059669;color:#fff}.brp__toolbar{display:flex;align-items:center;justify-content:space-between}.brp__create-btn{height:36px;padding:0 16px;border-radius:8px;border:none;background:var(--brand-accent, #3B82F6);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,opacity .12s}.brp__create-btn:hover:not(:disabled){filter:brightness(1.1)}.brp__create-btn:disabled{opacity:.4;cursor:not-allowed}.brp__count{font-size:12px;color:var(--text-muted, #64748b)}.brp__empty{text-align:center;padding:32px 16px;color:var(--text-muted, #64748b)}.brp__empty-icon{font-size:36px;margin:0 0 8px}.brp__empty-text{font-size:14px;font-weight:600;margin:0 0 4px}.brp__empty-sub{font-size:12px;margin:0;line-height:1.5}.brp__room-list{display:flex;flex-direction:column;gap:10px}.brp__room-card{border:1.5px solid var(--border, #e2e8f0);border-radius:12px;padding:12px;background:var(--modal-bg);transition:border-color .15s,box-shadow .15s}.brp__room-card.is-joined{border-color:var(--room-colour, #3B82F6);box-shadow:0 0 0 3px color-mix(in srgb,var(--room-colour, #3B82F6) 15%,transparent)}.brp__room-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.brp__room-colour-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.brp__room-name{flex:1;text-align:left;background:transparent;border:none;font-size:13px;font-weight:700;color:var(--text, #1e293b);cursor:pointer;padding:0;display:flex;align-items:center;gap:4px}.brp__room-name:hover .brp__edit-hint{opacity:1}.brp__edit-hint{font-size:11px;opacity:0;transition:opacity .15s}.brp__room-name-input{flex:1;font-size:13px;font-weight:700;color:var(--text, #1e293b);border:1px solid #93c5fd;border-radius:4px;padding:2px 6px;outline:none;background:var(--modal-bg)}.brp__status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background .3s}.brp__room-students{font-size:11px;color:var(--text-muted, #64748b);margin-bottom:10px;min-height:16px}.brp__no-students{font-style:italic}.brp__room-actions{display:flex;gap:6px;align-items:center}.brp__assign-btn,.brp__join-btn,.brp__leave-room-btn{height:32px;padding:0 12px;border-radius:7px;border:1px solid var(--border, #e2e8f0);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s;background:var(--modal-bg);color:var(--text, #1e293b)}.brp__assign-btn:hover{background:var(--hover, #f1f5f9)}.brp__join-btn{background:var(--room-colour, #3B82F6);color:#fff;border-color:transparent}.brp__join-btn:hover{filter:brightness(.9)}.brp__leave-room-btn{color:#059669;border-color:#059669}.brp__leave-room-btn:hover{background:#05966914}.brp__destroy-btn{margin-left:auto;width:32px;height:32px;border-radius:7px;border:1px solid var(--border, #e2e8f0);background:transparent;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s;color:var(--text-muted, #64748b)}.brp__destroy-btn:hover{background:#ef44441f;border-color:#ef444466;color:#ef4444}.brp__assign-picker{margin-top:10px;border-top:1px solid var(--border, #e2e8f0);padding-top:10px}.brp__assign-label{font-size:11px;font-weight:600;color:var(--text-muted, #64748b);margin:0 0 8px;text-transform:uppercase;letter-spacing:.04em}.brp__student-list{list-style:none;margin:0 0 10px;padding:0;display:flex;flex-direction:column;gap:4px}.brp__student-label{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;cursor:pointer;transition:background .1s;font-size:13px}.brp__student-label:hover{background:var(--hover, #f1f5f9)}.brp__student-label input[type=checkbox]{width:14px;height:14px;cursor:pointer}.brp__student-avatar{font-size:16px}.brp__student-name-text{color:var(--text, #1e293b)}.brp__assign-footer{display:flex;gap:8px}.brp__assign-confirm,.brp__assign-cancel{height:30px;padding:0 14px;border-radius:6px;border:1px solid var(--border, #e2e8f0);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s;background:var(--modal-bg);color:var(--text, #1e293b)}.brp__assign-confirm{background:#3b82f6;color:#fff;border-color:transparent}.brp__assign-confirm:hover{background:#2563eb}.brp__assign-cancel:hover{background:var(--hover, #f1f5f9)}.brp__footer-note{font-size:11px;color:var(--text-muted, #94a3b8);line-height:1.5;margin:0;padding-top:4px;border-top:1px solid var(--border, #e2e8f0)}.library-filters{display:flex;flex-direction:column;flex-shrink:0;width:100%;min-width:0;border-bottom:1px solid var(--brand-border);background:var(--brand-bg)}.library-filters__controls{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 8px 10px;gap:8px;border-bottom:1px solid var(--brand-border)}.library-filters__view-toggle{display:flex;align-items:center;gap:2px;padding:3px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-radius:var(--radius-sm)}.library-filters__view-btn{display:flex;align-items:center;justify-content:center;width:30px;height:26px;border:none;border-radius:5px;background:transparent;color:var(--brand-text-muted);cursor:pointer;transition:background .13s ease-out,color .13s ease-out,transform .1s ease-out;flex-shrink:0}.library-filters__view-btn:hover:not(.is-active){background:var(--brand-hover);color:var(--brand-text);transform:scale(1.05)}.library-filters__view-btn.is-active{background:var(--brand-accent);color:#fff;box-shadow:0 1px 4px #00000026}.library-filters__add-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;font-family:var(--font-body, "Nunito Sans", sans-serif);font-size:12px;font-weight:700;color:var(--brand-accent);background:color-mix(in srgb,var(--brand-accent) 10%,transparent);border:1.5px solid color-mix(in srgb,var(--brand-accent) 35%,transparent);border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;transition:background .14s ease-out,color .14s ease-out,border-color .14s ease-out,transform .12s ease-out}.library-filters__add-btn:hover{background:var(--brand-accent);color:#fff;border-color:var(--brand-accent);transform:scale(1.03)}.library-filters__add-btn:active{transform:scale(.97)}.library-filter-track{padding:7px 10px 6px}.library-filter-track:first-of-type{border-bottom:1px solid var(--brand-border)}.library-filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:5px}.library-filter-pill{display:inline-flex;align-items:center;padding:5px 12px;font-family:var(--font-body, "Nunito Sans", sans-serif);font-size:11.5px;font-weight:600;color:var(--brand-text-muted);background:var(--brand-hover);border:1.5px solid transparent;border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .14s ease-out,color .14s ease-out,border-color .14s ease-out,transform .11s ease-out}.library-filter-pill:hover:not(.is-active){background:var(--brand-hover);border-color:var(--brand-border);color:var(--brand-text);transform:scale(1.04)}.library-filter-pill.is-active{background:var(--pill-active-bg, var(--brand-accent));color:var(--pill-active-color, #fff);border-color:var(--pill-active-bg, var(--brand-accent));font-weight:700;transform:scale(1.04);box-shadow:0 2px 8px color-mix(in srgb,var(--pill-active-bg, var(--brand-accent)) 35%,transparent)}.library-filter-pill:active{transform:scale(.97)}.library-card{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:6px;padding:10px 10px 8px 12px;min-height:100px;background:var(--brand-bg-deep, var(--brand-bg));border:1.5px solid var(--brand-border);border-left:4px solid var(--card-subject-color, var(--teal));border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s ease-out,box-shadow .15s ease-out,transform .12s ease-out,background .15s ease-out}.library-card:hover{border-color:var(--brand-border);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0,0,0,.12));transform:translateY(-2px)}.library-card:active{transform:translateY(0) scale(.98)}.library-card.is-selected{border:2px solid var(--card-subject-color, var(--teal));border-left:4px solid var(--card-subject-color, var(--teal));box-shadow:0 0 0 3px color-mix(in srgb,var(--card-subject-color, var(--teal)) 20%,transparent),var(--shadow-sm);background:color-mix(in srgb,var(--card-subject-color, var(--brand-accent)) 8%,var(--brand-bg))}.library-card__check{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;background:var(--card-subject-color, var(--teal));color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 1px 4px #00000040;z-index:2;pointer-events:none}.library-card__top{display:flex;align-items:flex-start;gap:8px;flex:1;min-height:0}.library-card__emoji{font-size:22px;line-height:1;flex-shrink:0;margin-top:1px}.library-card__title{font-family:var(--font, "Nunito", sans-serif);font-size:13px;font-weight:700;color:var(--brand-text);line-height:1.35;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.library-card__bottom{display:flex;align-items:center;justify-content:space-between;gap:4px;flex-shrink:0}.library-card__badges{display:flex;align-items:center;gap:4px;flex-wrap:wrap;min-width:0}.library-card__badge{font-family:var(--font-body, "Nunito Sans", sans-serif);font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-pill);white-space:nowrap;line-height:1.4}.library-card__badge--subject{background:color-mix(in srgb,var(--card-subject-color, var(--teal)) 18%,var(--brand-bg-deep, var(--brand-bg)));color:var(--card-subject-color, var(--teal));outline:1px solid color-mix(in srgb,var(--card-subject-color, var(--teal)) 30%,transparent);outline-offset:-1px}.library-card__badge--type{background:var(--brand-hover);color:var(--brand-text-muted)}.library-card__badge--custom{background:color-mix(in srgb,var(--amber, #D97706) 18%,var(--brand-bg-deep, var(--brand-bg)));color:var(--amber, #D97706);outline:1px solid color-mix(in srgb,var(--amber, #D97706) 30%,transparent);outline-offset:-1px}.library-card__age{font-family:var(--font-body, "Nunito Sans", sans-serif);font-size:10px;font-weight:500;color:var(--brand-text-muted);white-space:nowrap;flex-shrink:0}.library-card--list{flex-direction:row;align-items:center;min-height:unset;padding:8px 12px;gap:10px;border-left:3px solid var(--card-subject-color, var(--teal));border-radius:var(--radius-sm)}.library-card--list:hover{transform:translateY(-1px)}.library-card--list .library-card__emoji{font-size:18px;margin-top:0;flex-shrink:0}.library-card--list .library-card__title--list{flex:1;min-width:0;font-size:12px;font-weight:700;color:var(--brand-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;-webkit-line-clamp:unset}.library-card__list-meta{display:flex;align-items:center;gap:5px;flex-shrink:0}.library-card--list .library-card__age{font-size:10px}.library-card__delete-zone{position:absolute;top:-1px;left:-1px;z-index:3;opacity:0;pointer-events:none;transition:opacity .12s ease}.library-card:hover .library-card__delete-zone,.library-card__delete-zone:has(.library-card__confirm){opacity:1;pointer-events:all}.library-card__delete-btn{width:26px;height:26px;border:none;border-radius:0 0 8px;background:#e11d481a;color:var(--rose, #E11D48);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .12s ease,transform .1s ease}.library-card__delete-btn:hover{background:#e11d4833;transform:scale(1.1)}.library-card__confirm{display:flex;align-items:center;gap:4px;padding:4px 6px;background:var(--brand-bg);border:1.5px solid var(--rose, #E11D48);border-radius:0 8px 8px 0;box-shadow:var(--shadow);white-space:nowrap;animation:card-confirm-in .12s ease-out both}@media(prefers-reduced-motion:no-preference){@keyframes card-confirm-in{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}}.library-card__confirm-text{font-size:11px;font-weight:700;color:var(--rose, #E11D48)}.library-card__confirm-yes,.library-card__confirm-no{height:20px;padding:0 7px;border:none;border-radius:4px;font-size:11px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .1s ease,transform 80ms ease}.library-card__confirm-yes{background:var(--rose, #E11D48);color:#fff}.library-card__confirm-yes:hover{background:#be123c;transform:scale(1.05)}.library-card__confirm-no{background:var(--brand-hover);color:var(--brand-text-muted)}.library-card__confirm-no:hover{background:var(--brand-active);color:var(--brand-text)}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 16px;width:100%}.loading-spinner--sm .loading-spinner__ring{width:24px;height:24px;border-width:2px}.loading-spinner--md .loading-spinner__ring{width:36px;height:36px;border-width:3px}.loading-spinner--lg .loading-spinner__ring{width:52px;height:52px;border-width:4px}.loading-spinner__ring{border-style:solid;border-color:var(--surface2, #E2E8F0);border-top-color:var(--teal, #0D9488);border-radius:50%;animation:ls-spin .75s linear infinite}.loading-spinner__label{font-size:13px;color:var(--text-muted, #94A3B8);font-family:var(--font-ui, Arial, sans-serif)}@keyframes ls-spin{to{transform:rotate(360deg)}}.library-card-grid-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 12px 16px;min-height:0}.library-card-grid-wrapper::-webkit-scrollbar{width:4px}.library-card-grid-wrapper::-webkit-scrollbar-track{background:transparent}.library-card-grid-wrapper::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}.library-card-grid__count{font-family:var(--font-body, "Nunito Sans", sans-serif);font-size:11px;font-weight:600;color:var(--brand-text-muted);margin:0 0 10px 2px;line-height:1}.library-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.library-card-list{display:flex;flex-direction:column;gap:6px}.library-card-grid__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 16px;text-align:center}.library-card-grid__empty-icon{font-size:36px;line-height:1;opacity:.5}.library-card-grid__empty-text{font-family:var(--font-body, "Nunito Sans", sans-serif);font-size:13px;font-weight:500;color:var(--brand-text-muted);margin:0}.library-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 16px;height:52px;flex-shrink:0;background:var(--brand-bg-deep, var(--brand-bg));border-bottom:1px solid var(--brand-border);position:sticky;top:0;z-index:10}.library-header__title-group{display:flex;align-items:center;gap:9px;min-width:0}.library-header__icon{font-size:18px;line-height:1;flex-shrink:0}.library-header__title{font-family:var(--font, "Nunito", sans-serif);font-size:14px;font-weight:800;color:var(--brand-text);margin:0;line-height:1.2;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-header__close-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1.5px solid var(--brand-border);border-radius:50%;background:transparent;cursor:pointer;color:var(--brand-text-muted);flex-shrink:0;transition:background .12s ease-out,color .12s ease-out,border-color .12s ease-out,transform .12s ease-out}.library-header__close-btn:hover{background:#dc26261a;border-color:#dc2626;color:#dc2626;transform:scale(1.08)}.library-header__close-btn:active{transform:scale(.94)}.assign-btn-wrap{flex-shrink:0;padding:0 12px;opacity:0;transform:translateY(10px);pointer-events:none;max-height:0;overflow:hidden;transition:opacity .22s ease-out,transform .22s ease-out,max-height .22s ease-out,padding .22s ease-out}.assign-btn-wrap.is-visible{opacity:1;transform:translateY(0);pointer-events:all;max-height:80px;padding:10px 12px 12px}.assign-btn{display:block;width:100%;height:48px;padding:0 16px;background:var(--teal);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:14px;font-weight:700;letter-spacing:.01em;white-space:nowrap;box-shadow:0 2px 8px #0d948859;transition:background .14s ease,box-shadow .14s ease,transform .1s ease}.assign-btn:hover:not(:disabled){background:var(--teal-d);box-shadow:0 4px 14px #0d948873;transform:translateY(-1px)}.assign-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #0d94884d}.assign-btn:disabled{cursor:default}.board-thumbnail{display:block;width:100%;height:90px;flex-shrink:0;border-top:1px solid var(--border)}.student-card{background:var(--modal-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;transition:box-shadow .12s ease-out,transform .12s ease-out,border-color .12s ease-out}.student-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--border2)}.student-card:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.student-card__header{display:flex;align-items:center;gap:10px;padding:14px 14px 12px}.student-card__avatar{width:36px;height:36px;border-radius:50%;border:2px solid transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-card__avatar-emoji{font-size:20px;line-height:1}.student-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.student-card__name{font-size:13px;font-weight:700;color:var(--text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-card__game{font-size:11px;font-weight:500;color:var(--text-muted);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-card__status{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0}.student-card__board-placeholder{height:90px;background:var(--modal-surface2);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;background-image:radial-gradient(circle,var(--border2) 1px,transparent 1px);background-size:20px 20px}.student-card__board-hint{font-size:22px;opacity:.25}.monitor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:stretch;align-content:start;width:100%;padding:4px 2px;box-sizing:border-box}@media(max-width:1279px){.monitor-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1023px){.monitor-grid{grid-template-columns:repeat(2,1fr)}}.slb-backdrop{position:fixed;inset:0;z-index:400;background:#0f172a8c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:slb-backdrop-in .16s ease-out both}@media(prefers-reduced-motion:no-preference){@keyframes slb-backdrop-in{0%{opacity:0}to{opacity:1}}}.slb{position:fixed;z-index:401;margin:auto;width:min(520px,calc(100vw - 48px));height:fit-content;inset:50% 0 0 50%;transform:translate(-50%,-50%);background:var(--modal-bg);border-radius:var(--radius-xl, 24px);box-shadow:0 24px 64px #00000038,0 4px 16px #0000001f;border:1px solid var(--border);overflow:hidden;outline:none;animation:slb-card-in .2s cubic-bezier(.34,1.2,.64,1) both}@media(prefers-reduced-motion:no-preference){@keyframes slb-card-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 18px)) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}}.slb__header{display:flex;align-items:center;gap:12px;padding:18px 18px 16px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border)}.slb__avatar{width:44px;height:44px;border-radius:50%;border:2px solid transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0}.slb__avatar-emoji{font-size:26px;line-height:1}.slb__name-group{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.slb__name{font-size:17px;font-weight:800;color:var(--brand-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slb__game{font-size:11px;font-weight:500;color:var(--brand-text-sub);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slb__status{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 11px;border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0}.slb__close{width:34px;height:34px;border:none;border-radius:50%;background:var(--modal-surface2);color:var(--text-sub, var(--text-muted));font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s ease,color .12s ease,transform .1s ease}.slb__close:hover{background:var(--border2);color:var(--text);transform:scale(1.08)}.slb__divider{height:1px;background:var(--border);flex-shrink:0}.slb__board{line-height:0}.slb__board .board-thumbnail{height:300px;border-top:none}.results-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 32px;gap:14px;min-height:340px}.results-empty__emoji{font-size:56px;line-height:1;display:block}.results-empty__heading{font-size:16px;font-weight:800;color:var(--text-muted);margin:0}.results-empty__sub{font-size:14px;font-weight:500;color:var(--text-muted);margin:0;max-width:320px;line-height:1.5;opacity:.75}.acr{display:flex;flex-direction:column;gap:10px;padding:16px 18px 14px;background:var(--modal-bg);border:1px solid var(--border);border-radius:var(--radius-lg, 16px);transition:box-shadow .12s ease-out,transform .12s ease-out}.acr:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.acr__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.acr__left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.acr__emoji{font-size:26px;line-height:1;flex-shrink:0}.acr__title-group{display:flex;flex-direction:column;gap:4px;min-width:0}.acr__title{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.acr__subject-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-pill);width:fit-content}.acr__count{font-size:13px;font-weight:600;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.acr__bar-track{height:8px;background:var(--modal-surface2);border-radius:var(--radius-pill);overflow:hidden;flex-shrink:0}.acr__bar-fill{height:100%;border-radius:var(--radius-pill);transition:width .6s cubic-bezier(.4,0,.2,1);min-width:0}.acr__chips{display:flex;flex-wrap:wrap;gap:6px}.acr__chip{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;line-height:1;cursor:default;flex-shrink:0;position:relative;transition:transform .12s ease-out,box-shadow .12s ease-out}.acr__chip:hover{transform:scale(1.15);z-index:1}.acr__chip--done{background:#05966926;font-size:16px}.acr__chip--done:hover{background:#05966940;box-shadow:0 0 0 2px #05966959}.child-view{display:flex;flex-direction:column;height:100vh;overflow:hidden}.child-canvas{flex:1;position:relative;overflow:hidden}.child-canvas>.drawing-canvas-wrapper{width:100%;height:100%}.child-canvas--game-annotating .drawing-canvas{z-index:35}.activity-card{position:relative;flex-shrink:0;width:130px;height:105px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px 8px;border-radius:12px;border:2px solid var(--border);background:var(--modal-bg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease,transform .12s ease-out}.activity-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.activity-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.activity-card--not-started{border-color:var(--border);background:var(--modal-bg)}.activity-card--not-started .activity-card__status{color:var(--text-muted)}.activity-card--active{border-color:var(--card-color);background:var(--modal-bg);animation:card-glow-pulse 2s ease-in-out infinite}@media(prefers-reduced-motion:no-preference){@keyframes card-glow-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--card-color) 30%,transparent)}50%{box-shadow:0 0 0 6px color-mix(in srgb,var(--card-color) 0%,transparent)}}}@supports not (color: color-mix(in srgb,red 10%,transparent)){@media(prefers-reduced-motion:no-preference){@keyframes card-glow-pulse{0%,to{box-shadow:0 0 #0d94884d}50%{box-shadow:0 0 0 6px #0d948800}}}}.activity-card--active .activity-card__status{color:var(--card-color)}.activity-card--done{border-color:var(--green, #059669);background:#0596691a}.activity-card--done .activity-card__status{color:var(--green, #059669);font-weight:700}.activity-card__done-badge{position:absolute;top:6px;right:6px;font-size:14px;line-height:1}.activity-card__emoji{font-size:30px;line-height:1;display:block;margin-top:2px}.activity-card__title{font-size:11px;font-weight:700;color:var(--text);text-align:center;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3;width:100%;overflow-wrap:break-word}.activity-card__status{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;line-height:1}.activity-shelf{position:absolute;bottom:0;left:0;right:0;z-index:20;display:flex;flex-direction:column;transform:translateY(100%);opacity:0;transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .28s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.activity-shelf--visible{transform:translateY(0);opacity:1}.shelf-cards-area{height:0;overflow:hidden;transition:height .22s cubic-bezier(.4,0,.2,1);background:var(--modal-bg);border-top:1px solid var(--brand-border)}.activity-shelf--open .shelf-cards-area{height:130px}.shelf-cards-scroll{display:flex;flex-direction:row;align-items:center;gap:10px;padding:12px 16px;height:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.shelf-cards-scroll::-webkit-scrollbar{height:4px}.shelf-cards-scroll::-webkit-scrollbar-track{background:transparent}.shelf-cards-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.shelf-handle{height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--modal-bg);border-top:1px solid var(--border);box-shadow:0 -2px 8px #00000014;border-radius:12px 12px 0 0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease-in-out,box-shadow .12s ease-out}.activity-shelf--open .shelf-handle{border-radius:0;box-shadow:0 -1px 4px #0000000f}.shelf-handle:hover,.shelf-handle:focus-visible{background:var(--modal-surface2);outline:none;box-shadow:0 -2px 12px #0000001f}.shelf-handle:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}.shelf-handle__label{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:5px}.shelf-handle__count{color:var(--text-muted);font-weight:500}.shelf-handle__arrow{font-size:14px;color:var(--text-muted);line-height:1;display:inline-block;transform:rotate(0);transition:transform .22s cubic-bezier(.4,0,.2,1),color .12s ease;will-change:transform}.activity-shelf--open .shelf-handle__arrow{transform:rotate(180deg);color:var(--teal)}.egc{position:absolute;left:50%;top:80px;transform:translate(-50%);width:420px;max-width:calc(100vw - 32px);z-index:30;background:transparent;border:none;box-shadow:none;outline:none;overflow:visible;animation:egc-in .24s cubic-bezier(.34,1.56,.64,1) both}@keyframes egc-in{0%{opacity:0;transform:translate(-50%) scale(.95) translateY(8px)}to{opacity:1;transform:translate(-50%) scale(1) translateY(0)}}.egc[style*="transform: none"]{animation:egc-in-d .24s cubic-bezier(.34,1.56,.64,1) both}@keyframes egc-in-d{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.egc--annotate{cursor:default}.egc__grip{position:absolute;top:0;left:0;right:0;height:14px;cursor:grab;z-index:50}.egc__grip:active{cursor:grabbing}.egc__game-layer{width:100%;height:380px;position:relative;background:transparent}.egc-ctrl{position:absolute;z-index:9999;display:flex;align-items:center;gap:3px;padding:4px 6px;pointer-events:all!important;background:color-mix(in srgb,var(--modal-bg,#fff) 84%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:6px;border:1px solid color-mix(in srgb,var(--egc-color,#0D9488) 28%,var(--border,#E2E8F0));box-shadow:0 1px 8px #0000001c}.egc-ctrl__grip{font-size:13px;line-height:1;color:var(--text-muted,#94A3B8);cursor:grab;padding:1px 3px;border:none;background:transparent;border-radius:3px;-webkit-user-select:none;user-select:none;transition:color .1s;flex-shrink:0}.egc-ctrl__grip:hover{color:var(--text,#1E293B)}.egc-ctrl__grip:active{cursor:grabbing}.egc-ctrl__close{width:20px;height:20px;border-radius:50%;border:none;background:transparent;color:var(--text-muted,#94A3B8);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.egc-ctrl__close:hover{background:#ef44441f;color:#ef4444}.egc-ctrl__close:focus-visible{outline:2px solid var(--egc-color,#0D9488);outline-offset:2px}.celebration-backdrop{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#0f172a8c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease}.celebration-backdrop.is-visible{opacity:1}.celebration-card{background:#fff;border-radius:28px;box-shadow:0 32px 80px #00000047,0 8px 24px #00000024;padding:40px 48px 36px;width:min(360px,calc(100vw - 48px));text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;transform:scale(.7) translateY(30px);transition:opacity .4s cubic-bezier(.34,1.56,.64,1),transform .4s cubic-bezier(.34,1.56,.64,1);will-change:opacity,transform}.celebration-backdrop.is-visible .celebration-card{opacity:1;transform:scale(1) translateY(0)}.celebration-trophy{font-size:56px;line-height:1;display:block;opacity:0;transform:scale(0) rotate(-10deg);transition:opacity .6s .2s cubic-bezier(.34,1.56,.64,1),transform .6s .2s cubic-bezier(.34,1.56,.64,1);will-change:opacity,transform}.celebration-backdrop.is-visible .celebration-trophy{opacity:1;transform:scale(1) rotate(0)}.celebration-heading{font-size:24px;font-weight:900;color:#1e293b;margin:0;letter-spacing:-.5px}.celebration-activity{font-size:14px;font-weight:600;color:#64748b;margin:0}.celebration-stars{display:flex;gap:6px;margin:6px 0 2px}.celebration-star{font-size:28px;line-height:1;display:inline-block;opacity:0;transform:scale(0);transition:opacity .3s cubic-bezier(.34,1.56,.64,1),transform .3s cubic-bezier(.34,1.56,.64,1);will-change:opacity,transform}.celebration-star--visible{opacity:1;transform:scale(1)}.celebration-sub{font-size:13px;color:#94a3b8;font-weight:500;margin:0}.celebration-dismiss{margin-top:16px;padding:8px 24px;border:2px solid var(--teal, #0D9488);border-radius:var(--radius-pill, 9999px);background:transparent;color:var(--teal, #0D9488);font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;transition:background .12s ease,color .12s ease}.celebration-dismiss:hover{background:var(--teal, #0D9488);color:#fff}.celebration-dismiss:focus-visible{outline:2px solid var(--teal, #0D9488);outline-offset:2px}.wcm-toggle-btn:focus-visible{outline:2px solid #74C69D;outline-offset:3px}.clm__backdrop{position:fixed;inset:0;background:#00000059;z-index:9000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:clm-fade-in .18s ease;display:flex;align-items:stretch;justify-content:flex-end}@keyframes clm-fade-in{0%{opacity:0}to{opacity:1}}.clm__panel{background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:-4px 0 32px #0000002e;width:340px;max-width:calc(100vw - 48px);height:100%;display:flex;flex-direction:column;overflow:hidden;animation:clm-slide-in .24s cubic-bezier(.22,1,.36,1)}@keyframes clm-slide-in{0%{transform:translate(100%);opacity:.6}to{transform:translate(0);opacity:1}}.clm__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);gap:12px;flex-shrink:0}.clm__header-left{display:flex;align-items:center;gap:14px}.clm__header-icon{width:40px;height:40px;border-radius:12px;background:#ffffff1f;color:var(--brand-text);display:flex;align-items:center;justify-content:center;flex-shrink:0}.clm__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0 0 2px;line-height:1.3}.clm__subtitle{font-size:12.5px;color:var(--brand-text-sub);margin:0;line-height:1.4}.clm__close-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--brand-text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .14s,color .14s;flex-shrink:0}.clm__close-btn:hover{background:#ffffff1f;color:var(--brand-text)}.clm__body{flex:1;padding:16px;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.clm__option{display:flex;align-items:center;gap:14px;padding:16px;border-radius:14px;border:1.5px solid var(--border);background:var(--modal-surface2);cursor:pointer;text-align:left;width:100%;transition:background .13s,border-color .13s,transform .1s}.clm__option:active{transform:scale(.98)}.clm__option-icon{font-size:26px;line-height:1;flex-shrink:0;width:36px;text-align:center}.clm__option-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.clm__option-label{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;display:block}.clm__option-hint{font-size:12px;color:var(--text-muted);line-height:1.45;display:block}.clm__option-arrow{flex-shrink:0;color:var(--text-muted);opacity:.5;transition:opacity .13s,transform .13s}.clm__option--drawings:hover{background:var(--modal-surface2);border-color:var(--teal)}.clm__option--drawings:hover .clm__option-label{color:var(--teal)}.clm__option--drawings:hover .clm__option-arrow{opacity:1;color:var(--teal);transform:translate(2px)}.clm__option--all:hover{background:var(--modal-surface2);border-color:var(--rose, #F87171)}.clm__option--all:hover .clm__option-label{color:var(--rose, #DC2626)}.clm__option--all:hover .clm__option-arrow{opacity:1;color:var(--rose, #DC2626);transform:translate(2px)}.clm__footer{padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0;display:flex;justify-content:flex-end}.clm__cancel-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;padding:8px 20px;border-radius:9px;transition:background .13s,color .13s}.clm__cancel-btn:hover{background:var(--modal-surface2);color:var(--text)}@media(max-width:767px){.clm__backdrop{align-items:flex-end;justify-content:stretch}.clm__panel{width:100%;max-width:100%;height:auto;max-height:80vh;border-left:none;border-top:1px solid var(--border);border-radius:20px 20px 0 0;animation:clm-slide-up .24s cubic-bezier(.22,1,.36,1)}@keyframes clm-slide-up{0%{transform:translateY(100%);opacity:.6}to{transform:translateY(0);opacity:1}}}.icon-rail{width:var(--rail-w);flex-shrink:0;height:100%;background:var(--brand-bg);border-right:1px solid var(--brand-border);display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:2px;z-index:90;overflow:hidden;transition:background .2s ease-in-out,border-color .2s ease-in-out}.rail__icon{position:relative;width:66px;min-height:54px;border-radius:12px;border:none;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex-shrink:0;padding:6px 4px 5px;transition:background .12s ease-out,transform .1s ease-out}.rail__icon:before{content:"";position:absolute;inset:0;border-radius:12px;background:var(--brand-accent);opacity:0;pointer-events:none;transition:opacity 80ms ease}.rail__icon--active:before{opacity:.18}.rail__svg-icon{display:flex;align-items:center;justify-content:center;color:var(--brand-text-muted);transition:transform 80ms ease,color 80ms ease;line-height:1}.rail__icon:hover .rail__svg-icon{color:var(--brand-text)}.rail__icon--active .rail__svg-icon{color:var(--brand-active-text)}.rail__label{font-family:var(--font-body);font-size:9.5px;font-weight:700;color:var(--brand-text-muted);letter-spacing:.02em;line-height:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60px;pointer-events:none;transition:color 80ms ease}.rail__icon:hover{background:var(--brand-hover)}.rail__icon:hover .rail__label{color:var(--brand-text-sub)}.rail__icon--active .rail__label{color:var(--brand-active-text);font-weight:800}.rail__icon--active:hover{background:var(--brand-active);transform:scale(1.03)}.rail__dot{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--brand-accent);display:block;pointer-events:none;opacity:0;transition:opacity 80ms ease}.rail__icon--active .rail__dot{opacity:1}.rail__tooltip{display:none}.rail__spacer{flex:1}.rail__separator{width:40px;height:1px;background:var(--brand-border);margin:5px 0;flex-shrink:0}@media(max-width:1023px){.rail__icon{width:52px;min-height:48px;padding:5px 4px;border-radius:10px}.rail__svg-icon svg{width:18px;height:18px}.rail__label{font-size:11px;max-width:48px}.rail__separator{width:32px}}.rail__perspective{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 5px;width:100%}.rail__persp-btn{width:58px;padding:4px 4px 3px;border:1.5px solid transparent;border-radius:9px;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;transition:background .1s,border-color .1s,transform 80ms}.rail__persp-btn:hover{background:var(--brand-hover);border-color:var(--brand-border);transform:scale(1.04)}.rail__persp-btn.is-active{background:var(--brand-active);border-color:var(--brand-accent)}.rail__persp-icon{font-size:16px;line-height:1}.rail__persp-label{font-family:var(--font-body);font-size:8.5px;font-weight:700;color:var(--brand-text-muted);letter-spacing:.02em;line-height:1;white-space:nowrap;pointer-events:none;transition:color 80ms}.rail__persp-btn:hover .rail__persp-label,.rail__persp-btn.is-active .rail__persp-label{color:var(--brand-active-text)}@media(max-width:767px){.icon-rail{display:none}}.demo-chip{position:fixed;bottom:calc(var(--toolbar-h) + 16px);left:calc(var(--rail-w) + 16px);z-index:9999;display:flex;align-items:center;gap:4px;background:#1e1b4b;border:1.5px solid #4338CA;border-radius:var(--radius-pill);padding:5px 6px 5px 10px;box-shadow:0 4px 20px #00000059;-webkit-user-select:none;user-select:none}.demo-chip__label{font-family:var(--font);font-size:9px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;color:#818cf8;padding-right:6px;border-right:1px solid #4338CA;margin-right:2px;flex-shrink:0}.demo-chip__btn{font-family:var(--font);font-size:11px;font-weight:700;color:#a5b4fc;background:transparent;border:none;border-radius:var(--radius-pill);padding:4px 10px;cursor:pointer;transition:background .12s ease,color .12s ease;white-space:nowrap}.demo-chip__btn:hover{background:#6366f133;color:#e0e7ff}.demo-chip__btn--active{background:#4338ca;color:#fff}.demo-chip__btn--active:hover{background:#4f46e5;color:#fff}[data-toolbar-pill] .demo-chip{bottom:20px}@media(min-width:768px){[data-toolbar-fab] .demo-chip{bottom:24px}}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;font-family:var(--font-ui, Arial, sans-serif);font-size:14px;line-height:1.4;pointer-events:auto;box-shadow:0 4px 12px #00000026;animation:toast-in .2s ease}.toast--success{background:var(--teal, #0D9488);color:#fff}.toast--error{background:#e74c3c;color:#fff}.toast--info{background:var(--surface2, #E2E8F0);color:var(--text-base, #1B2631)}.toast__message{flex:1}.toast__dismiss{background:transparent;border:none;color:inherit;opacity:.7;cursor:pointer;font-size:13px;padding:0 2px;line-height:1;transition:opacity .15s}.toast__dismiss:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-tab-bar{display:flex;align-items:flex-end;height:34px;flex-shrink:0;position:relative;z-index:95;overflow:visible;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);padding:0 8px 0 var(--rail-w);gap:0}[data-fullscreen] .page-tab-bar,[data-perspective=student] .page-tab-bar{display:none}.page-tab-bar__track{position:relative;display:flex;align-items:flex-end;flex:1;min-width:0;height:100%;overflow-x:auto;overflow-y:visible;gap:2px;padding:0;scrollbar-width:none}.page-tab-bar__track::-webkit-scrollbar{display:none}.page-tab-bar__indicator{display:none}.page-tab{position:relative;display:flex;align-items:center;gap:4px;padding:0 8px 0 7px;height:26px;min-width:72px;max-width:148px;flex-shrink:0;cursor:pointer;-webkit-user-select:none;user-select:none;overflow:visible;z-index:1;border-radius:6px 6px 0 0;border-top:1px solid var(--brand-border);border-left:1px solid var(--brand-border);border-right:1px solid var(--brand-border);border-bottom:none;background:#ffffff0a;color:var(--brand-text-muted);font-size:11px;font-weight:500;letter-spacing:.01em;transition:color .16s ease,background .16s ease,height .16s ease}.page-tab:hover{color:var(--brand-text-sub);background:#ffffff14;height:28px}.page-tab.is-active{height:30px;color:var(--text);font-weight:600;background:var(--wb-bg);border-color:var(--brand-border);margin-bottom:-1px;z-index:3}.page-tab.is-drag-over:after{content:"";position:absolute;inset:0;border-radius:6px 6px 0 0;border:2px solid var(--blue, #2563EB);pointer-events:none}.page-tab__stripe{flex-shrink:0;width:3px;height:14px;border-radius:2px;opacity:.5;transition:opacity .16s ease,transform .16s ease}.page-tab:hover .page-tab__stripe{opacity:.7}.page-tab.is-active .page-tab__stripe{opacity:1;transform:scaleY(1.1)}.page-tab__num{flex-shrink:0;font-size:9px;font-weight:700;line-height:1;letter-spacing:.05em;color:var(--text-muted);opacity:.55;min-width:10px;text-align:center;transition:opacity .16s ease}.page-tab.is-active .page-tab__num{opacity:.85;color:var(--brand-accent)}.page-tab__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;line-height:1}.page-tab__rename-input{flex:1;min-width:56px;max-width:110px;height:22px;padding:0 5px;font-size:12px;font-family:inherit;font-weight:600;border:1.5px solid var(--blue, #2563EB);border-radius:6px;background:var(--modal-bg);color:var(--text);outline:none;box-shadow:0 0 0 3px #2563eb1f}.page-tab__color-btn{flex-shrink:0;width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(0,0,0,.1);padding:0;cursor:pointer;opacity:0;transition:opacity .16s ease,transform .16s ease,box-shadow .16s ease}.page-tab:hover .page-tab__color-btn,.page-tab.is-active .page-tab__color-btn{opacity:.75}.page-tab__color-btn:hover{opacity:1!important;transform:scale(1.25);box-shadow:0 0 0 2.5px var(--blue, #2563EB)}.page-tab__delete{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;border:none;background:transparent;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .12s ease,background .12s ease,color .12s ease,transform .12s ease}.page-tab:hover .page-tab__delete,.page-tab.is-active .page-tab__delete{opacity:.45}.page-tab__delete:hover{opacity:1!important;background:#e11d481f;color:var(--rose, #E11D48);transform:scale(1.1)}.page-tab__color-picker{position:absolute;top:calc(100% + 8px);left:0;z-index:300;width:172px;padding:12px;background:var(--modal-bg);border:1.5px solid var(--border2);border-radius:12px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:10px;animation:ptb-pop .16s cubic-bezier(.34,1.4,.64,1) both}@keyframes ptb-pop{0%{opacity:0;transform:scale(.88) translateY(-6px)}to{opacity:1;transform:scale(1) translateY(0)}}.page-tab__picker-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0}.page-tab__picker-swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.page-tab__picker-swatch{width:100%;aspect-ratio:1;border-radius:8px;cursor:pointer;padding:0;outline:2px solid transparent;outline-offset:2px;transition:transform .1s ease,outline-color .1s ease,box-shadow .1s ease;color:var(--text-muted)}.page-tab__picker-swatch:hover{transform:scale(1.12);outline-color:#80808080;box-shadow:0 2px 6px #00000026}.page-tab__picker-swatch.is-active{outline-color:var(--blue, #2563EB);outline-width:2px;transform:scale(1.08)}.page-tab__picker-custom{position:relative;display:flex;align-items:center;gap:8px;cursor:pointer;padding-top:8px;border-top:1px solid var(--border2)}.page-tab__picker-custom input[type=color]{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0}.page-tab__custom-swatch{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border2);flex-shrink:0;box-shadow:inset 0 0 0 1px #0000000f}.page-tab__custom-label{font-size:12px;color:var(--text-sub)}.page-tab-bar__divider{width:1px;height:20px;flex-shrink:0;background:var(--brand-border);opacity:.6}.page-tab-bar__add{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1px solid var(--brand-border);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-bottom:5px;transition:background .16s ease,color .16s ease,border-color .16s ease,transform .2s cubic-bezier(.34,1.6,.64,1),box-shadow .16s ease}.page-tab-bar__add:hover{background:var(--wb-bg);color:var(--brand-accent);border-color:var(--brand-accent);transform:scale(1.1) rotate(90deg);box-shadow:0 2px 10px #0000001a}.page-tab-bar__add:active{transform:scale(.95) rotate(90deg)}.bottom-tab-bar{position:fixed;bottom:0;left:0;right:0;height:68px;z-index:90;display:none;align-items:stretch;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--brand-bg);border-top:1px solid var(--brand-border);box-shadow:0 -2px 10px #0000002e;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.bottom-tab-bar::-webkit-scrollbar{display:none}@media(max-width:767px){.bottom-tab-bar{display:flex}}.bottom-tab{position:relative;flex:0 0 auto;min-width:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:transparent;color:var(--brand-text-muted);cursor:pointer;padding:6px 6px 5px;font-family:var(--font-body);font-size:9.5px;font-weight:700;letter-spacing:.02em;transition:background .12s ease-out,color .12s ease-out;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.bottom-tab:hover{background:var(--brand-hover);color:var(--brand-text-sub)}.bottom-tab--active{background:var(--brand-active);color:var(--brand-active-text)}.bottom-tab--active:hover{background:var(--brand-active)}.bottom-tab--active:before{content:"";position:absolute;top:0;left:20%;right:20%;height:3px;border-radius:0 0 3px 3px;background:var(--brand-accent)}.bottom-tab__icon-wrap{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;border:1.5px solid transparent;background:transparent;color:var(--brand-text-muted);transition:border-color .12s ease,background .12s ease,color .12s ease,transform .1s ease}.bottom-tab:hover .bottom-tab__icon-wrap{color:var(--brand-text);background:var(--brand-hover);transform:translateY(-1px)}.bottom-tab--active .bottom-tab__icon-wrap{color:var(--brand-active-text);border-color:var(--brand-border);background:#7c3aed2e;transform:scale(1.08)}.bottom-tab__icon-wrap svg{width:18px;height:18px;flex-shrink:0}.bottom-tab__label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:inherit;transition:color 80ms ease}.bottom-tab--active .bottom-tab__label{font-weight:800}.mobile-banner{display:none;width:100%;flex-shrink:0;align-items:center;justify-content:center;gap:10px;padding:10px 16px;background:#fef3c7;border-bottom:1px solid #FCD34D;color:#92400e;font-family:var(--font-body);font-size:13px;font-weight:600;line-height:1.4;z-index:110}@media(max-width:599px){.mobile-banner{display:flex}}[data-theme=dark] .mobile-banner{background:#451a03;border-color:#78350f;color:#fde68a}[data-theme=high-contrast] .mobile-banner{background:#000;border-color:#f59e0b;color:#f59e0b}.mobile-banner__text{flex:1;text-align:center}.mobile-banner__close{flex-shrink:0;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:inherit;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:background .12s ease,opacity .12s ease;line-height:1}.mobile-banner__close:hover{background:#00000014;opacity:1}[data-theme=dark] .mobile-banner__close:hover{background:#ffffff1a}.mobile-banner__close:focus-visible{outline:2px solid currentColor;outline-offset:2px;opacity:1}.profile-panel-backdrop{position:fixed;inset:0;z-index:399;background:#00000040;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.profile-panel{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:100vw;z-index:400;display:flex;flex-direction:column;background:var(--surface, #ffffff);border-left:1px solid var(--border, #e2e8f0);box-shadow:-8px 0 40px #0000002e;overflow:hidden;animation:profileSlideIn .22s cubic-bezier(.4,0,.2,1) both}@keyframes profileSlideIn{0%{transform:translate(100%);opacity:.6}to{transform:translate(0);opacity:1}}.profile-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border, #e2e8f0);flex-shrink:0;background:var(--surface, #ffffff)}.profile-panel__header-left{display:flex;align-items:center;gap:10px}.profile-panel__header-icon{width:32px;height:32px;border-radius:8px;background:var(--p100, #ede9fe);display:flex;align-items:center;justify-content:center;font-size:16px}.profile-panel__title{margin:0;font-size:14px;font-weight:800;color:var(--text, #1a1040);font-family:var(--font, inherit)}.profile-panel__subtitle{margin:0;font-size:11px;color:var(--muted, #6b63a8)}.profile-panel__close{width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--muted, #6b63a8);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;font-family:inherit}.profile-panel__close:hover{background:var(--border, #e2e8f0);color:var(--text, #1a1040)}.profile-panel__body{flex:1;overflow-y:auto;padding:8px 0;display:flex;flex-direction:column}.profile-panel__body::-webkit-scrollbar{width:4px}.profile-panel__body::-webkit-scrollbar-thumb{background:var(--border, #e2e8f0);border-radius:4px}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;gap:14px;padding:18px;background:var(--bg, #f5f3ff);border-radius:12px;border:1px solid var(--border, #e2e8f0)}.profile-avatar-display{width:72px;height:72px;border-radius:50%;background:var(--p500, #4a2dc4);display:flex;align-items:center;justify-content:center;font-size:36px;line-height:1;border:3px solid var(--p300, #9b82f0);box-shadow:0 4px 16px #4a2dc440;cursor:pointer;transition:transform .15s,box-shadow .15s;-webkit-user-select:none;user-select:none}.profile-avatar-display:hover{transform:scale(1.06);box-shadow:0 6px 20px #4a2dc459}.profile-avatar-display--initials{font-size:24px;font-weight:800;color:#fff;font-family:var(--font, inherit)}.profile-avatar-label{font-size:11px;color:var(--muted, #6b63a8);font-weight:600}.profile-avatar-picker{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;width:100%}.profile-avatar-option{width:100%;aspect-ratio:1;border-radius:50%;border:2px solid transparent;background:var(--surface, #fff);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;transition:transform .12s,border-color .12s,box-shadow .12s;padding:0;line-height:1}.profile-avatar-option:hover{transform:scale(1.12);box-shadow:0 2px 8px #00000026}.profile-avatar-option--active{border-color:var(--p500, #4a2dc4);box-shadow:0 0 0 3px var(--p100, #ede9fe)}.profile-section{display:flex;flex-direction:column;gap:12px}.profile-section__title{font-size:11px;font-weight:700;color:var(--muted, #6b63a8);text-transform:uppercase;letter-spacing:.8px;margin:0}.profile-field{display:flex;flex-direction:column;gap:5px}.profile-field__label{font-size:11px;font-weight:700;color:var(--muted, #6b63a8)}.profile-field__input{padding:9px 12px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--surface, #fff);color:var(--text, #1a1040);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.profile-field__input:focus{border-color:var(--p400, #6b50da);box-shadow:0 0 0 3px var(--p100, #ede9fe)}.profile-field__input:disabled{background:var(--bg, #f5f3ff);color:var(--muted, #6b63a8);cursor:not-allowed}.profile-field__hint{font-size:10px;color:var(--muted, #6b63a8);margin:0}.profile-plan-card{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:10px;background:var(--bg, #f5f3ff);border:1px solid var(--border, #e2e8f0)}.profile-plan-card__left{display:flex;flex-direction:column;gap:3px}.profile-plan-card__name{font-size:13px;font-weight:800;color:var(--text, #1a1040)}.profile-plan-card__status{font-size:11px;color:var(--muted, #6b63a8)}.profile-plan-badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}.profile-plan-badge--active{background:#dcfce7;color:#166534}.profile-plan-badge--pending{background:#fef9c3;color:#854d0e}.profile-plan-badge--cancelled{background:#fee2e2;color:#991b1b}.profile-plan-badge--past_due{background:#ffedd5;color:#9a3412}.profile-pw-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:8px;border:1px solid var(--border, #e2e8f0);background:var(--surface, #fff);cursor:pointer;font-size:13px;font-weight:600;color:var(--text, #1a1040);font-family:inherit;transition:background .12s;width:100%;box-sizing:border-box}.profile-pw-toggle:hover{background:var(--bg, #f5f3ff)}.profile-pw-form{display:flex;flex-direction:column;gap:10px}.profile-btn{padding:9px 16px;border-radius:8px;border:none;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .15s,background .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}.profile-btn:disabled{opacity:.6;cursor:not-allowed}.profile-btn--primary{background:var(--p500, #4a2dc4);color:#fff}.profile-btn--primary:hover:not(:disabled){opacity:.88}.profile-btn--outline{background:transparent;border:1.5px solid var(--border, #e2e8f0);color:var(--muted, #6b63a8)}.profile-btn--outline:hover:not(:disabled){border-color:var(--p400, #6b50da);color:var(--p500, #4a2dc4)}.profile-btn--danger{background:transparent;border:1.5px solid #fecaca;color:#dc2626}.profile-btn--danger:hover:not(:disabled){background:#fef2f2}.profile-btn--full{width:100%}.profile-msg{padding:8px 12px;border-radius:8px;font-size:12px;font-weight:600}.profile-msg--success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.profile-msg--error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.profile-panel__footer{padding:14px 18px;border-top:1px solid var(--border, #e2e8f0);flex-shrink:0}@media(max-width:480px){.profile-panel{width:100vw}}.profile-panel__header{background:var(--brand-bg);border-bottom:1px solid var(--brand-border)}.profile-panel__header-icon{background:var(--brand-hover);color:var(--brand-text)}.profile-panel__title{color:var(--brand-text)}.profile-panel__subtitle,.profile-panel__close{color:var(--brand-text-sub)}.profile-panel__close:hover{background:#ffffff1f;color:var(--brand-text)}.profile-panel__body{min-height:0!important;overflow-y:auto!important;display:flex!important;flex-direction:column!important;gap:0!important;padding:8px 0 12px!important}.profile-panel .settings-panel__controls{margin:0 18px 10px!important;display:flex!important;align-items:center!important;border:1px solid var(--border, #e2e8f0)!important;background:var(--bg, #f5f3ff)!important}.profile-panel .settings-ctrl-btn{flex:1 1 0!important}.profile-panel .settings-ctrl-divider{width:1px!important;align-self:stretch!important;background:var(--border, #e2e8f0)!important}.profile-panel .settings-section{display:block!important;position:relative!important;width:auto!important;margin:0 18px 12px!important;padding:0!important;border:1px solid var(--border, #e2e8f0)!important;border-radius:12px!important;background:var(--surface, #fff)!important;overflow:hidden!important;box-shadow:none!important;height:auto!important;min-height:0!important;max-height:none!important;flex:none!important}.profile-panel .settings-section__header{width:100%!important;box-sizing:border-box!important;display:grid!important;grid-template-columns:auto minmax(0,1fr) auto auto!important;align-items:center!important;gap:8px!important;margin:0!important;padding:12px 14px!important;border:0!important;border-bottom:1px solid transparent!important;background:var(--bg, #f5f3ff)!important;color:var(--text, #1a1040)!important;text-align:left!important;font:inherit!important;cursor:pointer!important;min-height:46px!important;line-height:1.2!important;position:relative!important;z-index:1!important}.profile-panel .settings-section--open .settings-section__header{border-bottom-color:var(--border, #e2e8f0)!important}.profile-panel .settings-section__title{margin:0!important;min-width:0!important;font-size:11px!important;font-weight:700!important;color:var(--text-muted, #6b63a8)!important;text-transform:uppercase!important;letter-spacing:.8px!important}.profile-panel .settings-section__summary{min-width:0!important;max-width:120px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;justify-self:end!important;font-size:11px!important;color:var(--text-muted, #6b63a8)!important}.profile-panel .settings-section__chevron{justify-self:end!important;font-size:11px!important;color:var(--text-muted, #6b63a8)!important}.profile-panel .settings-section__body{display:block!important;position:relative!important;width:100%!important;box-sizing:border-box!important;padding:14px!important;margin:0!important;border:0!important;background:var(--surface, #fff)!important;overflow:visible!important;height:auto!important;min-height:0!important;max-height:none!important;flex:none!important;contain:none!important;transform:none!important}.profile-panel .settings-section__body>*{position:relative!important;max-width:100%!important}.profile-panel .profile-field,.profile-panel .profile-pw-form,.profile-panel .profile-avatar-section,.profile-panel .profile-avatar-picker,.profile-panel .profile-plan-card{min-height:0!important;max-height:none!important;overflow:visible!important}.profile-panel .profile-field__input,.profile-panel .profile-pw-toggle,.profile-panel .profile-plan-card,.profile-panel .profile-btn--full{width:100%!important;box-sizing:border-box!important}.fsp-backdrop{position:fixed;inset:0;z-index:200;background:#0f172a73;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .18s ease-in-out}.fsp-backdrop.is-open{opacity:1;pointer-events:all}.fsp{position:fixed;inset:0;z-index:201;margin:auto;top:var(--topbar-h, 56px);left:var(--rail-w, 72px);right:0;bottom:0;display:flex;flex-direction:column;overflow:hidden;background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:var(--shadow-lg);opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .18s ease-in-out,transform .18s ease-in-out;will-change:opacity,transform}.fsp.is-open{opacity:1;transform:translateY(0);pointer-events:all}.fsp__header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;flex-shrink:0;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);gap:12px}.fsp__header-left{display:flex;align-items:center;gap:10px;min-width:0}.fsp__icon{font-size:22px;line-height:1;flex-shrink:0}.fsp__title{font-size:18px;font-weight:800;color:var(--brand-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fsp__badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;border-radius:var(--radius-pill);background:#ffffff1f;color:var(--brand-text-sub);font-size:13px;font-weight:700;white-space:nowrap;flex-shrink:0}.fsp__close{width:36px;height:36px;border:none;border-radius:50%;background:#ffffff14;color:var(--brand-text-sub);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s ease,color .12s ease,transform .1s ease}.fsp__close:hover{background:#ffffff2e;color:var(--brand-text);transform:scale(1.08)}.fsp__body{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;min-height:0;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.fsp__body::-webkit-scrollbar{width:6px}.fsp__body::-webkit-scrollbar-track{background:transparent}.fsp__body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}@media(max-width:767px){.fsp{left:0;bottom:56px}}.dice-roller{position:fixed;right:20px;bottom:72px;width:240px;border-radius:16px;background:var(--modal-bg);border:1.5px solid var(--border2);box-shadow:var(--shadow-lg);z-index:61;-webkit-user-select:none;user-select:none;overflow:hidden}.dice-roller__header{display:flex;align-items:center;justify-content:space-between;padding:11px 10px 8px 14px;cursor:grab;border-bottom:1px solid var(--border2)}.dice-roller__header:active{cursor:grabbing}.dice-roller__title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;font-family:var(--font-body);color:var(--purple);text-transform:uppercase;letter-spacing:.07em}.dice-roller__title svg{flex-shrink:0;color:var(--purple)}.dice-roller__close-btn{width:28px;height:28px;border-radius:7px;border:1.5px solid transparent;background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;-webkit-tap-highlight-color:transparent;padding:0}.dice-roller__close-btn:hover{background:var(--rose);color:#fff;border-color:var(--rose)}.dice-roller__count-row{display:flex;flex-direction:column;align-items:flex-start;gap:7px;padding:12px 14px 8px}.dice-roller__count-label{font-size:11px;font-weight:700;color:var(--text-muted);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.06em}.dice-roller__count-btns{display:flex;gap:4px;width:100%}.dice-roller__count-btn{flex:1;height:34px;min-width:0;border-radius:8px;border:1.5px solid var(--border2);background:var(--modal-surface2);color:var(--text-sub);font-size:13px;font-weight:700;font-family:var(--font-body);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;-webkit-tap-highlight-color:transparent;padding:0}.dice-roller__count-btn:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-l)}.dice-roller__count-btn.is-active{background:var(--purple);border-color:var(--purple);color:#fff;box-shadow:0 2px 6px #7c3aed4d}.dice-roller__grid{display:grid;gap:8px;padding:8px 14px;justify-items:center;align-items:center;min-height:88px}.dice-roller__grid[data-count="1"]{grid-template-columns:68px;justify-content:center}.dice-roller__grid[data-count="2"]{grid-template-columns:repeat(2,68px);justify-content:center}.dice-roller__grid[data-count="3"]{grid-template-columns:repeat(3,60px);justify-content:center}.dice-roller__grid[data-count="4"]{grid-template-columns:repeat(2,68px);justify-content:center}.dice-roller__grid[data-count="5"],.dice-roller__grid[data-count="6"]{grid-template-columns:repeat(3,60px);justify-content:center}.dice-roller__die{width:100%;aspect-ratio:1;max-width:68px;border-radius:var(--radius-sm);border:2px solid var(--border2);background:var(--modal-surface2);color:var(--purple);padding:7px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;transition:all .1s;box-shadow:0 1px 4px #00000012,inset 0 1px #ffffff80}.dice-roller__die.is-rolling{border-color:var(--purple);background:var(--purple-l);animation:die-tumble .1s ease-in-out infinite alternate}@keyframes die-tumble{0%{transform:rotate(-10deg) scale(.94)}to{transform:rotate(10deg) scale(1.06)}}.dice-roller__total{display:flex;align-items:center;justify-content:center;gap:10px;min-height:40px;padding:6px 14px 4px;opacity:0;transform:translateY(5px);transition:opacity .2s,transform .2s;pointer-events:none}.dice-roller__total.is-visible{opacity:1;transform:translateY(0)}.dice-roller__total-label{font-size:11px;font-weight:700;color:var(--text-muted);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.07em}.dice-roller__total-value{font-size:26px;font-weight:800;font-family:var(--font-body);color:var(--purple);line-height:1;letter-spacing:-.02em}.dice-roller__total-breakdown{font-size:11px;color:var(--text-muted);font-family:var(--font-body);letter-spacing:.02em}.dice-roller__footer{padding:6px 12px 12px}.dice-roller__roll-btn{width:100%;height:44px;border-radius:10px;border:none;background:var(--purple);color:#fff;font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;box-shadow:0 3px 10px #7c3aed59;transition:all .12s;-webkit-tap-highlight-color:transparent;letter-spacing:.02em}.dice-roller__roll-btn:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 14px #7c3aed73;transform:translateY(-1px)}.dice-roller__roll-btn:active:not(:disabled){transform:scale(.97) translateY(0);box-shadow:0 2px 6px #7c3aed4d}.dice-roller__roll-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dice-roller__roll-spin{display:inline-block;animation:spin .35s linear infinite}@media(max-width:480px){.dice-roller{width:210px;right:8px;bottom:68px}}.acm-backdrop{position:fixed;inset:0;z-index:300;background:#0f172a8c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:acm-backdrop-in .18s ease-out both}@media(prefers-reduced-motion:no-preference){@keyframes acm-backdrop-in{0%{opacity:0}to{opacity:1}}}.acm{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:301;width:min(480px,calc(100vw - 32px));max-height:calc(100vh - 48px);overflow-y:auto;background:var(--modal-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:acm-slide-in .22s cubic-bezier(.34,1.2,.64,1) both}@media(prefers-reduced-motion:no-preference){@keyframes acm-slide-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 18px)) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}}.acm__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0}.acm__header-left{display:flex;align-items:center;gap:8px}.acm__header-icon{font-size:20px;line-height:1}.acm__title{font-size:17px;font-weight:700;color:var(--brand-text);margin:0}.acm__close{width:32px;height:32px;border:none;background:#ffffff14;border-radius:50%;cursor:pointer;font-size:14px;color:var(--brand-text-sub);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s ease,color .12s ease}.acm__close:hover{background:#ffffff2e;color:var(--brand-text)}.acm__mode-tabs{display:flex;gap:4px;padding:12px 20px 0;border-bottom:1px solid var(--border);flex-shrink:0}.acm__mode-tab{padding:8px 18px;border:none;background:transparent;border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:13px;font-weight:600;color:var(--text-sub);cursor:pointer;position:relative;transition:color .12s ease,background .12s ease}.acm__mode-tab:disabled{opacity:.4;cursor:not-allowed}.acm__mode-tab.is-active{color:var(--teal);background:var(--teal-xl)}.acm__mode-tab.is-active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--teal);border-radius:2px 2px 0 0}.acm__form{padding:20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;flex:1}.acm__field{display:flex;flex-direction:column;gap:6px}.acm__label{font-size:13px;font-weight:600;color:var(--text-mid)}.acm__required{color:var(--rose);margin-left:2px}.acm__error{font-size:12px;color:var(--rose);margin:0}.acm__error:before{content:"⚠ "}.acm__input{height:48px;padding:0 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .14s ease,box-shadow .14s ease;outline:none}.acm__input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0d94881f}.acm__input.is-error{border-color:var(--rose)}.acm__input.is-error:focus{box-shadow:0 0 0 3px #e11d481f}.acm__input::placeholder{color:var(--text-muted)}.acm__input--custom-topic{margin-top:6px}.acm__select-wrap{position:relative}.acm__select-wrap:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--text-sub);font-size:13px;pointer-events:none}.acm__select{width:100%;height:48px;padding:0 36px 0 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;appearance:none;-webkit-appearance:none;cursor:pointer;transition:border-color .14s ease,box-shadow .14s ease;outline:none}.acm__select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0d94881f}.acm__select.is-error{border-color:var(--rose)}.acm__select.is-error:focus{box-shadow:0 0 0 3px #e11d481f}.acm__select:disabled{opacity:.5;cursor:not-allowed}.acm__emoji-preview-wrap{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--subject-bg, var(--modal-surface2));border-radius:var(--radius-sm);border:1.5px solid var(--border);transition:background .2s ease}.acm__emoji-preview-big{font-size:32px;line-height:1;flex-shrink:0}.acm__colour-swatch{display:flex;align-items:center;gap:7px}.acm__colour-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:1.5px solid rgba(0,0,0,.08);transition:background .2s ease}.acm__colour-label{font-size:12px;color:var(--text-sub);font-style:italic}.acm__emoji-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:4px}.acm__emoji-btn{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:18px;border:1.5px solid transparent;border-radius:var(--radius-sm);background:var(--modal-surface2);cursor:pointer;transition:background .1s ease,border-color .1s ease,transform .1s ease;line-height:1}.acm__emoji-btn:hover{background:var(--border);transform:scale(1.15)}.acm__emoji-btn.is-selected{background:var(--subject-bg, rgba(13,148,136,.12));border-color:var(--subject-color, var(--teal));transform:scale(1.1)}.acm__footer{display:flex;gap:10px;justify-content:flex-end;padding-top:4px;flex-shrink:0}.acm__btn-cancel{height:44px;padding:0 20px;border:1.5px solid var(--border2);border-radius:var(--radius-sm);background:transparent;color:var(--text-sub);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.acm__btn-cancel:hover{border-color:var(--text-sub);color:var(--text);background:var(--modal-surface2)}.acm__btn-save{height:44px;padding:0 24px;border:none;border-radius:var(--radius-sm);background:var(--teal);color:#fff;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 2px 8px #0d948859;transition:background .12s,box-shadow .12s,transform .1s}.acm__btn-save:hover:not(:disabled){background:var(--teal-d);box-shadow:0 4px 14px #0d948873;transform:translateY(-1px)}.acm__btn-save:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #0d94884d}.acm__btn-save.is-saved{background:var(--green);box-shadow:0 2px 8px #05966959;cursor:default;animation:acm-saved-pulse .3s ease-out}@media(prefers-reduced-motion:no-preference){@keyframes acm-saved-pulse{0%{transform:scale(1)}40%{transform:scale(1.06)}to{transform:scale(1)}}}.acm--bulk{width:min(760px,calc(100vw - 32px))}.acm__bulk{display:flex;flex-direction:column;gap:12px;padding:16px 20px 20px;flex:1;overflow:hidden;min-height:0}.acm__bulk-hint{font-size:12px;color:var(--text-muted);margin:0}.acm__bulk-table-wrap{overflow-y:auto;overflow-x:auto;flex:1;border:1px solid var(--border);border-radius:var(--radius-sm);min-height:0;max-height:340px}.acm__bulk-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.acm__bulk-table thead{position:sticky;top:0;z-index:1;background:var(--modal-surface2)}.acm__bulk-table th{padding:9px 10px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);border-bottom:1px solid var(--border);white-space:nowrap}.acm__bulk-table th:nth-child(1),.acm__bulk-table td:nth-child(1){width:30%}.acm__bulk-table th:nth-child(2),.acm__bulk-table td:nth-child(2){width:17%}.acm__bulk-table th:nth-child(3),.acm__bulk-table td:nth-child(3){width:20%}.acm__bulk-table th:nth-child(4),.acm__bulk-table td:nth-child(4){width:13%}.acm__bulk-table th:nth-child(5),.acm__bulk-table td:nth-child(5){width:13%}.acm__bulk-table th:nth-child(6),.acm__bulk-table td:nth-child(6){width:36px;min-width:36px}.acm__bulk-table td{padding:5px 6px;border-bottom:1px solid var(--border);vertical-align:top}.acm__bulk-table tbody tr:last-child td{border-bottom:none}.acm__bulk-table tbody tr.is-complete{background:#0596690a}.acm__bulk-table tbody tr.is-complete td:first-child{border-left:3px solid var(--green)}.acm__bulk-input,.acm__bulk-select{width:100%;height:36px;padding:0 8px;border:1.5px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:border-color .12s ease,box-shadow .12s ease;box-sizing:border-box}.acm__bulk-select{appearance:none;-webkit-appearance:none;padding-right:24px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2394A3B8'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer}.acm__bulk-input:focus,.acm__bulk-select:focus{border-color:var(--teal);box-shadow:0 0 0 2px #0d94881f}.acm__bulk-input.is-error,.acm__bulk-select.is-error{border-color:var(--rose)}.acm__bulk-select:disabled{opacity:.45;cursor:not-allowed}.acm__bulk-err{display:block;font-size:10px;color:var(--rose);margin-top:2px;line-height:1.2}.acm__bulk-remove{width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s;margin:4px auto 0}.acm__bulk-remove:hover:not(:disabled){background:#e11d481a;color:var(--rose)}.acm__bulk-remove:disabled{opacity:.3;cursor:not-allowed}.acm__bulk-add-row{align-self:flex-start;height:34px;padding:0 14px;border:1.5px dashed var(--border2);border-radius:8px;background:transparent;color:var(--text-sub);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.acm__bulk-add-row:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-xl)}.help-backdrop{position:fixed;inset:0;background:#0000;z-index:299;pointer-events:none;transition:background .28s ease}.help-backdrop--visible{background:#00000047;pointer-events:auto}.help-panel{position:fixed;top:0;right:0;bottom:0;width:min(520px,96vw);background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:-8px 0 48px #0000002e,-2px 0 12px #00000014;display:flex;flex-direction:column;z-index:300;overflow:hidden;transform:translate(100%);transition:transform .38s cubic-bezier(.16,1,.3,1);will-change:transform}.help-panel--open{transform:translate(0)}.help-panel__header{flex-shrink:0;padding:20px 20px 16px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border)}.help-panel__header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.help-panel__title-group{display:flex;align-items:center;gap:12px}.help-panel__orb{width:40px;height:40px;min-width:40px;border-radius:12px;background:linear-gradient(135deg,var(--teal) 0%,#2563EB 100%);display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;box-shadow:0 4px 16px #0d948859;animation:help-orb-pulse 3s ease-in-out infinite}@keyframes help-orb-pulse{0%,to{box-shadow:0 4px 16px #0d948859}50%{box-shadow:0 4px 24px #0d94888c,0 0 0 4px #0d94881f}}.help-panel__title{font-family:var(--font);font-size:18px;font-weight:900;color:var(--brand-text);line-height:1.1;letter-spacing:-.3px}.help-panel__subtitle{font-family:var(--font-body);font-size:12px;color:var(--brand-text-sub);margin-top:2px}.help-panel__close{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--modal-surface2);color:var(--text-sub);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease,transform .12s ease;flex-shrink:0}.help-panel__close:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:rotate(90deg)}.help-search-wrap{position:relative;margin-bottom:12px}.help-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:15px;pointer-events:none;line-height:1}.help-search{width:100%;box-sizing:border-box;height:44px;padding:0 36px 0 40px;border-radius:12px;border:1.5px solid rgba(255,255,255,.15);background:#ffffff14;color:var(--brand-text);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;appearance:none;-webkit-appearance:none}.help-search::placeholder{color:var(--text-muted)}.help-search::-webkit-search-cancel-button{display:none}.help-search:focus{border-color:var(--teal);background:#ffffff1f;box-shadow:0 0 0 3px #0d948826,0 2px 8px #0d94881a}.help-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;border:none;background:var(--border2);color:var(--text-sub);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease}.help-search-clear:hover{background:var(--teal);color:#fff}.help-chips{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:4px}.help-chip{height:28px;padding:0 12px;border-radius:var(--radius-pill);border:1.5px solid transparent;font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;background:#ffffff14;color:var(--brand-text-sub);border-color:#ffffff26;transition:background .12s ease,color .12s ease,border-color .12s ease,transform .12s ease,box-shadow .12s ease;white-space:nowrap}.help-chip:hover{border-color:var(--chip-color, var(--teal));color:var(--chip-color, var(--teal));transform:translateY(-1px)}.help-chip--all.help-chip--active{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 2px 8px #0d94884d}.help-chip--active:not(.help-chip--all){background:var(--chip-bg, #F0FDFA);color:var(--chip-color, var(--teal));border-color:var(--chip-color, var(--teal));box-shadow:0 2px 8px #00000014}.help-panel__body{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:14px 16px 24px;scroll-behavior:smooth}.help-panel__body::-webkit-scrollbar{width:4px}.help-panel__body::-webkit-scrollbar-track{background:transparent}.help-panel__body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.help-results-count{font-family:var(--font-body);font-size:12px;color:var(--text-muted);margin-bottom:10px;padding:0 4px}.help-results-count strong{color:var(--text-sub)}.help-articles{display:flex;flex-direction:column;gap:8px}.help-card{border-radius:14px;border:1.5px solid var(--border);background:var(--modal-bg);overflow:hidden;transition:border-color .16s ease,box-shadow .16s ease,transform .12s ease;border-left:3px solid var(--cat-color)}.help-card:hover{border-color:var(--cat-color);box-shadow:0 4px 20px #0000000f;transform:translateY(-1px)}.help-card--open{border-color:var(--cat-color);box-shadow:0 6px 28px #0000001a}.help-card__header{width:100%;display:flex;align-items:center;gap:12px;padding:14px 14px 14px 12px;background:none;border:none;cursor:pointer;text-align:left;transition:background .12s ease}.help-card__header:hover,.help-card--open .help-card__header{background:var(--modal-surface2)}.help-card__icon{font-size:22px;line-height:1;flex-shrink:0;width:32px;text-align:center}.help-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.help-card__title{font-family:var(--font);font-size:14px;font-weight:800;color:var(--text);line-height:1.2}.help-card__desc{font-family:var(--font-body);font-size:12px;color:var(--text-sub);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.help-card__cat-badge{flex-shrink:0;font-family:var(--font-body);font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.help-card__chevron{flex-shrink:0;font-size:10px;color:var(--text-muted);transition:transform .2s ease}.help-card__content{border-top:1px solid var(--border);animation:help-expand .2s cubic-bezier(.16,1,.3,1)}@keyframes help-expand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.help-article__body{padding:14px 16px 16px 48px}.help-article__subhead{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #64748B);margin:12px 0 4px;padding-bottom:4px;border-bottom:1px solid var(--border, #E2E8F0)}.help-article__para{font-family:var(--font-body);font-size:13px;color:var(--text-mid);line-height:1.65;margin:0 0 10px}.help-article__para strong{color:var(--text)}.help-article__list{font-family:var(--font-body);font-size:13px;color:var(--text-mid);line-height:1.65;margin:0 0 10px;padding-left:18px}.help-article__list li{margin-bottom:5px}.help-article__list strong{color:var(--text)}.help-article__tips{margin:10px 0;padding:12px 14px;border-radius:10px;background:#0d948812;border:1px solid rgba(13,148,136,.2)}.help-article__tips-label{font-family:var(--font);font-size:11px;font-weight:800;color:var(--teal);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.help-article__tips ul{margin:0;padding-left:16px}.help-article__tips li{font-family:var(--font-body);font-size:12.5px;color:var(--text-mid);line-height:1.6;margin-bottom:4px}.help-article__shortcuts{margin:10px 0;padding:12px 14px;border-radius:10px;background:var(--modal-surface2);border:1px solid var(--border)}.help-article__shortcuts-label{font-family:var(--font);font-size:11px;font-weight:800;color:var(--text-sub);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.help-article__shortcut-row{display:flex;align-items:center;gap:12px;margin-bottom:6px}.help-article__shortcut-desc{font-family:var(--font-body);font-size:12px;color:var(--text-sub)}.help-shortcut{display:flex;align-items:center;gap:3px}.help-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:22px;padding:0 6px;border-radius:5px;border:1.5px solid var(--border2);background:var(--modal-bg);font-family:var(--font-body);font-size:11px;font-weight:700;color:var(--text);box-shadow:0 2px 0 var(--border2);white-space:nowrap}.help-kbd-sep{font-size:11px;color:var(--text-muted);font-family:var(--font-body)}.help-highlight{background:#0d94882e;color:var(--teal);border-radius:3px;padding:0 1px;font-style:normal}.help-empty{text-align:center;padding:60px 20px}.help-empty__icon{font-size:40px;margin-bottom:16px;opacity:.5}.help-empty__title{font-family:var(--font);font-size:16px;font-weight:800;color:var(--text-mid);margin-bottom:6px}.help-empty__sub{font-family:var(--font-body);font-size:13px;color:var(--text-muted)}@media(max-width:540px){.help-panel{width:100vw;border-left:none}.help-article__body{padding-left:16px}.help-card__cat-badge{display:none}}[data-theme=dark] .help-panel,[data-theme=terracotta-dark] .help-panel{box-shadow:-8px 0 48px #00000080,-2px 0 12px #0000004d}[data-theme=dark] .help-article__tips,[data-theme=terracotta-dark] .help-article__tips{background:#0d94881a;border-color:#0d948840}.pdf-picker__backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:8500;padding:16px;opacity:0;transition:opacity .14s ease;pointer-events:none}.pdf-picker__backdrop.is-open{opacity:1;pointer-events:auto}@keyframes pdf-fade{0%{opacity:0}to{opacity:1}}.pdf-picker{background:var(--modal-bg);border:1px solid var(--brand-border);border-radius:var(--radius-lg, 20px);box-shadow:var(--shadow-lg, 0 20px 60px rgba(0,0,0,.2));width:min(780px,100%);max-height:min(88vh,700px);display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:scale(.95) translateY(10px);transition:opacity .2s cubic-bezier(.34,1.1,.64,1),transform .2s cubic-bezier(.34,1.1,.64,1)}.pdf-picker__backdrop.is-open .pdf-picker{opacity:1;transform:scale(1) translateY(0)}@keyframes pdf-slide{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.pdf-picker__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0}.pdf-picker__header-left{display:flex;align-items:center;gap:12px}.pdf-picker__icon{font-size:28px;line-height:1}.pdf-picker__title{font-size:16px;font-weight:700;color:var(--brand-text)}.pdf-picker__subtitle{font-size:12px;color:var(--brand-text-sub);margin-top:2px;max-width:400px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pdf-picker__close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--brand-text-sub);padding:0;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, 8px);flex-shrink:0}.pdf-picker__close:hover{background:#ffffff1f;color:var(--brand-text)}.pdf-picker__loading{padding:10px 20px;flex-shrink:0}.pdf-picker__loading-bar{height:4px;background:var(--modal-surface2);border-radius:var(--radius-pill);overflow:hidden}.pdf-picker__loading-fill{height:100%;background:var(--teal, #0d9488);border-radius:var(--radius-pill);transition:width .3s ease;min-width:6%}.pdf-picker__loading-label{font-size:12px;color:var(--text-muted, #94a3b8);margin-top:6px}.pdf-picker__toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border, #e2e8f0);flex-shrink:0}.pdf-picker__count{font-size:13px;color:var(--text-sub, #64748b)}.pdf-picker__toolbar-actions{display:flex;align-items:center;gap:10px}.pdf-picker__selected-badge{font-size:12px;font-weight:600;background:var(--teal, #0d9488);color:#fff;padding:2px 10px;border-radius:var(--radius-pill, 9999px)}.pdf-picker__text-btn{background:none;border:none;cursor:pointer;font-size:13px;color:var(--teal, #0d9488);padding:4px 8px;border-radius:var(--radius-sm, 6px);font-weight:500}.pdf-picker__text-btn:hover:not(:disabled){background:var(--modal-surface2)}.pdf-picker__text-btn:disabled{opacity:.35;cursor:default}.pdf-picker__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;padding:16px 20px;overflow-y:auto;flex:1;min-height:0}.pdf-picker__page{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;outline:none;border-radius:var(--radius-sm, 8px);padding:6px;transition:background .1s;-webkit-user-select:none;user-select:none}.pdf-picker__page:hover{background:var(--modal-surface2)}.pdf-picker__page:focus-visible{box-shadow:0 0 0 2px var(--teal, #0d9488)}.pdf-picker__page-thumb-wrap{position:relative;width:100%;border-radius:6px;overflow:hidden;box-shadow:0 1px 4px #0000001f;transition:box-shadow .12s,transform .12s;aspect-ratio:8.5 / 11;background:#fff}.pdf-picker__page:hover .pdf-picker__page-thumb-wrap{box-shadow:0 4px 12px #0000002e;transform:translateY(-1px)}.pdf-picker__page--selected .pdf-picker__page-thumb-wrap{box-shadow:0 0 0 3px var(--teal, #0d9488),0 4px 12px #00000026}.pdf-picker__page-thumb{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}.pdf-picker__zoom-hint{position:absolute;top:4px;right:4px;background:#00000080;color:#fff;border:none;border-radius:4px;width:22px;height:22px;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s;line-height:1}.pdf-picker__page:hover .pdf-picker__zoom-hint,.pdf-picker__page:focus-visible .pdf-picker__zoom-hint{opacity:1}.pdf-picker__tick{position:absolute;bottom:4px;right:4px;background:var(--teal, #0d9488);color:#fff;border-radius:50%;width:20px;height:20px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #00000040}.pdf-picker__grid:has(.pdf-picker__page--selected) .pdf-picker__page:not(.pdf-picker__page--selected) .pdf-picker__page-thumb-wrap{opacity:.55}.pdf-picker__page-num{font-size:12px;color:var(--text-sub, #64748b);font-weight:400}.pdf-picker__page--selected .pdf-picker__page-num{color:var(--teal, #0d9488);font-weight:600}.pdf-picker__empty{grid-column:1 / -1;text-align:center;padding:40px;color:var(--text-muted, #94a3b8);font-size:14px}.pdf-picker__footer{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border, #e2e8f0);flex-shrink:0}.pdf-picker__btn{padding:0 20px;height:44px;border-radius:var(--radius-sm, 8px);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:background .12s,opacity .12s;min-width:80px}.pdf-picker__btn--primary{background:var(--teal, #0d9488);color:#fff}.pdf-picker__btn--primary:hover:not(:disabled){filter:brightness(1.08)}.pdf-picker__btn--primary:disabled{opacity:.4;cursor:not-allowed}.pdf-picker__btn--ghost{background:transparent;color:var(--text-sub, #64748b)}.pdf-picker__btn--ghost:hover{background:var(--modal-surface2);color:var(--text, #1e293b)}.pdf-picker__zoom{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9100;animation:pdf-fade .1s ease;padding:24px}.pdf-picker__zoom-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;max-height:90vh}.pdf-picker__zoom-img{max-width:min(600px,100%);max-height:75vh;border-radius:8px;box-shadow:0 8px 40px #00000080;object-fit:contain}.pdf-picker__zoom-label{font-size:13px;color:#ffffffb3}.pdf-picker__zoom-select{padding:0 24px;height:44px;border-radius:var(--radius-sm, 8px);font-size:14px;font-weight:600;cursor:pointer;border:2px solid rgba(255,255,255,.4);background:transparent;color:#fff;transition:background .12s,border-color .12s}.pdf-picker__zoom-select:hover{background:#ffffff1f;border-color:#ffffffb3}.pdf-picker__zoom-select--active{background:var(--teal, #0d9488);border-color:var(--teal, #0d9488)}.pdf-picker__zoom-close{position:fixed;top:16px;right:16px;background:#ffffff26;border:none;color:#fff;font-size:18px;cursor:pointer;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center}.pdf-picker__zoom-close:hover{background:#ffffff40}.lim__backdrop{position:fixed;inset:0;background:#00000059;z-index:9000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:lim-fade-in .18s ease;display:flex;align-items:stretch;justify-content:flex-end}@keyframes lim-fade-in{0%{opacity:0}to{opacity:1}}.lim__panel{background:var(--modal-bg);border-left:1px solid var(--brand-border);box-shadow:-4px 0 32px #0000002e;width:360px;max-width:calc(100vw - 48px);height:100%;display:flex;flex-direction:column;overflow:hidden;animation:lim-slide-in .24s cubic-bezier(.22,1,.36,1)}@keyframes lim-slide-in{0%{transform:translate(100%);opacity:.6}to{transform:translate(0);opacity:1}}.lim__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);gap:12px;flex-shrink:0}.lim__header-left{display:flex;align-items:center;gap:14px}.lim__header-icon{width:40px;height:40px;border-radius:12px;background:#ffffff1f;color:var(--brand-text);display:flex;align-items:center;justify-content:center;flex-shrink:0}.lim__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0 0 2px;line-height:1.3}.lim__subtitle{font-size:12.5px;color:var(--brand-text-sub);margin:0;line-height:1.4}.lim__close-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--brand-text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .14s,color .14s;flex-shrink:0}.lim__close-btn:hover{background:#ffffff1f;color:var(--brand-text)}.lim__body{overflow-y:auto;flex:1;padding:12px}.lim__empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:36px 24px;gap:10px}.lim__empty-icon{width:68px;height:68px;border-radius:18px;background:var(--modal-surface2);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:4px}.lim__empty-title{font-size:15px;font-weight:600;color:var(--text);margin:0}.lim__empty-hint{font-size:13px;color:var(--text-muted);line-height:1.55;max-width:300px;margin:0}.lim__list{display:flex;flex-direction:column;gap:6px}.lim__item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;background:var(--modal-surface2);border:1px solid transparent;transition:border-color .15s,background .15s}.lim__item:hover{border-color:var(--border);background:var(--modal-bg)}.lim__thumb{width:52px;height:40px;border-radius:7px;overflow:hidden;flex-shrink:0;background:var(--modal-bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}.lim__thumb img{width:100%;height:100%;object-fit:cover;display:block}.lim__thumb--placeholder{background:var(--teal-xl, #F0FDFA)}.lim__thumb--placeholder span{font-size:20px;line-height:1}.lim__item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.lim__item-header{display:flex;align-items:center;gap:6px}.lim__item-icon{font-size:13px;line-height:1;flex-shrink:0}.lim__item-label{font-size:13.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lim__item-dims{font-size:11.5px;color:var(--text-muted);font-variant-numeric:tabular-nums}.lim__item-badge{display:flex;gap:6px}.lim__badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.01em}.lim__badge--locked{background:rgba(var(--teal-rgb, 13, 148, 136),.12);color:var(--teal)}.lim__unlock-btn{display:flex;align-items:center;gap:6px;padding:7px 13px;border-radius:8px;border:1px solid var(--border);background:var(--modal-bg);color:var(--text);font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .14s,color .14s,border-color .14s;min-height:34px}.lim__unlock-btn:hover{background:var(--teal);border-color:var(--teal);color:#fff}.lim__unlock-btn:hover svg{stroke:#fff}.lim__footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0}.lim__footer-hint{font-size:12px;color:var(--text-muted);margin:0;line-height:1.4;flex:1}.lim__unlock-all-btn{display:flex;align-items:center;gap:7px;padding:9px 18px;border-radius:10px;border:none;background:var(--teal);color:#fff;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .14s,transform .1s;min-height:38px}.lim__unlock-all-btn:hover{background:var(--teal-d, #0F766E)}.lim__unlock-all-btn:active{transform:scale(.97)}@media(max-width:767px){.lim__panel{width:100%;border-left:none;border-top:1px solid var(--border);border-radius:20px 20px 0 0}.lim__backdrop{align-items:flex-end}}.upload-dialog__backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9000;animation:upload-fade-in .14s ease}@keyframes upload-fade-in{0%{opacity:0}to{opacity:1}}.upload-dialog{background:var(--modal-bg);border:1px solid var(--brand-border);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 8px 32px rgba(0,0,0,.18));width:min(480px,calc(100vw - 32px));padding:24px;display:flex;flex-direction:column;gap:18px;animation:upload-slide-in .18s cubic-bezier(.34,1.2,.64,1)}@keyframes upload-slide-in{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.upload-dialog__header{display:flex;align-items:center;justify-content:space-between;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);padding:16px 20px;margin:-20px -20px 16px}.upload-dialog__title{font-size:16px;font-weight:600;color:var(--brand-text)}.upload-dialog__close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--brand-text-sub);padding:4px 8px;border-radius:var(--radius-sm, 6px);line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.upload-dialog__close:hover{background:#ffffff1f;color:var(--brand-text)}.upload-dialog__dropzone{border:2px dashed var(--border, #e2e8f0);border-radius:var(--radius-md, 8px);padding:28px 20px;text-align:center;cursor:pointer;transition:border-color .12s,background .12s;-webkit-user-select:none;user-select:none;min-height:100px;display:flex;align-items:center;justify-content:center}.upload-dialog__dropzone:hover,.upload-dialog__dropzone:focus-visible{border-color:var(--teal, #0ea5e9);background:color-mix(in srgb,var(--teal, #0ea5e9) 5%,transparent);outline:none}.upload-dialog__dropzone--drag{border-color:var(--teal, #0ea5e9);background:color-mix(in srgb,var(--teal, #0ea5e9) 10%,transparent)}.upload-dialog__dropzone--has-file{border-style:solid;border-color:var(--teal, #0ea5e9);background:color-mix(in srgb,var(--teal, #0ea5e9) 5%,transparent)}.upload-dialog__file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.upload-dialog__drop-hint{display:flex;flex-direction:column;align-items:center;gap:6px}.upload-dialog__drop-icon{font-size:28px;color:var(--text-muted, #94a3b8)}.upload-dialog__drop-text{font-size:14px;font-weight:500;color:var(--text, #1e293b)}.upload-dialog__drop-sub{font-size:12px;color:var(--text-muted, #94a3b8)}.upload-dialog__file-info{display:flex;flex-direction:column;align-items:center;gap:4px}.upload-dialog__file-icon{font-size:24px}.upload-dialog__file-name{font-size:14px;font-weight:500;color:var(--text, #1e293b);word-break:break-all;max-width:100%}.upload-dialog__file-size{font-size:12px;color:var(--text-muted, #94a3b8)}.upload-dialog__progress-wrap{display:flex;flex-direction:column;gap:6px}.upload-dialog__progress-bar{height:8px;background:var(--modal-surface2);border-radius:var(--radius-pill);overflow:hidden}.upload-dialog__progress-fill{height:100%;background:var(--teal, #0ea5e9);border-radius:var(--radius-pill);transition:width .2s ease}.upload-dialog__progress-fill--done{background:#22c55e}.upload-dialog__progress-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted, #64748b)}.upload-dialog__status{font-size:13px;padding:10px 14px;border-radius:var(--radius-sm, 6px);font-weight:500}.upload-dialog__status--success{background:color-mix(in srgb,#22c55e 12%,transparent);color:#16a34a}.upload-dialog__status--error{background:color-mix(in srgb,#ef4444 10%,transparent);color:#dc2626}.upload-dialog__status--demo{background:color-mix(in srgb,var(--teal, #0ea5e9) 10%,transparent);color:var(--teal, #0ea5e9)}.upload-dialog__actions{display:flex;gap:10px;justify-content:flex-end}.upload-dialog__btn{padding:0 20px;height:44px;border-radius:var(--radius-sm, 8px);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:background .12s,opacity .12s;min-width:80px}.upload-dialog__btn--primary{background:var(--teal, #0ea5e9);color:#fff}.upload-dialog__btn--primary:hover:not(:disabled){background:color-mix(in srgb,var(--teal, #0ea5e9) 85%,black)}.upload-dialog__btn--primary:disabled{opacity:.4;cursor:not-allowed}.upload-dialog__btn--secondary{background:var(--modal-surface2);color:var(--text, #1e293b);border:1px solid var(--border, #e2e8f0)}.upload-dialog__btn--secondary:hover{background:color-mix(in srgb,var(--modal-surface2) 80%,black)}.upload-dialog__btn--ghost{background:transparent;color:var(--text-muted, #64748b)}.upload-dialog__btn--ghost:hover{background:var(--modal-surface2);color:var(--text, #1e293b)}.upload-dialog__pending{border-top:1px solid var(--border, #e2e8f0);padding-top:14px;display:flex;flex-direction:column;gap:8px}.upload-dialog__pending-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #94a3b8)}.upload-dialog__pending-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm, 6px);background:var(--modal-surface2);border:1px solid var(--border, #e2e8f0);cursor:pointer;transition:background .1s}.upload-dialog__pending-row:hover,.upload-dialog__pending-row:focus-visible{background:color-mix(in srgb,var(--teal, #0ea5e9) 8%,transparent);border-color:var(--teal, #0ea5e9);outline:none}.upload-dialog__pending-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.upload-dialog__pending-name{font-size:13px;font-weight:500;color:var(--text, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-dialog__pending-meta{font-size:11px;color:var(--text-muted, #94a3b8)}.upload-dialog__pending-bar{height:4px;background:var(--modal-bg);border-radius:var(--radius-pill);overflow:hidden}.upload-dialog__pending-fill{height:100%;background:var(--teal, #0ea5e9);border-radius:var(--radius-pill)}.upload-dialog__pending-discard{background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-muted, #94a3b8);padding:4px;border-radius:var(--radius-sm, 4px);min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.upload-dialog__pending-discard:hover{background:color-mix(in srgb,#ef4444 12%,transparent);color:#dc2626}.thumbnail{position:relative;overflow:hidden;border-radius:6px;background:var(--surface2, #f1f5f9);flex-shrink:0;display:block}.thumbnail__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .18s ease}.thumbnail__img--loaded{opacity:1}.thumbnail__shimmer{position:absolute;inset:0;background:linear-gradient(90deg,var(--surface2, #f1f5f9) 25%,color-mix(in srgb,var(--surface2, #f1f5f9) 60%,var(--border, #e2e8f0)) 50%,var(--surface2, #f1f5f9) 75%);background-size:200% 100%;animation:thumbnail-shimmer 1.4s infinite}@keyframes thumbnail-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.thumbnail__fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text2, #94a3b8)}.thumbnail__fallback-icon{font-size:28px;opacity:.5}.thumbnail[role=button]{cursor:pointer}.thumbnail[role=button]:hover .thumbnail__img{opacity:.88}.thumbnail[role=button]:focus-visible{outline:2px solid var(--teal, #0d9488);outline-offset:2px}.snapshot-gallery{position:absolute;top:0;left:0;width:320px;height:100%;background:var(--modal-bg);border-right:1px solid var(--brand-border);box-shadow:4px 0 16px #00000014;z-index:30;display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none}.snapshot-gallery__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;background:var(--brand-bg);border-bottom:1px solid var(--brand-border);flex-shrink:0;gap:12px}.snapshot-gallery__header-left{display:flex;align-items:center;gap:14px}.snapshot-gallery__header-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--brand-hover);color:var(--brand-text);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.snapshot-gallery__title{font-size:16px;font-weight:700;color:var(--brand-text);margin:0 0 2px;line-height:1.3}.snapshot-gallery__subtitle{font-size:12px;color:var(--brand-text-sub);margin:0}.snapshot-gallery__close{width:32px;height:32px;border:none;border-radius:var(--radius-sm, 6px);background:transparent;color:var(--brand-text-sub);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;margin-left:auto;flex-shrink:0}.snapshot-gallery__close:hover{background:var(--brand-hover);color:var(--brand-text)}.snapshot-gallery__save-bar{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border, #e2e8f0);flex-shrink:0}.snapshot-gallery__label-input{flex:1;height:36px;padding:0 10px;border:1px solid var(--border, #e2e8f0);border-radius:var(--radius-sm, 6px);background:var(--modal-surface2);color:var(--text, #1e293b);font-size:13px;font-family:var(--font-body, sans-serif);outline:none;transition:border-color .12s}.snapshot-gallery__label-input:focus{border-color:var(--teal, #0d9488);background:var(--modal-bg)}.snapshot-gallery__save-btn{height:36px;padding:0 14px;border:none;border-radius:var(--radius-sm, 6px);background:var(--teal, #0d9488);color:#fff;font-size:13px;font-weight:600;font-family:var(--font-body, sans-serif);cursor:pointer;white-space:nowrap;transition:background .12s,opacity .12s}.snapshot-gallery__save-btn:hover{background:var(--teal-dark, #0f766e)}.snapshot-gallery__save-btn:disabled{opacity:.5;cursor:not-allowed}.snapshot-gallery__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:32px 24px;color:var(--text-muted, #94a3b8);text-align:center}.snapshot-gallery__empty-icon{font-size:40px;line-height:1;margin-bottom:8px}.snapshot-gallery__empty p{margin:0;font-size:13px;line-height:1.5}.snapshot-gallery__grid{flex:1;overflow-y:auto;padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}.snapshot-card{display:flex;flex-direction:column;border:1px solid var(--border, #e2e8f0);border-radius:var(--radius, 10px);overflow:hidden;background:var(--modal-bg);transition:box-shadow .15s,border-color .15s}.snapshot-card:hover{border-color:var(--teal, #0d9488);box-shadow:0 2px 10px #0d94881f}.snapshot-card__thumb-btn{position:relative;display:block;width:100%;aspect-ratio:3 / 2;padding:0;border:none;background:var(--modal-surface2);cursor:pointer;overflow:hidden}.snapshot-card__thumb{width:100%;height:100%;object-fit:cover;display:block}.snapshot-card__thumb--blank{display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--text-muted, #cbd5e1);width:100%;height:100%}.snapshot-card__restore-overlay{position:absolute;inset:0;background:#0d9488b8;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;letter-spacing:.05em;text-transform:uppercase}.snapshot-card__thumb-btn:hover .snapshot-card__restore-overlay{opacity:1}.snapshot-card__footer{padding:6px 8px 2px;display:flex;flex-direction:column;gap:2px;min-width:0}.snapshot-card__label{font-size:12px;font-weight:600;color:var(--text, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;border:none;background:transparent;padding:0;cursor:pointer;font-family:var(--font-body, sans-serif);width:100%}.snapshot-card__label:hover{color:var(--teal, #0d9488);text-decoration:underline}.snapshot-card__rename-input{width:100%;font-size:12px;font-weight:600;font-family:var(--font-body, sans-serif);color:var(--text, #1e293b);border:1px solid var(--teal, #0d9488);border-radius:4px;padding:1px 4px;outline:none;background:var(--modal-bg)}.snapshot-card__date{font-size:11px;color:var(--text-muted, #94a3b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.snapshot-card__actions{display:flex;justify-content:flex-end;gap:2px;padding:2px 6px 6px}.snapshot-card__action-btn{width:28px;height:28px;border:none;border-radius:var(--radius-sm, 6px);background:transparent;color:var(--text-muted, #94a3b8);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.snapshot-card__action-btn:hover{background:var(--modal-surface2);color:var(--text, #1e293b)}.snapshot-card__action-btn--delete:hover{background:#ef44441f;color:#ef4444}.snapshot-card__action-btn:disabled{opacity:.4;cursor:not-allowed}.countdown-timer{position:fixed;right:20px;bottom:72px;width:240px;border-radius:16px;background:var(--modal-bg);border:1.5px solid var(--border2);box-shadow:var(--shadow-lg);z-index:60;overflow:hidden;-webkit-user-select:none;user-select:none;transition:border-color .25s,box-shadow .25s}.countdown-timer.is-warning{border-color:var(--amber);animation:ct-pulse .65s ease-in-out infinite alternate}@keyframes ct-pulse{0%{box-shadow:0 0 0 2px var(--amber-l),var(--shadow-lg)}to{box-shadow:0 0 0 7px var(--amber-l),var(--shadow-lg)}}.countdown-timer.is-done{border-color:var(--green)}.countdown-timer__header{display:flex;align-items:center;justify-content:space-between;padding:11px 10px 8px 14px;cursor:grab;border-bottom:1px solid var(--border2)}.countdown-timer__header:active{cursor:grabbing}.countdown-timer__title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;font-family:var(--font-body);color:var(--amber);text-transform:uppercase;letter-spacing:.07em}.countdown-timer__title svg{flex-shrink:0;color:var(--amber)}.countdown-timer__header-actions{display:flex;align-items:center;gap:2px}.countdown-timer__mute-btn,.countdown-timer__close-btn{width:28px;height:28px;border-radius:7px;border:1.5px solid transparent;background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s,border-color .12s;-webkit-tap-highlight-color:transparent;padding:0}.countdown-timer__mute-btn:hover{background:var(--amber-l);color:var(--amber);border-color:var(--amber)}.countdown-timer__mute-btn.is-muted{opacity:.45}.countdown-timer__close-btn:hover{background:var(--rose);color:#fff;border-color:var(--rose)}.countdown-timer__arc-wrap{position:relative;width:148px;height:148px;margin:16px auto 12px}.countdown-timer__arc-svg{width:100%;height:100%;transform:rotate(-90deg)}.countdown-timer__arc-track{fill:none;stroke:var(--modal-surface2);stroke-width:7}.countdown-timer__arc-fill{fill:none;stroke:var(--amber);stroke-width:7;stroke-linecap:round;stroke-dasharray:263.9;stroke-dashoffset:0;transition:stroke-dashoffset .95s linear,stroke .3s}.countdown-timer.is-warning .countdown-timer__arc-fill{stroke:var(--rose)}.countdown-timer.is-done .countdown-timer__arc-fill{stroke:var(--green)}.countdown-timer__display{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:30px;font-weight:800;font-family:var(--font-body);color:var(--text-primary, #1e293b);letter-spacing:-.03em;line-height:1;gap:3px}.countdown-timer__display-done{font-size:36px}.countdown-timer__display-label{font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-body)}.countdown-timer.is-warning .countdown-timer__display{color:var(--rose)}.countdown-timer.is-done .countdown-timer__display{color:var(--green)}.countdown-timer__inputs{display:flex;align-items:center;justify-content:center;gap:8px;padding:0 16px 12px}.countdown-timer__input-wrap{display:flex;flex-direction:column;align-items:center;gap:3px}.countdown-timer__input{width:60px;height:38px;text-align:center;font-size:17px;font-weight:700;font-family:var(--font-body);border:1.5px solid var(--border2);border-radius:10px;background:var(--modal-surface2);color:var(--text-primary);outline:none;transition:border-color .15s;-moz-appearance:textfield}.countdown-timer__input::-webkit-outer-spin-button,.countdown-timer__input::-webkit-inner-spin-button{-webkit-appearance:none}.countdown-timer__input:focus{border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-l)}.countdown-timer__input-label{font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-body)}.countdown-timer__sep{font-size:22px;font-weight:800;color:var(--border2);margin-top:-14px;font-family:var(--font-body);line-height:1}.countdown-timer__controls{display:flex;align-items:center;gap:8px;padding:0 12px 12px}.countdown-timer__btn{height:42px;min-width:42px;border-radius:10px;border:1.5px solid var(--border2);background:var(--modal-surface2);color:var(--text-sub);font-size:13px;font-weight:700;font-family:var(--font-body);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;transition:all .12s;-webkit-tap-highlight-color:transparent}.countdown-timer__btn:hover{border-color:var(--amber);color:var(--amber);background:var(--amber-l)}.countdown-timer__btn:active{transform:scale(.95)}.countdown-timer__btn--start{flex:1;background:var(--amber);border-color:var(--amber);color:#fff;box-shadow:0 2px 8px #d9770659}.countdown-timer__btn--start:hover{background:var(--amber);filter:brightness(1.08);color:#fff}.countdown-timer__btn--pause{flex:1}.countdown-timer__btn--pause:hover{border-color:var(--amber);color:var(--amber);background:var(--amber-l)}.countdown-timer__btn--reset{width:42px;min-width:42px;padding:0;flex:none}@media(max-width:480px){.countdown-timer{width:210px;right:8px;bottom:68px}.countdown-timer__arc-wrap{width:126px;height:126px}.countdown-timer__display{font-size:26px}}.rb-wrap{position:relative;display:inline-flex;align-items:center;gap:6px}.rb-btn{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:10px;border:none;font-size:12px;font-weight:800;font-family:var(--font, "Nunito Sans", sans-serif);letter-spacing:.01em;cursor:pointer;transition:background .15s ease,box-shadow .15s ease,transform .12s cubic-bezier(.34,1.56,.64,1),opacity .12s ease;outline:none;white-space:nowrap;user-select:none;-webkit-user-select:none}.rb-btn:focus-visible{box-shadow:0 0 0 3px #7c3aed66}.rb-btn:active:not(:disabled){transform:scale(.96)}.rb-btn:disabled{opacity:.55;cursor:not-allowed}.rb-btn--idle{background:linear-gradient(135deg,#4c1d95,#6d28d9);color:#fff;box-shadow:0 2px 8px #6d28d959,0 1px 2px #0000001f}.rb-btn--idle:hover:not(:disabled){background:linear-gradient(135deg,#5b21b6,#7c3aed);box-shadow:0 4px 14px #6d28d973,0 1px 3px #0000001f;transform:translateY(-1px)}.rb-btn--recording{background:linear-gradient(135deg,#b91c1c,#dc2626);color:#fff;box-shadow:0 2px 8px #dc262673,0 1px 2px #0000001f;animation:rb-record-pulse 2.2s ease-in-out infinite}.rb-btn--recording:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#ef4444);animation:none;box-shadow:0 4px 14px #dc262680;transform:translateY(-1px)}@keyframes rb-record-pulse{0%,to{box-shadow:0 2px 8px #dc262673,0 1px 2px #0000001f}50%{box-shadow:0 4px 18px #dc2626a6,0 2px 4px #00000026}}.rb-btn--stopping,.rb-btn--uploading{background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;box-shadow:0 2px 8px #0d948859;cursor:not-allowed}.rb-btn--done{background:linear-gradient(135deg,#15803d,#16a34a);color:#fff;box-shadow:0 2px 8px #16a34a59}.rb-btn--error{background:linear-gradient(135deg,#9f1239,#be123c);color:#fff;box-shadow:0 2px 8px #be123c59}.rb-dot{width:9px;height:9px;border-radius:50%;background:#ffffffe6;flex-shrink:0;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.rb-btn--idle .rb-dot{background:transparent;border:2px solid rgba(255,255,255,.9);width:8px;height:8px}.rb-btn--recording .rb-dot{background:#fff;animation:rb-blink 1.1s step-start infinite}@keyframes rb-blink{0%,to{opacity:1}50%{opacity:.2}}.rb-square{width:9px;height:9px;border-radius:2px;background:#fffffff2;flex-shrink:0}.rb-timer{font-size:12px;font-weight:700;font-family:Courier New,Consolas,monospace;color:#fff;background:#0003;border-radius:5px;padding:0 5px;letter-spacing:.04em;font-variant-numeric:tabular-nums;min-width:38px;text-align:center}.rb-library-btn{display:inline-flex;align-items:center;gap:5px;height:36px;padding:0 11px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface, #fff);color:var(--text-sub, #475569);font-size:12px;font-weight:700;font-family:var(--font, "Nunito Sans", sans-serif);cursor:pointer;transition:border-color .12s,background .12s,color .12s,transform .12s cubic-bezier(.34,1.56,.64,1);outline:none;white-space:nowrap}.rb-library-btn:hover{border-color:#7c3aed;color:#7c3aed;background:#7c3aed0d;transform:translateY(-1px)}.rb-library-btn:focus-visible{box-shadow:0 0 0 3px #7c3aed4d}.rb-library-badge{height:18px;min-width:18px;padding:0 5px;border-radius:9px;background:#7c3aed;color:#fff;font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body, "Nunito Sans", sans-serif);letter-spacing:0;box-shadow:0 1px 4px #7c3aed66}.rb-error-tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1e0a4e;color:#fca5a5;font-size:11px;font-weight:600;font-family:var(--font-body, "Nunito Sans", sans-serif);padding:6px 12px;border-radius:8px;white-space:nowrap;box-shadow:0 4px 16px #00000040;pointer-events:none;z-index:50;animation:rb-tip-in .2s ease}.rb-error-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1e0a4e}@keyframes rb-tip-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.rb-snackbar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#1e0a4e;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:13px;font-weight:600;font-family:var(--font-body, "Nunito Sans", sans-serif);padding:10px 20px;border-radius:12px;box-shadow:0 8px 24px #0000004d;z-index:500;display:flex;align-items:center;gap:10px;animation:rb-snack-in .28s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}.rb-snackbar--done{border-color:#16a34a66}.rb-snackbar--error{border-color:#dc262666;color:#fca5a5}@keyframes rb-snack-in{0%{opacity:0;transform:translate(-50%) translateY(16px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.rb-snackbar__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rb-snackbar--done .rb-snackbar__dot{background:#16a34a}.rb-snackbar--error .rb-snackbar__dot{background:#ef4444}.recp-backdrop{position:fixed;inset:0;z-index:700;background:#0a071e7a;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.recp-panel{position:fixed;top:0;right:0;bottom:0;width:min(840px,100vw);z-index:701;display:flex;flex-direction:column;overflow:hidden;background:#fff;box-shadow:-20px 0 70px #0f172a47;border-left:1px solid rgba(226,232,240,.9);animation:recp-in .24s cubic-bezier(.22,1,.36,1)}.recp-panel--closing{animation:recp-out .18s ease forwards}@keyframes recp-in{0%{transform:translate(100%);opacity:.6}to{transform:translate(0);opacity:1}}@keyframes recp-out{to{transform:translate(100%);opacity:0}}.recp-header{display:flex;align-items:center;gap:12px;padding:16px 18px;background:linear-gradient(135deg,#1e0a4e,#3b0878);color:#fff;flex-shrink:0}.recp-header__icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#ffffff21;border:1px solid rgba(255,255,255,.16)}.recp-header__text{flex:1;min-width:0}.recp-header__title{font-size:16px;font-weight:900;font-family:var(--font, "Nunito Sans", sans-serif);line-height:1.2}.recp-header__subtitle{margin-top:2px;font-size:12px;color:#ffffff9e}.recp-header__close{width:32px;height:32px;border-radius:10px;border:none;background:#ffffff1a;color:#ffffffb8;cursor:pointer;font-size:16px}.recp-header__close:hover{background:#fff3;color:#fff}.recp-upload{padding:10px 14px;border-bottom:1px solid #e2e8f0;background:#faf7ff;flex-shrink:0}.recp-upload div{display:flex;justify-content:space-between;font-size:12px;font-weight:800;color:#3b0878;margin-bottom:6px}.recp-upload progress{width:100%;height:7px;accent-color:#7c3aed}.recp-toolbar{display:flex;gap:8px;padding:12px 14px;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0}.recp-toolbar input,.recp-toolbar select{height:38px;border-radius:11px;border:1.5px solid #e2e8f0;background:#f8fafc;color:#1e293b;outline:none;font-size:13px;padding:0 10px}.recp-toolbar input{flex:1;min-width:0}.recp-toolbar input:focus,.recp-toolbar select:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1f}.recp-bulkbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 14px;border-bottom:1px solid #e2e8f0;background:#fbfaff;flex-shrink:0}.recp-bulkbar span{margin-right:auto;font-size:12px;font-weight:900;color:#6d28d9}.recp-bulkbar button,.recp-card__actions button{height:30px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer;font-size:11px;font-weight:800;padding:0 9px}.recp-bulkbar button:hover,.recp-card__actions button:hover{border-color:#7c3aed;color:#6d28d9}.recp-bulkbar button:disabled{opacity:.45;cursor:not-allowed}.recp-danger{color:#dc2626!important}.recp-danger:hover{border-color:#fca5a5!important;background:#fef2f2!important}.recp-list{flex:1;min-height:0;overflow-y:auto;padding:16px;background:#f8fafc;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-flow:row;grid-auto-rows:max-content;align-content:start;align-items:start;gap:18px}.recp-status,.recp-empty{grid-column:1 / -1;padding:32px 20px;text-align:center;color:#64748b;font-size:13px}.recp-status--error{color:#dc2626}.recp-empty{min-height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.recp-empty__icon{width:58px;height:58px;border-radius:18px;background:#ede9fe;display:flex;align-items:center;justify-content:center;font-size:26px}.recp-empty strong{color:#1e293b;font-size:15px}.recp-empty span{max-width:250px;line-height:1.5}.recp-card{position:relative;min-width:0;width:100%;display:flex;flex-direction:column;overflow:hidden;border-radius:18px;background:#fff;border:1.5px solid #e2e8f0;box-shadow:0 3px 12px #0f172a0f;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;contain:layout paint}.recp-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px #0f172a1f;border-color:#7c3aed52}.recp-card--selected{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed24,0 12px 30px #0f172a1a}.recp-card__check{position:absolute;top:10px;left:10px;z-index:5;cursor:pointer}.recp-card__check input{display:none}.recp-card__check span{display:block;width:22px;height:22px;border-radius:7px;border:2px solid rgba(255,255,255,.94);background:#0f172a40;box-shadow:0 1px 5px #0000003d}.recp-card__check input:checked+span{background:#7c3aed;border-color:#fff}.recp-card__check input:checked+span:after{content:"✓";display:flex;align-items:center;justify-content:center;height:100%;color:#fff;font-size:13px;font-weight:900}.recp-card__preview{position:relative;display:block;flex:0 0 auto;width:100%;aspect-ratio:16 / 9;min-height:0;border:none;padding:0;cursor:pointer;overflow:hidden;background:var(--wb-canvas, #ffffff)}.recp-card__preview:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 26% 18%,rgba(124,58,237,.18),transparent 36%),linear-gradient(135deg,#1e0a4e14,#3b087814);pointer-events:none;z-index:1}.recp-card__preview img{position:relative;z-index:0;display:block;width:100%;height:100%;object-fit:cover;object-position:center center;background:var(--wb-canvas, #ffffff)}.recp-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;gap:14px;color:#ffffffb8;background:radial-gradient(circle at 25% 20%,rgba(124,58,237,.4),transparent 32%),linear-gradient(135deg,#1e0a4e,#290060 58%,#0f172a)}.recp-card__placeholder-icon{width:54px;height:54px;border-radius:50%;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:22px}.recp-card__placeholder-lines{display:flex;flex-direction:column;gap:7px}.recp-card__placeholder-lines span{width:104px;height:9px;border-radius:999px;background:#ffffff2e}.recp-card__placeholder-lines span:nth-child(2){width:80px}.recp-card__placeholder-lines span:nth-child(3){width:120px}.recp-card__duration{position:absolute;right:10px;bottom:10px;z-index:3;border-radius:7px;background:#0f172ac7;color:#fff;font-size:11px;font-weight:900;padding:3px 8px}.recp-card__play{position:absolute;left:50%;top:50%;z-index:3;transform:translate(-50%,-50%);opacity:1;width:46px;height:46px;padding:0;border-radius:999px;background:#ffffff2e;color:transparent;border:1px solid rgba(255,255,255,.34);display:inline-flex;align-items:center;justify-content:center;font-size:0;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}.recp-card__play:before{content:"";display:block;width:0;height:0;margin-left:3px;border-top:9px solid transparent;border-bottom:9px solid transparent;border-left:14px solid #fff}.recp-card__body{position:relative;z-index:2;flex:0 0 auto;display:flex;flex-direction:column;gap:4px;width:100%;min-height:108px;padding:11px 12px 12px;background:#fff;border-top:1px solid rgba(226,232,240,.9)}.recp-card__title{display:block;width:100%;border:none;background:transparent;padding:0;text-align:left;color:#1e293b;font-size:13px;line-height:1.25;font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.recp-card__meta{margin-top:0;color:#94a3b8;font-size:11.5px}.recp-card__actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:auto;padding-top:9px}.recp-card__actions button{height:32px;width:100%;min-width:0}@media(max-width:740px){.recp-panel{width:100vw}.recp-list{grid-template-columns:1fr}}.sp-overlay{position:fixed;inset:0;background:#000000e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:300;display:flex;align-items:center;justify-content:center;animation:sp-overlay-in .26s ease}@keyframes sp-overlay-in{0%{opacity:0}to{opacity:1}}.sp-overlay--closing{animation:sp-overlay-out .2s ease forwards}@keyframes sp-overlay-out{to{opacity:0}}.sp-modal{width:100%;height:100%;max-width:1400px;max-height:100vh;display:flex;flex-direction:column;background:#0d0a1e;overflow:hidden;animation:sp-modal-in .3s cubic-bezier(.34,1.02,.64,1)}@media(min-width:900px){.sp-modal{max-height:96vh;border-radius:20px;box-shadow:0 40px 120px #0009,0 8px 32px #0006}}@keyframes sp-modal-in{0%{opacity:0;transform:scale(.97) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.sp-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.sp-header__title{flex:1;font-size:14px;font-weight:700;color:#ffffffe6;font-family:var(--font, "Nunito Sans", sans-serif);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-header__badge{height:22px;padding:0 8px;border-radius:6px;background:#0d948833;color:#2dd4bf;font-size:10px;font-weight:700;font-family:var(--font-body, "Nunito Sans", sans-serif);display:flex;align-items:center;letter-spacing:.04em;text-transform:uppercase;border:1px solid rgba(13,148,136,.3);flex-shrink:0}.sp-header__close{width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff9;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;flex-shrink:0}.sp-header__close:hover{background:#ffffff24;color:#fff}.sp-body{flex:1;display:flex;min-height:0;overflow:hidden}.sp-player-area{flex:1;display:flex;flex-direction:column;min-width:0;position:relative;background:#0a0818}.sp-replay-stage{flex:1;position:relative;min-height:0;overflow:hidden;background:#fbfbff}.sp-replay-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;background:#fbfbff}.sp-loading,.sp-empty-message{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;color:#ffffff9e;font-size:13px;font-family:var(--font-body, "Nunito Sans", sans-serif);background:radial-gradient(circle at center,#14b8a61a,#0a0818d6)}.sp-empty-message strong{color:#fff;font-size:16px}.sp-empty-message span{max-width:420px;line-height:1.5}.sp-empty-message--error{color:#fca5a5}.sp-empty-message__icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:1px solid rgba(255,255,255,.12)}.sp-loading__spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.08);border-top-color:#0d9488;border-radius:50%;animation:sp-spin .7s linear infinite}@keyframes sp-spin{to{transform:rotate(360deg)}}.sp-replay-hint{position:absolute;left:50%;bottom:18px;transform:translate(-50%);border-radius:999px;padding:8px 14px;background:#0f172aad;color:#ffffffd6;font-size:12px;font-weight:700;font-family:var(--font-body, "Nunito Sans", sans-serif);pointer-events:none}.sp-controls{padding:10px 14px 12px;background:#ffffff08;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;display:flex;flex-direction:column;gap:8px}.sp-audio{width:100%;height:32px;filter:invert(.88) hue-rotate(175deg) saturate(1.2);border-radius:8px;outline:none;accent-color:#0d9488}.sp-controls-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sp-controls-label{font-size:10px;font-weight:700;color:#fff6;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-body, "Nunito Sans", sans-serif)}.sp-speed-group{display:flex;align-items:center;gap:3px;background:#ffffff0f;border-radius:8px;padding:2px}.sp-speed-btn,.sp-secondary-btn,.sp-annotate-btn{height:28px;padding:0 10px;border-radius:7px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#ffffffb3;font-size:11px;font-weight:700;font-family:var(--font-body, "Nunito Sans", sans-serif);cursor:pointer;transition:background .1s,color .1s,border-color .1s}.sp-speed-btn{min-width:36px;border:none;background:transparent}.sp-speed-btn:hover,.sp-secondary-btn:hover,.sp-annotate-btn:hover{background:#ffffff1a;color:#ffffffe6}.sp-speed-btn--active{background:#0d9488;color:#fff}.sp-secondary-btn:disabled{opacity:.4;cursor:not-allowed}.sp-annotate-btn{margin-left:auto}.sp-annotate-btn--active{background:#7c3aed33;border-color:#7c3aed80;color:#c4b5fd}.sp-annotation-canvas{position:absolute;inset:0;z-index:10;pointer-events:none;cursor:crosshair}.sp-annotation-canvas--active{pointer-events:all}.sp-timeline-markers{position:relative;height:6px;background:#ffffff0f;border-radius:3px;margin:0 0 4px;overflow:visible}.sp-timeline-marker{position:absolute;width:8px;height:8px;border-radius:50%;background:#0d9488;top:50%;transform:translate(-50%,-50%);cursor:pointer;border:2px solid #0a0818;z-index:1}.sp-timeline-marker--drawing{background:#7c3aed}.sp-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid rgba(255,255,255,.06);background:#ffffff05;overflow:hidden}.sp-sidebar__header{padding:12px 14px 10px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.sp-sidebar__title{font-size:12px;font-weight:700;color:#fff9;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font, "Nunito Sans", sans-serif)}.sp-comments{flex:1;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:8px 0}.sp-comment{width:100%;display:block;padding:8px 14px;cursor:pointer;border:none;border-left:3px solid transparent;background:transparent;margin-bottom:2px;text-align:left;transition:background 80ms}.sp-comment:hover{background:#ffffff0a}.sp-comment--active{background:#0d948814;border-left-color:#0d9488}.sp-comment__meta{display:flex;align-items:center;gap:6px;margin-bottom:3px}.sp-comment__user{font-size:11px;font-weight:700;color:#ffffffa6;font-family:var(--font, "Nunito Sans", sans-serif)}.sp-comment__time{font-size:10px;color:#0d9488;font-weight:700;font-family:var(--font-body, "Nunito Sans", sans-serif);margin-left:auto;background:#0d948826;padding:1px 5px;border-radius:4px}.sp-comment__text{font-size:12px;color:#ffffff80;line-height:1.5;font-family:var(--font-body, "Nunito Sans", sans-serif)}.sp-comment__drawing-badge{font-size:9px;background:#7c3aed33;color:#c4b5fd;border-radius:4px;padding:1px 5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sp-no-comments{padding:24px 14px;text-align:center;font-size:12px;color:#ffffff40;font-family:var(--font-body, "Nunito Sans", sans-serif);line-height:1.5}.sp-comment-form{padding:10px 12px 12px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;display:flex;flex-direction:column;gap:6px}.sp-comment-form__label{font-size:10px;font-weight:700;color:#ffffff59;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-body, "Nunito Sans", sans-serif)}.sp-comment-form__input{width:100%;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);border-radius:8px;padding:7px 10px;font-size:12px;font-family:var(--font-body, "Nunito Sans", sans-serif);color:#ffffffd9;resize:none;outline:none;box-sizing:border-box}.sp-comment-form__row{display:flex;align-items:center;gap:6px}.sp-comment-form__timestamp{font-size:11px;color:#0d9488;font-weight:700;font-family:var(--font-body, "Nunito Sans", sans-serif);flex:1}.sp-comment-form__submit{height:28px;padding:0 12px;border-radius:7px;border:none;background:#0d9488;color:#fff;font-size:12px;font-weight:700;cursor:pointer}.sp-comment-form__submit:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.sp-sidebar{display:none}.sp-modal{border-radius:0;max-height:100vh}}.sp-audio-warning{border:1px solid rgba(245,158,11,.45);background:#f59e0b1a;color:#fbbf24;border-radius:10px;padding:8px 10px;font-size:12px;line-height:1.45;font-family:var(--font-body, "Nunito Sans", sans-serif)}.topbar{height:var(--topbar-h);background:var(--brand-bg);border-bottom:1px solid var(--brand-border);box-shadow:0 2px 20px #0000004d;transition:background .2s ease,border-color .2s ease}.topbar__logo-name{font-family:"Fraunces",var(--font);font-size:16px;font-weight:600;letter-spacing:-.2px;color:var(--brand-text)}.topbar__logo-sub{font-size:9px;letter-spacing:.14em;color:var(--brand-text-muted);opacity:1}.topbar__timer{font-family:Fraunces,monospace;font-size:14px;font-weight:400;letter-spacing:.08em;padding:6px 14px;border-radius:var(--radius-pill);background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:var(--brand-text-sub);min-width:80px;text-align:center}.topbar__icon-btn{width:34px;height:34px;border-radius:9px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:var(--brand-text-sub);display:flex;align-items:center;justify-content:center;transition:background .14s,color .14s,border-color .14s;font-size:15px}.topbar__icon-btn:hover{background:#ffffff24;color:var(--brand-text);border-color:#ffffff38}.topbar__icon-btn--active,.topbar__icon-btn--recording{background:rgba(var(--teal-rgb,13,148,136),.2);color:var(--brand-accent);border-color:rgba(var(--teal-rgb,13,148,136),.35)}.topbar__mode-switcher{background:#00000040;border-radius:20px;padding:2px;border:1px solid rgba(255,255,255,.1)}.topbar__mode-btn--active{background:var(--brand-accent);box-shadow:0 1px 8px color-mix(in srgb,var(--brand-accent) 50%,transparent)}.icon-rail{background:var(--brand-bg);border-right:1px solid var(--brand-border);transition:background .2s ease}.rail__icon{border-radius:12px;transition:background .14s ease,transform .1s ease}.rail__icon:hover{background:var(--brand-hover);transform:translateY(-1px)}.rail__icon--active{background:var(--brand-active)}.rail__dot{background:var(--brand-accent);width:3px;height:22px;border-radius:0 3px 3px 0}.rail__label{font-size:9px;font-weight:700;letter-spacing:.06em}.page-tab-bar{background:var(--brand-bg);border-bottom:1px solid var(--brand-border);height:36px}.page-tab{border-radius:7px 7px 0 0;border-color:var(--brand-border);background:#ffffff0a;color:var(--brand-text-muted);transition:all .16s ease}.page-tab.is-active{background:var(--wb-bg);color:var(--text);border-color:var(--brand-border);font-weight:700;height:32px}.page-tab__num.is-active{color:var(--brand-accent)}.page-tab-bar__add{border-color:var(--brand-border);color:var(--brand-text-muted)}.page-tab-bar__add:hover{border-color:var(--brand-accent);color:var(--brand-accent);background:var(--wb-bg)}.pen-toolbar{background:var(--brand-bg-deep);border-top:1px solid var(--brand-border);box-shadow:0 -4px 24px #00000059;transition:background .2s ease,border-color .2s ease}.pen-toolbar--pill{background:var(--brand-bg-deep);border:1px solid var(--brand-border);border-radius:var(--radius-pill);box-shadow:0 6px 28px #0006}.pen-toolbar__group{background:var(--brand-hover);border:1px solid var(--brand-border);border-radius:10px;padding:3px}.pen-toolbar__tool-btn{border-radius:8px;color:var(--brand-text-sub);transition:background .12s,color .12s,transform .1s}.pen-toolbar__tool-btn:hover{background:var(--brand-hover);color:var(--brand-text);transform:scale(1.06)}.pen-toolbar__tool-btn.is-active{background:var(--brand-active);color:var(--brand-accent);box-shadow:none}.pen-toolbar__divider{background:var(--brand-border);border-radius:1px;height:22px}.zoom-controls{background:var(--brand-bg-deep);border:1px solid var(--brand-border);border-radius:var(--radius-pill);box-shadow:0 4px 24px #0006;transition:background .2s ease,border-color .2s ease}.zoom-controls__btn:hover{background:var(--brand-hover);color:var(--brand-text)}.zoom-controls__btn--fit:hover{color:var(--brand-accent)}.zoom-controls__level:hover{background:var(--brand-hover);color:var(--brand-text)}.zoom-controls__divider{background:var(--brand-border)}.library-drawer{background:var(--brand-bg);border-right:1px solid var(--brand-border);box-shadow:var(--shadow-lg)}.library-header{background:var(--brand-bg-deep);border-bottom:1px solid var(--brand-border)}.library-header__title{font-family:"Fraunces",var(--font);font-weight:600;font-size:16px;color:var(--brand-text)}.settings-panel__header,.profile-panel__header,.layer-panel__header,.snapshot-gallery__header,.fsp__header,.help-panel__header,.brp__header{background:var(--brand-bg);border-bottom:1px solid var(--brand-border)}.settings-panel__title,.profile-panel__title,.layer-panel__title,.snapshot-gallery__title,.fsp__title,.brp__title{font-family:"Fraunces",var(--font);font-weight:600;color:var(--brand-text)}.settings-panel__header-icon,.profile-panel__header-icon,.layer-panel__header-icon,.snapshot-gallery__header-icon,.brp__header-icon{background:var(--brand-hover);border-radius:var(--radius-sm);color:var(--brand-text)}.settings-panel__close:hover,.profile-panel__close:hover,.layer-panel__close:hover,.snapshot-gallery__close:hover,.fsp__close:hover,.brp__close:hover{background:#ffffff24;color:var(--brand-text)}.settings-panel,.layer-panel,.profile-panel,.help-panel,.brp{background:var(--modal-bg);border-left:1px solid var(--brand-border)}.settings-panel__body,.profile-panel__body,.layer-panel__list,.help-panel__body{background:var(--modal-bg)}.settings-section__header:hover,.settings-section--open .settings-section__header{background:var(--modal-surface2)}.settings-toggle input:checked+.settings-toggle__track{background:var(--teal)}.profile-field__input{background:var(--modal-surface2);border-color:var(--border);color:var(--text)}.profile-field__input:focus{border-color:var(--teal);box-shadow:0 0 0 3px color-mix(in srgb,var(--teal) 15%,transparent)}.profile-btn--primary{background:var(--teal);box-shadow:0 2px 10px color-mix(in srgb,var(--teal) 35%,transparent)}.profile-btn--primary:hover:not(:disabled){background:var(--teal-d, var(--teal));box-shadow:0 4px 16px color-mix(in srgb,var(--teal) 50%,transparent);opacity:1}.profile-btn--outline{border-color:var(--border2);color:var(--text-sub)}.profile-btn--outline:hover:not(:disabled){border-color:var(--teal);color:var(--teal)}.profile-avatar-display{background:var(--brand-bg);border:3px solid var(--brand-accent);box-shadow:0 4px 16px color-mix(in srgb,var(--brand-accent) 25%,transparent)}.profile-avatar-section{background:var(--modal-surface2);border:1px solid var(--border);border-radius:14px}.settings-theme-swatch{border-radius:12px;border:1.5px solid var(--border);background:var(--modal-surface2);transition:border-color .14s,transform .1s,box-shadow .14s}.settings-theme-swatch:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 16px color-mix(in srgb,var(--teal) 20%,transparent)}.settings-theme-swatch--active{border-color:var(--teal);box-shadow:0 0 0 2px color-mix(in srgb,var(--teal) 30%,transparent)}.settings-theme-swatch__tick{background:var(--teal)}.fsp{background:var(--modal-bg);border-left:1px solid var(--brand-border)}.fsp__header{height:60px;background:var(--brand-bg)}.fsp__title{font-family:"Fraunces",var(--font);font-weight:600;font-size:20px}.fsp__badge{background:#ffffff1f;border-radius:var(--radius-pill);color:var(--brand-text-sub)}.library-card{background:var(--brand-bg-deep);border:1.5px solid var(--brand-border);border-radius:var(--radius);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.library-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--card-subject-color, var(--teal)) 60%,var(--brand-border))}.student-card{background:var(--modal-bg);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.student-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--teal)}.snapshot-gallery{background:var(--modal-bg);border-right:1px solid var(--brand-border)}.snapshot-gallery__label-input{background:var(--modal-surface2);border-color:var(--border);color:var(--text)}.snapshot-gallery__save-btn{background:var(--teal)}.snapshot-gallery__save-btn:hover{background:var(--teal-d, var(--teal))}.snapshot-card{background:var(--modal-bg);border-color:var(--border);border-radius:var(--radius)}.snapshot-card:hover{border-color:var(--teal);box-shadow:0 2px 14px color-mix(in srgb,var(--teal) 15%,transparent)}.toast--success{background:var(--teal)}.toast--info{background:var(--surface2);color:var(--text)}.bottom-tab-bar{background:var(--brand-bg);border-top:1px solid var(--brand-border);box-shadow:0 -2px 16px #00000040}.tracker-card:hover{background:var(--modal-surface2);transform:translateY(-2px);box-shadow:var(--shadow)}.theme-strip{z-index:98}.layer-row:hover{background:var(--modal-surface2)}.layer-row.is-active{background:color-mix(in srgb,var(--teal) 8%,var(--modal-bg));border-left-color:var(--teal)}.layer-row.is-selected{background:color-mix(in srgb,var(--blue) 8%,var(--modal-bg));border-left-color:var(--blue)}.layer-row__name{color:var(--text)}.layer-row.is-active .layer-row__name{color:var(--teal)}.help-panel{background:var(--modal-bg);border-left:1px solid var(--brand-border)}.help-panel__header{background:var(--brand-bg);border-bottom:1px solid var(--brand-border)}[data-theme=clean-white] .icon-rail{box-shadow:1px 0 0 var(--border2)}[data-theme=clean-white] .topbar{box-shadow:0 1px 0 var(--border2)}[data-theme=clean-white] .page-tab-bar,[data-theme=clean-white] .theme-strip{border-bottom:1px solid var(--border2)}[data-theme=clean-white] .topbar__icon-btn{border-color:var(--border);background:var(--surface2);color:var(--text-sub)}[data-theme=clean-white] .topbar__icon-btn:hover{background:var(--teal);color:#fff;border-color:var(--teal)}[data-theme=clean-white] .topbar__timer{background:var(--surface2);border-color:var(--border2);color:var(--text-sub)}[data-theme=pure-black] .topbar__icon-btn:hover{background:#c8a96a1f;color:var(--brand-accent);border-color:#c8a96a4d}[data-theme=pure-black] .rail__icon:hover{background:#c8a96a14}[data-theme=pure-black] .rail__icon--active{background:#c8a96a1f}[data-theme=pure-black] .rail__dot{background:var(--brand-accent)}[data-theme=pure-black] .pen-toolbar__tool-btn:hover{background:#c8a96a1a;color:var(--brand-accent)}[data-theme=high-contrast] .topbar__icon-btn{border-color:#ffffff40}[data-theme=high-contrast] .topbar__icon-btn:hover{border-color:var(--teal);background:rgba(var(--teal-rgb,45,212,191),.15);color:var(--teal)}[data-theme=high-contrast] .rail__icon--active{background:#ffe6001f;border:1px solid rgba(255,230,0,.35)}[data-theme=high-contrast] .page-tab.is-active{border-color:var(--teal)}.thp-clock{font-family:"Fraunces",var(--font)!important;font-style:normal}.thp-hdr-title{font-family:"Fraunces",var(--font)!important}.thp-snapshot-val,.thp-hours-bar-val{font-family:"Fraunces",var(--font)!important;font-weight:300!important}.thp-glance-time{font-family:"Fraunces",var(--font)!important;font-weight:400!important}.thp-rating-big{font-family:"Fraunces",var(--font);font-weight:300;font-size:50px;color:var(--amber);line-height:1}.thp-hdr-title,.shp-hdr-title,.hhp-hdr-title,.tdbx-hdr__title,.sdb-hdr-name,.hdb-fhdr-name,.pdb2-hdr-name,.adp-hdr-name,.hap-hdr-name,.sap-hdr-name,.pap-hdr-name{color:var(--brand-text)!important}.thp-hdr-date,.tdbx-hdr__sub,.sdb-hdr-sub,.hdb-fhdr-sub,.pdb2-hdr-sub,.adp-hdr-sub,.hap-hdr-sub,.sap-hdr-sub,.pap-hdr-sub{color:var(--brand-text-sub)!important}.thp-hdr-chip,.shp-hdr-chip,.hhp-hdr-chip,.hdb-fhdr-badge,.pdb2-hdr-badge{background:var(--brand-hover)!important;color:var(--brand-text)!important;border:1px solid var(--brand-border)!important}.tdbx-stats>div,.sdb-grid .sdb-stats>div{border-top-color:var(--teal)}[data-theme=clean-white] .thp-hdr-title,[data-theme=clean-white] .shp-hdr-title,[data-theme=clean-white] .hhp-hdr-title,[data-theme=clean-white] .tdbx-hdr__title,[data-theme=clean-white] .sdb-hdr-name,[data-theme=clean-white] .hdb-fhdr-name,[data-theme=clean-white] .pdb2-hdr-name,[data-theme=clean-white] .adp-hdr-name{color:var(--text)!important}[data-theme=clean-white] .thp-hdr-chip,[data-theme=clean-white] .shp-hdr-chip,[data-theme=clean-white] .hhp-hdr-chip{background:#2563eb14!important;color:var(--teal)!important;border-color:#2563eb2e!important}.tdbx-root>div>div[style*="background:var(--surface)"],.sdb-root>div>div[style*="background:var(--surface)"],.hdb-root>div>div[style*="background:var(--surface)"]{background:var(--surface)!important;border-bottom:1px solid var(--border)!important}.topbar__lock-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--brand-border);background:var(--brand-hover);color:var(--brand-text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s,color .15s}.topbar__lock-btn:hover{background:#ffffff38;border-color:#fff6;color:var(--brand-text)}[data-theme=clean-white] .topbar__lock-btn{border-color:var(--border2);background:var(--surface2);color:var(--text-sub)}[data-theme=clean-white] .topbar__lock-btn:hover{background:var(--teal);border-color:var(--teal);color:#fff}[data-theme=pure-black] .topbar__lock-btn{border-color:#c8a96a33;background:#c8a96a0f;color:var(--brand-text-muted)}[data-theme=pure-black] .topbar__lock-btn:hover{background:#c8a96a29;border-color:#c8a96a66;color:var(--brand-accent)}.topbar__timer{letter-spacing:0!important;min-width:76px;text-align:center;display:inline-flex;align-items:center;justify-content:center}
