@font-face{font-family:Inter;src:url(/fonts/inter/Inter18pt-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/fonts/inter/Inter18pt-Medium.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/fonts/inter/Inter18pt-SemiBold.woff2) format("woff2");font-weight:600;font-style:normal;font-display:optional}@font-face{font-family:Inter;src:url(/fonts/inter/Inter18pt-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:optional}@font-face{font-family:Inter;src:url(/fonts/inter/Inter18pt-ExtraBold.woff2) format("woff2");font-weight:800;font-style:normal;font-display:optional}@font-face{font-family:Outfit;src:url(/fonts/outfit/Outfit-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:optional}@font-face{font-family:Outfit;src:url(/fonts/outfit/Outfit-ExtraBold.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap}@font-face{font-family:Outfit;src:url(/fonts/outfit/Outfit-Black.woff2) format("woff2");font-weight:900;font-style:normal;font-display:optional}:root{--blue-950: #0A1628;--blue-900: #0F2044;--blue-800: #1A3A6E;--blue-700: #1D4ED8;--blue-600: #2563EB;--blue-500: #3B82F6;--blue-400: #60A5FA;--blue-300: #93C5FD;--blue-200: #BFDBFE;--blue-100: #DBEAFE;--blue-50: #EFF6FF;--surface-0: #FFFFFF;--surface-1: #F8FAFF;--surface-2: #F1F5FD;--surface-3: #E8EEFA;--surface-4: #D5E3FA;--border: rgba(37, 99, 235, .12);--border-md: rgba(37, 99, 235, .25);--border-focus: rgba(37, 99, 235, .55);--text-primary: #0F172A;--text-secondary: #334155;--text-muted: #64748B;--text-on-blue: #FFFFFF;--accent: #2563EB;--accent-dim: rgba(37, 99, 235, .08);--accent-glow: rgba(37, 99, 235, .25);--accent-light: #DBEAFE;--success: #10B981;--danger: #EF4444;--warning: #F59E0B;--info: #3B82F6;--conflict-bg: rgba(239, 68, 68, .08);--conflict-border: #EF4444;--conflict-text: #B91C1C;--conflict-stripe: rgba(239, 68, 68, .12);--sidebar-w: 320px;--header-h: 56px;--font: "Inter", system-ui, -apple-system, sans-serif;--font-disp: "Outfit", "Inter", sans-serif;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 24px;--r-full: 9999px;--sh-sm: 0 1px 4px rgba(0, 0, 0, .06);--sh-md: 0 4px 20px rgba(0, 0, 0, .08);--sh-lg: 0 8px 40px rgba(0, 0, 0, .12);--sh-glow: 0 0 24px var(--accent-glow);--sh-blue: 0 4px 16px rgba(37, 99, 235, .18);--fast: .12s cubic-bezier(.4, 0, .2, 1);--normal: .22s cubic-bezier(.4, 0, .2, 1);--slow: .38s cubic-bezier(.4, 0, .2, 1);color-scheme:light}[data-theme=dark]{--surface-0: #0B1120;--surface-1: #101828;--surface-2: #162032;--surface-3: #1E2D42;--surface-4: #263650;--border: rgba(96, 165, 250, .12);--border-md: rgba(96, 165, 250, .25);--border-focus: rgba(96, 165, 250, .55);--text-primary: #E8F0FE;--text-secondary: #93C5FD;--text-muted: #4B6A94;--text-on-blue: #FFFFFF;--accent: #3B82F6;--accent-dim: rgba(59, 130, 246, .12);--accent-glow: rgba(59, 130, 246, .3);--accent-light: rgba(59, 130, 246, .15);--conflict-bg: rgba(239, 68, 68, .12);--conflict-border: #F87171;--conflict-text: #FCA5A5;--conflict-stripe: rgba(239, 68, 68, .08);color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font);background:var(--surface-0);color:var(--text-primary);min-height:100dvh;overflow:hidden;transition:background var(--normal),color var(--normal)}#root{height:100dvh;display:flex;flex-direction:column}button{font-family:var(--font);cursor:pointer}input,textarea{font-family:var(--font)}select{font-family:var(--font);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--surface-0);color:var(--text-primary);border:1px solid var(--border-md);border-radius:var(--r-md);padding:10px 36px 10px 14px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--fast) ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px}[data-theme=dark] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}select:hover{border-color:var(--border-focus)}select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}:root{color-scheme:light}[data-theme=dark]{color-scheme:dark}::selection{background:var(--blue-200);color:var(--blue-900)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.app-layout{display:flex;height:100dvh;overflow:hidden;width:100%;position:relative;background:var(--surface-0)}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);height:100dvh;background:var(--surface-1);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;position:relative;z-index:20}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--surface-0)}.sidebar{transition:width var(--fast),min-width var(--fast)}.sidebar--collapsed{width:0!important;min-width:0!important;border-right-color:transparent;overflow:hidden}.sidebar-logo{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--surface-1)}.logo-mark{display:flex;align-items:center;gap:10px}.logo-icon{width:36px;height:36px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--blue-600),var(--blue-400));display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:var(--sh-blue);flex-shrink:0}.logo-text{font-family:var(--font-disp);font-weight:800;font-size:1.2rem;background:linear-gradient(135deg,var(--blue-600),var(--blue-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.logo-sub{font-size:.62rem;color:var(--text-muted);margin-top:-2px;font-weight:500}.theme-toggle{width:32px;height:32px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast);flex-shrink:0}.theme-toggle:hover{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent)}.sidebar-search{padding:12px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-career-name{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;color:var(--accent);margin-bottom:10px;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-career-name span{overflow:hidden;text-overflow:ellipsis}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:9px 12px 9px 34px;background:var(--surface-0);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:.85rem;transition:border-color var(--fast),box-shadow var(--fast)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.career-list{flex:1;overflow-y:auto;padding:8px}.career-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:2px;border-radius:var(--r-md);border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:500;text-align:left;transition:all var(--fast);line-height:1.3}.career-item:hover{background:var(--accent-dim);border-color:var(--border);color:var(--text-primary)}.career-item.active{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent);font-weight:600}.career-code-badge{font-size:.62rem;font-weight:700;background:var(--surface-3);color:var(--text-muted);padding:2px 6px;border-radius:var(--r-sm);flex-shrink:0;font-variant-numeric:tabular-nums;border:1px solid var(--border);letter-spacing:.02em}.level-tabs-wrap{background:var(--surface-1);border-bottom:1px solid var(--border);flex-shrink:0}.level-tabs-label{display:block;padding:8px 12px 0;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.level-tabs{padding:8px 12px;border-bottom:1px solid var(--border);display:flex;gap:4px;flex-wrap:wrap;flex-shrink:0;background:var(--surface-1)}.level-tabs-wrap .level-tabs{border-bottom:none;padding-top:6px;background:transparent}.level-tab{padding:5px 12px;border-radius:var(--r-full);border:1.5px solid transparent;background:var(--surface-3);color:var(--text-muted);font-size:.74rem;font-weight:700;letter-spacing:.03em;transition:all var(--fast)}.level-tab:hover{border-color:var(--border-md);color:var(--text-secondary)}.level-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--sh-blue)}.subject-list{flex:1;overflow-y:auto;padding:8px}.subject-item{border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);margin-bottom:5px;overflow:hidden;transition:border-color var(--fast),box-shadow var(--fast)}.subject-item.has-selection{border-color:var(--border-md);box-shadow:var(--sh-sm)}.subject-item:hover{border-color:var(--border-md)}.subject-header{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:transparent;border:none;text-align:left;color:var(--text-primary);font-size:.82rem;font-weight:600;cursor:pointer;transition:background var(--fast);line-height:1.3}.subject-header:hover{background:var(--accent-dim)}.subject-selected-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.subject-chevron{margin-left:auto;flex-shrink:0;color:var(--text-muted);transition:transform var(--fast)}@keyframes groups-open{0%{opacity:0;transform:translateY(-8px);clip-path:inset(0 0 100% 0)}to{opacity:1;transform:translateY(0);clip-path:inset(0 0 0% 0)}}.groups-list{padding:0 8px 8px;display:flex;flex-direction:column;gap:4px;animation:groups-open .22s cubic-bezier(.16,1,.3,1)}.group-btn{width:100%;display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:var(--r-sm);border:1.5px solid transparent;background:var(--surface-1);text-align:left;transition:all var(--fast);cursor:pointer;position:relative}.group-btn:hover{background:var(--surface-2);border-color:var(--border-md)}.group-btn.selected{border-color:var(--accent);background:var(--accent-dim)}.group-btn.conflict{border-color:var(--conflict-border)!important;background:var(--conflict-bg)!important;position:relative;overflow:hidden}.group-btn.conflict:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 5px,var(--conflict-stripe) 5px,var(--conflict-stripe) 6px);pointer-events:none}.group-check{width:16px;height:16px;border-radius:4px;border:2px solid var(--border-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;transition:all var(--fast);background:transparent;position:relative;z-index:1}.group-btn.selected .group-check{background:var(--accent);border-color:var(--accent)}.group-info{flex:1;min-width:0;position:relative;z-index:1}.group-code{font-size:.75rem;font-weight:700;color:var(--text-primary)}.group-teacher{font-size:.7rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-schedule-preview{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.time-chip{font-size:.62rem;padding:2px 6px;border-radius:var(--r-full);background:var(--surface-3);color:var(--text-secondary);font-weight:600;border:1px solid var(--border)}.time-chip.theory{border-color:var(--blue-400);color:var(--blue-600);background:var(--blue-50)}[data-theme=dark] .time-chip.theory{color:var(--blue-300);background:#3b82f61a}.time-chip.practice{border-color:#10b98166;color:#059669;background:#10b98114}[data-theme=dark] .time-chip.practice{color:#34d399;background:#10b9811a}.conflict-badge{display:inline-flex;align-items:center;gap:3px;font-size:.6rem;padding:2px 7px;border-radius:var(--r-full);background:#ef44441f;color:var(--conflict-text);font-weight:700;border:1px solid rgba(239,68,68,.3);animation:conflict-pulse 2s ease infinite}@keyframes conflict-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 3px #ef444426}}.conflict-details{margin-top:4px;font-size:.62rem;color:var(--conflict-text);font-weight:600;display:flex;flex-wrap:wrap;gap:3px}.conflict-with-chip{background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--r-full);padding:1px 6px;font-size:.6rem;font-weight:700}.selected-panel{border-top:1px solid var(--border);padding:10px 12px;background:var(--surface-1);flex-shrink:0;max-height:148px;overflow-y:auto}.selected-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.panel-title{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.selected-chip{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--r-sm);background:var(--surface-2);border:1px solid var(--border);margin-bottom:4px;font-size:.75rem}.selected-chip-color{width:8px;height:8px;border-radius:50%;flex-shrink:0}.selected-chip-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-weight:600}.selected-chip-group{color:var(--text-muted);font-weight:500;flex-shrink:0}.selected-chip-remove{width:16px;height:16px;border-radius:3px;border:none;background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;font-size:.7rem;transition:all var(--fast)}.selected-chip-remove:hover{background:var(--danger);color:#fff}.slot-section{display:flex;flex-direction:column;gap:4px}.slot-section-label{display:flex;align-items:center;gap:5px;font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:4px 6px 2px}.slot-label-theory{color:var(--blue-500, #3b82f6)}.slot-label-lab{color:#059669}[data-theme=dark] .slot-label-theory{color:var(--blue-300, #93c5fd)}[data-theme=dark] .slot-label-lab{color:#34d399}.slot-divider{display:flex;align-items:center;gap:8px;padding:6px 4px}.slot-divider span:first-child,.slot-divider span:last-child{flex:1;height:1px;background:var(--border)}.slot-divider-text{font-size:.58rem;color:var(--text-muted);white-space:nowrap;font-weight:600;flex:0!important;height:auto!important;background:none!important}.career-tabs-row{display:flex;gap:4px;padding:6px 8px;border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0;background:var(--surface-1);scrollbar-width:none}.career-tabs-row::-webkit-scrollbar{display:none}.career-tab-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.73rem;font-weight:600;white-space:nowrap;flex-shrink:0;transition:all var(--fast);cursor:pointer}.career-tab-btn:hover{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent)}.career-tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:var(--sh-blue)}.career-tab-name{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.career-tab-remove{font-size:.85rem;line-height:1;color:inherit;opacity:.6;padding:0 2px;border-radius:3px;transition:all var(--fast);cursor:pointer}.career-tab-btn.active .career-tab-remove:hover{background:#ffffff40;opacity:1}.career-tab-btn:not(.active) .career-tab-remove:hover{background:#ef444426;color:var(--danger);opacity:1}.add-career-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:calc(100% - 24px);margin:6px 12px 4px;padding:9px 14px;border-radius:var(--r-md);border:1.5px dashed var(--border-md);background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--fast);flex-shrink:0;text-align:center}.add-career-btn:hover{background:var(--accent-dim);border-color:var(--accent);border-style:solid;color:var(--accent)}.add-career-btn svg{flex-shrink:0}.back-home-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:calc(100% - 24px);margin:0 12px 20px;padding:9px 14px;border-radius:var(--r-md);border:none;background:var(--accent);color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;transition:all var(--fast);flex-shrink:0;text-align:center;box-shadow:0 2px 8px var(--accent-glow)}.back-home-btn:hover{filter:brightness(.88);box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-1px)}.back-home-btn svg{flex-shrink:0;opacity:.9}.career-modal-overlay{position:fixed;inset:0;z-index:1000;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.career-modal{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg, 12px);width:100%;max-width:440px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;animation:slide-up .18s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.career-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.career-modal-title{font-size:.9rem;font-weight:700;color:var(--text-primary)}.career-modal-close{width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast)}.career-modal-close:hover{background:#ef44441f;border-color:#ef44444d;color:var(--danger)}.career-modal-search-wrap{position:relative;padding:10px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.career-modal-search-wrap svg{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.career-modal-search{width:100%;padding:8px 12px 8px 34px;background:var(--surface-0);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:.85rem;transition:border-color var(--fast),box-shadow var(--fast);box-sizing:border-box}.career-modal-search::placeholder{color:var(--text-muted)}.career-modal-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.career-modal-list{flex:1;overflow-y:auto;padding:8px}.career-modal-section-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:8px 8px 4px 12px;border-left:3px solid var(--border-focus);margin:6px 0 4px}.career-modal-item{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:500;text-align:left;cursor:pointer;transition:all var(--fast)}.career-modal-item:hover:not(:disabled){background:var(--accent-dim);border-color:var(--border);color:var(--text-primary)}.career-modal-item.already-added{opacity:.5;cursor:default}.career-modal-emoji{font-size:1rem;flex-shrink:0;width:20px;text-align:center}.career-modal-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.career-modal-badge{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:var(--r-full);background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-focus);flex-shrink:0}.career-modal-limit{padding:10px 16px;font-size:.75rem;color:var(--text-muted);text-align:center;border-top:1px solid var(--border);flex-shrink:0}.confirm-modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;z-index:99999;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fade-in .15s ease}.confirm-modal{background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-xl);width:100%;max-width:360px;padding:28px 24px 22px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 24px 64px #0000004d,0 4px 16px #00000026;animation:confirm-pop .2s cubic-bezier(.34,1.56,.64,1)}@keyframes confirm-pop{0%{opacity:0;transform:scale(.88) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-modal-icon-wrap{margin-bottom:16px}.confirm-modal-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center}.confirm-modal-icon--danger{background:#ef44441f;color:#ef4444;box-shadow:0 0 0 6px #ef444412}.confirm-modal-icon--primary{background:#3b82f61f;color:var(--accent);box-shadow:0 0 0 6px #3b82f612}.confirm-modal-title{margin:0 0 8px;font-size:1.05rem;font-weight:700;color:var(--text-primary);line-height:1.3}.confirm-modal-highlight{display:inline-block;margin-bottom:10px;padding:3px 12px;border-radius:var(--r-full);background:var(--accent-dim);color:var(--accent);font-size:.78rem;font-weight:700;letter-spacing:.03em;border:1px solid var(--border-focus);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.confirm-modal-message{margin:2px 0 22px;font-size:.84rem;color:var(--text-secondary);line-height:1.55}.confirm-modal-message strong{color:var(--text-primary)}.confirm-modal-actions{display:flex;gap:10px;width:100%}.confirm-modal-btn{flex:1;padding:10px 0;border-radius:var(--r-md);font-size:.88rem;font-weight:600;cursor:pointer;transition:all var(--fast);border:1.5px solid transparent;letter-spacing:.01em}.confirm-modal-btn--cancel{background:var(--surface-2);color:var(--text-secondary);border-color:var(--border)}.confirm-modal-btn--cancel:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-md)}.confirm-modal-btn--danger{background:#ef4444;color:#fff;font-weight:700;box-shadow:0 2px 8px #ef44444d}.confirm-modal-btn--danger:hover{background:#dc2626;box-shadow:0 4px 14px #ef444473;transform:translateY(-1px)}.confirm-modal-btn--danger:active{transform:translateY(0);box-shadow:0 2px 6px #ef444440}.confirm-modal-btn--primary{background:var(--accent);color:#fff;font-weight:700;box-shadow:0 2px 8px var(--accent-glow)}.confirm-modal-btn--primary:hover{filter:brightness(.9);box-shadow:0 4px 14px var(--accent-glow);transform:translateY(-1px)}[data-theme=dark] .confirm-modal{box-shadow:0 24px 64px #0000008c,0 4px 16px #0000004d}.sidebar--compact .subject-row{padding:5px 8px 5px 10px}.sidebar--compact .subject-name{font-size:.78rem}.sidebar--compact .subject-semester{font-size:.65rem}.sidebar--compact .group-btn{padding:5px 8px;font-size:.74rem}.sidebar--compact .groups-list{padding:0 6px 6px;gap:3px}.sidebar--compact .sidebar-career-name{font-size:.8rem}.sidebar--compact .sidebar-search input{padding:5px 10px 5px 30px;font-size:.82rem}.sidebar--compact .selected-chip{padding:3px 6px;font-size:.7rem}.top-bar{position:relative;height:var(--header-h);border-bottom:1px solid var(--border);background:var(--surface-0);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;gap:8px;padding:0 12px;flex-shrink:0;z-index:100;overflow-x:clip}.top-bar-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1 1 0;overflow:hidden}.top-bar-right{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto}.career-name{font-family:var(--font-disp);font-size:1rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.semester-badge{font-size:.7rem;font-weight:700;background:var(--blue-100);color:var(--blue-700);padding:3px 10px;border-radius:var(--r-full);border:1px solid var(--blue-200);white-space:nowrap;flex-shrink:1}[data-theme=dark] .semester-badge{background:#3b82f626;color:var(--blue-300);border-color:#3b82f640}.top-bar-action{display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}.view-toggle{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;gap:2px;flex-shrink:0}.view-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:600;white-space:nowrap;transition:all var(--fast);cursor:pointer}.view-btn.active{background:var(--accent);color:#fff;box-shadow:var(--sh-blue)}@media(max-width:1100px){.semester-badge{display:none}.top-bar-action .btn-label:not([data-keep]){display:none}}@media(max-width:960px){.top-bar{padding:0 10px;gap:6px}.top-bar-right{gap:4px}.top-bar-action .btn-label,.view-btn .btn-label{display:none}.top-bar-action{padding:7px 8px}.view-btn{padding:5px 8px;font-size:0}.view-btn svg{display:block}.topbar-donate-btn .btn-label{display:none}}@media(max-width:820px){.topbar-donate-btn{padding:4px 8px}}.topbar-clear-confirm{display:flex;align-items:center;gap:6px;animation:fade-in-right .15s ease}.topbar-clear-confirm-text{font-size:.78rem;font-weight:600;color:var(--danger, #ef4444);white-space:nowrap}@keyframes fade-in-right{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.user-btn{width:32px;height:32px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-1);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast);flex-shrink:0}.user-btn:hover{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent)}.user-avatar-btn{width:32px;height:32px;border-radius:var(--r-md);border:1.5px solid var(--accent);background:var(--accent-dim);color:var(--accent);font-size:.75rem;font-weight:800;letter-spacing:.03em;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast);flex-shrink:0;box-sizing:border-box}.user-avatar-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-glow)}.user-dropdown-wrap{position:relative}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--surface-0);border:1px solid var(--border-md);border-radius:var(--r-lg);box-shadow:var(--sh-lg);z-index:9998;overflow:hidden;animation:auth-dropdown-in var(--fast) ease}@keyframes auth-dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.user-dropdown-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.user-dropdown-avatar{width:38px;height:38px;border-radius:var(--r-md);background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);font-size:.85rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-dropdown-info{overflow:hidden}.user-dropdown-name{font-size:.85rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-email{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-meta{padding:10px 16px;display:flex;flex-wrap:wrap;gap:4px;border-bottom:1px solid var(--border)}.user-dropdown-badge{font-size:.68rem;font-weight:600;padding:2px 8px;border-radius:var(--r-full);background:var(--accent-dim);color:var(--accent);border:1px solid rgba(37,99,235,.18)}[data-theme=dark] .user-dropdown-badge{border-color:#3b82f640}.user-dropdown-actions{padding:6px}.user-dropdown-item{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-md);border:none;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--fast);text-align:left}.user-dropdown-item:hover{background:var(--surface-2);color:var(--text-primary)}.user-dropdown-item--danger{color:var(--danger)}.user-dropdown-item--danger:hover{background:#ef444414;color:var(--danger)}.modal-window.auth-modal{position:relative;z-index:1;max-width:820px;width:92vw;max-height:calc(100vh - 48px);overflow:hidden;display:flex;flex-direction:column}.auth-modal-layout{display:grid;grid-template-columns:1fr 1fr;flex:1;min-height:0;overflow:hidden}.auth-modal-image-panel{overflow:hidden;position:relative;min-height:280px}.auth-modal-image{width:100%;height:100%;object-fit:cover;display:block}.auth-modal-form-panel{overflow-y:auto;overscroll-behavior:contain;display:flex;flex-direction:column}@media(max-width:640px){.auth-modal-backdrop{width:100vw;height:100dvh;min-height:100dvh;display:grid;place-items:center;padding:max(14px,env(safe-area-inset-top)) 14px max(14px,env(safe-area-inset-bottom));overflow-y:auto;overscroll-behavior:contain}.modal-window.auth-modal{max-width:420px;width:min(420px,calc(100vw - 28px));max-height:calc(100dvh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));margin:auto;transform:translateZ(0)}.auth-modal-layout{grid-template-columns:1fr}.auth-modal-image-panel{display:none}.modal-window.auth-modal .modal-header{padding:18px 20px 14px}.modal-window.auth-modal .auth-tabs{padding:0 20px}.modal-window.auth-modal .auth-form-body{padding:18px 20px 20px}}.auth-tabs{display:flex;padding:0 24px;gap:0;border-bottom:1px solid var(--border);background:var(--surface-1)}.auth-tab{flex:1;padding:12px 8px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--fast);margin-bottom:-1px}.auth-tab:hover{color:var(--text-primary)}.auth-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.auth-form-body{padding:20px 24px;display:flex;flex-direction:column;gap:12px}.auth-input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:420px){.auth-input-row{grid-template-columns:1fr}}.auth-field{display:flex;flex-direction:column;gap:4px}.auth-label{font-size:.75rem;font-weight:600;color:var(--text-secondary)}.auth-input{padding:9px 12px;border-radius:var(--r-md);border:1px solid var(--border-md);background:var(--surface-1);color:var(--text-primary);font-size:.85rem;font-family:var(--font);outline:none;transition:border-color var(--fast),box-shadow var(--fast);width:100%;box-sizing:border-box}.auth-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.auth-input::placeholder{color:var(--text-muted);opacity:.7}.auth-input--error{border-color:var(--danger)}.auth-input--error:focus{box-shadow:0 0 0 3px #ef444426}.auth-error{display:flex;align-items:flex-start;gap:7px;padding:9px 12px;border-radius:var(--r-md);background:#ef444414;border:1px solid rgba(239,68,68,.25);color:var(--danger);font-size:.8rem;line-height:1.4}.auth-submit{width:100%;padding:10px;justify-content:center;font-size:.88rem;margin-top:2px}.auth-footer{padding:14px 24px;border-top:1px solid var(--border);background:var(--surface-1);border-bottom-left-radius:var(--r-lg);border-bottom-right-radius:var(--r-lg);font-size:.75rem;color:var(--text-muted);text-align:center}.auth-switch-link{background:none;border:none;color:var(--accent);font-size:inherit;font-weight:600;cursor:pointer;padding:0}.auth-switch-link:hover{text-decoration:underline}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input--with-eye{padding-right:36px}.auth-eye-btn{position:absolute;right:10px;background:none;border:none;padding:0;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:color var(--fast);line-height:1}.auth-eye-btn:hover{color:var(--text-secondary)}.auth-input--encrypting{border-color:var(--accent)!important;animation:auth-encrypt-pulse 1.8s ease infinite}@keyframes auth-encrypt-pulse{0%,to{box-shadow:0 0 0 3px #6366f11f}50%{box-shadow:0 0 0 3px #6366f147,0 0 10px #6366f12e}}.auth-input--encrypted{border-color:#22c55e!important;box-shadow:0 0 0 3px #22c55e1f!important;transition:border-color .3s ease,box-shadow .3s ease}.auth-encrypting{display:flex;align-items:center;gap:4px;margin-top:5px;font-size:.68rem;font-weight:600;color:var(--accent);opacity:.85;animation:auth-fade-in .25s ease}@keyframes auth-fade-in{0%{opacity:0;transform:translateY(-3px)}to{opacity:.85;transform:translateY(0)}}.auth-encrypting--done{color:#22c55e}[data-theme=dark] .auth-encrypting--done{color:#4ade80}.auth-encrypting-dots span{opacity:0;animation:auth-dot-blink 1.4s ease infinite}.auth-encrypting-dots span:nth-child(2){animation-delay:.22s}.auth-encrypting-dots span:nth-child(3){animation-delay:.44s}@keyframes auth-dot-blink{0%,to{opacity:0}50%{opacity:1}}.auth-pw-strength{display:flex;flex-direction:column;gap:3px;margin-top:6px;animation:auth-fade-in .2s ease}.auth-pw-req{display:flex;align-items:center;gap:5px;font-size:.68rem;font-weight:500;color:var(--text-muted);transition:color var(--fast)}.auth-pw-req--ok{color:#22c55e}[data-theme=dark] .auth-pw-req--ok{color:#4ade80}.auth-input--ok{border-color:#22c55e}.auth-input--ok:focus{box-shadow:0 0 0 3px #22c55e26}.auth-pw-mismatch{margin-top:4px;font-size:.68rem;color:var(--danger);font-weight:500}.auth-spin{animation:auth-spinner .7s linear infinite}@keyframes auth-spinner{to{transform:rotate(360deg)}}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--surface-0);padding:24px 16px}.auth-page-card{width:100%;max-width:400px;background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-lg);box-shadow:var(--sh-lg);overflow:hidden;display:flex;flex-direction:column}.auth-page-logo{display:flex;align-items:center;gap:10px;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.auth-page-brand{font-size:1rem;font-weight:800;color:var(--text-primary)}.auth-page-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.auth-page-subtitle{font-size:.82rem;color:var(--text-secondary);margin:0}.auth-page-footer{padding:14px 24px;border-top:1px solid var(--border);background:var(--surface-0);text-align:center;font-size:.78rem;border-bottom-left-radius:var(--r-lg);border-bottom-right-radius:var(--r-lg)}.auth-page-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto}.auth-page-icon--success{background:#22c55e1f;border:2px solid #22c55e}.auth-page-icon--error{background:#ef444414;border:2px solid var(--danger)}.auth-page-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:auth-spinner .7s linear infinite;margin:0 auto}.vb-banner{position:sticky;top:0;left:0;right:0;z-index:9990;background:linear-gradient(90deg,#d97706,#b45309);color:#fff;font-size:.8rem;font-weight:500;box-shadow:0 2px 12px #0000002e;animation:vb-slide-down .35s cubic-bezier(.22,1,.36,1)}.vb-banner--urgent{background:linear-gradient(90deg,#dc2626,#b91c1c);animation:vb-pulse 2s ease infinite,vb-slide-down .35s cubic-bezier(.22,1,.36,1)}@keyframes vb-slide-down{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes vb-pulse{0%,to{opacity:1}50%{opacity:.92}}.vb-banner-inner{max-width:960px;margin:0 auto;padding:8px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.vb-banner-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:wrap}.vb-banner-text{opacity:.95;white-space:nowrap}@media(max-width:480px){.vb-banner-text{display:none}}.vb-countdown{display:flex;align-items:center;gap:2px;font-size:.82rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em}.vb-countdown-seg{background:#00000040;border-radius:4px;padding:1px 5px;min-width:26px;text-align:center;transition:background .3s}.vb-countdown-colon{opacity:.7;font-weight:800;margin:0 1px;animation:vb-colon-blink 1s step-end infinite}@keyframes vb-colon-blink{0%,to{opacity:.7}50%{opacity:.2}}.vb-banner-btn{flex-shrink:0;padding:6px 16px;border-radius:999px;border:none;background:#fffffff5;color:#92400e;font-size:.78rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s,transform .12s,box-shadow .15s;white-space:nowrap;box-shadow:0 1px 6px #0000002e}.vb-banner-btn:hover{background:#fff;color:#78350f;transform:scale(1.03);box-shadow:0 2px 10px #00000038}.vb-banner--urgent .vb-banner-btn{color:#991b1b}.vb-banner--urgent .vb-banner-btn:hover{color:#7f1d1d}.vb-overlay{position:fixed;inset:0;z-index:10000;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;animation:vb-fade-in .2s ease}@keyframes vb-fade-in{0%{opacity:0}to{opacity:1}}.vb-modal{position:relative;width:100%;max-width:400px;background:var(--surface-1, #fff);border:1px solid var(--border-md, #e5e7eb);border-radius:20px;box-shadow:0 24px 60px #00000038;padding:32px 28px 28px;display:flex;flex-direction:column;align-items:center;gap:0;animation:vb-modal-in .32s cubic-bezier(.22,1,.36,1)}@keyframes vb-modal-in{0%{transform:translateY(20px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.vb-modal-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;border:none;background:var(--surface-2, #f3f4f6);color:var(--text-muted, #9ca3af);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s}.vb-modal-close:hover{background:var(--surface-3, #e5e7eb);color:var(--text-primary, #111)}.vb-modal-icon-wrap{margin-bottom:16px}.vb-modal-icon{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;display:flex;align-items:center;justify-content:center;color:#b45309;animation:vb-icon-bounce 2.4s ease-in-out infinite}@keyframes vb-icon-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.vb-modal-title{font-size:1.15rem;font-weight:800;color:var(--text-primary, #111);margin:0 0 8px;text-align:center}.vb-modal-sub{font-size:.82rem;color:var(--text-secondary, #6b7280);text-align:center;line-height:1.55;margin:0 0 14px}.vb-modal-sub strong{color:var(--text-primary, #111);font-weight:600}.vb-modal-timer{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:#b45309;font-size:.72rem;font-weight:700;font-variant-numeric:tabular-nums;margin-bottom:22px}.vb-modal-timer--urgent{background:#dc262614;border-color:#dc26264d;color:#dc2626;animation:vb-pulse 1.5s ease infinite}.vb-otp-row{display:flex;gap:8px;margin-bottom:14px}.vb-otp-box{width:44px;height:52px;border-radius:10px;border:2px solid var(--border-md, #d1d5db);background:var(--surface-0, #f9fafb);color:var(--text-primary, #111);font-size:1.4rem;font-weight:700;text-align:center;outline:none;transition:border-color .15s,box-shadow .15s,background .15s;caret-color:transparent}.vb-otp-box:focus{border-color:var(--border-focus, #6366f1);box-shadow:0 0 0 3px var(--accent-glow, rgba(99,102,241,.15));background:var(--surface-1, #fff)}.vb-otp-box--filled{border-color:var(--accent, #6366f1);background:var(--accent-dim, rgba(99,102,241,.06))}.vb-otp-box--error{border-color:var(--danger, #ef4444)!important;animation:vb-shake .4s cubic-bezier(.36,.07,.19,.97)}@keyframes vb-shake{0%,to{transform:translate(0)}20%{transform:translate(-5px)}60%{transform:translate(5px)}80%{transform:translate(-3px)}}.vb-otp-box:disabled{opacity:.55;cursor:not-allowed}.vb-error{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--r-md, 8px);background:#ef444412;border:1px solid rgba(239,68,68,.22);color:var(--danger, #ef4444);font-size:.78rem;font-weight:500;width:100%;margin-bottom:12px;animation:vb-fade-in .2s ease}.vb-verify-btn{width:100%;padding:12px;border-radius:12px;border:none;background:var(--accent, #6366f1);color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px}.vb-verify-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.vb-verify-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.vb-resend-row{display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-muted, #9ca3af);margin-bottom:8px}.vb-resend-btn{background:none;border:none;color:var(--accent, #6366f1);font-size:.75rem;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;transition:opacity .15s}.vb-resend-btn:hover:not(:disabled){opacity:.75}.vb-resend-btn:disabled{opacity:.5;cursor:not-allowed}.vb-resend-wait{color:var(--text-muted, #9ca3af);font-size:.75rem;font-weight:500}.vb-later-btn{background:none;border:none;color:var(--text-muted, #9ca3af);font-size:.72rem;cursor:pointer;padding:0;transition:color .15s}.vb-later-btn:hover{color:var(--text-secondary, #6b7280)}.vb-success{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 0}.vb-success-ring{width:68px;height:68px;border-radius:50%;background:#22c55e1a;border:2.5px solid #22c55e;display:flex;align-items:center;justify-content:center;animation:vb-success-pop .5s cubic-bezier(.22,1,.36,1)}@keyframes vb-success-pop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.grid-wrap{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.grid-outer-scroll{flex:1;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}.grid-scroll-container{flex:1;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;min-height:0}.grid-header{display:grid;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--surface-1);position:sticky;top:0;z-index:10}.grid-corner{border-right:1px solid var(--border);display:flex;align-items:center;justify-content:center}.day-col-header{padding:10px 8px;text-align:center;border-left:1px solid var(--border)}.day-col-name{font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.day-col-dots{display:flex;justify-content:center;gap:3px;margin-top:4px}.day-dot{width:5px;height:5px;border-radius:50%}.grid-body{flex:1;position:relative}.grid-inner{display:grid;position:relative}.grid-bg-watermark{position:absolute;inset:0;z-index:0;pointer-events:none;background-repeat:no-repeat;background-position:center;background-size:min(62%,520px);opacity:.15}.hour-col{position:sticky;left:0;border-right:1px solid var(--border);background:var(--surface-1);z-index:5;flex-shrink:0}.hour-label{position:absolute;right:8px;font-size:.63rem;color:var(--text-muted);font-variant-numeric:tabular-nums;transform:translateY(-50%);font-weight:600;line-height:1;white-space:nowrap}.day-col-body{position:relative;border-left:1px solid var(--border)}.hour-line{position:absolute;left:0;right:0;height:1px;background:var(--border);pointer-events:none}.current-time-line{position:absolute;left:0;right:0;height:0;z-index:12;pointer-events:none}.current-time-line__track{position:absolute;left:0;right:0;top:0;height:2px;background:var(--danger);box-shadow:0 0 0 1px #ef44442e,0 0 12px #ef444459;transform:translateY(-50%)}.current-time-line__label{position:sticky;left:6px;z-index:2;display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:22px;padding:0 7px;border-radius:var(--r-full);background:var(--danger);color:var(--text-on-blue);box-shadow:0 0 0 1px #ffffff47,0 6px 18px #ef444452;font-size:.68rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:0;transform:translateY(-50%)}.current-time-line__label:after{content:"";position:absolute;right:-4px;width:8px;height:8px;border-radius:2px;background:var(--danger);transform:rotate(45deg)}.half-line{position:absolute;left:0;right:0;height:1px;background:var(--border);pointer-events:none}.event-block{position:absolute;border-radius:var(--r-sm);padding:4px 6px;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;transition:box-shadow var(--fast),filter var(--fast);border-left-width:3px;border-left-style:solid;z-index:1}.conflict-group-block{position:absolute;left:2px;right:2px;z-index:4;border-radius:var(--r-sm);overflow:hidden;display:flex;flex-direction:column;border:1.5px solid rgba(239,68,68,.45);border-left:3px solid #EF4444;background:var(--surface-2);cursor:pointer;transition:box-shadow var(--fast),transform var(--fast);animation:cgb-in .22s ease both}@keyframes cgb-in{0%{opacity:0;transform:scaleY(.92)}to{opacity:1;transform:scaleY(1)}}.conflict-group-block:hover{box-shadow:0 0 0 2px #ef444459,0 6px 20px #ef444433;filter:brightness(1.03)}.cgb-header{display:flex;align-items:center;gap:4px;padding:3px 7px;font-size:.58rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#fff;background:linear-gradient(90deg,#dc2626,#f59e0b 130%);flex-shrink:0;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap;overflow:hidden}.cgb-header-icon{font-size:.65rem;flex-shrink:0}.cgb-items{display:flex;flex-direction:column;flex:1;overflow:hidden}.cgb-item{display:flex;align-items:stretch;flex:1 1 auto;height:auto;border-bottom:1px solid var(--border);overflow:hidden;transition:background var(--fast)}.cgb-item:last-child{border-bottom:none}.cgb-item:hover{background:#ef44440f}.cgb-item-strip{width:3px;flex-shrink:0}.cgb-item-body{flex:1;padding:6px;min-width:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.cgb-item-name{font-size:.64rem;font-weight:700;line-height:1.15;white-space:normal;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical}.cgb-item-meta{font-size:.58rem;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums}[data-theme=dark] .cgb-item-name{filter:brightness(1.15)}.event-title{font-weight:700;line-height:1.2;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.event-meta{opacity:.75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-room-tag{display:inline-flex;align-items:center;gap:4px;background:#00000026;border-radius:4px;padding:3px 6px;font-size:.72rem;font-weight:800;margin-top:4px;letter-spacing:.02em}[data-theme=dark] .event-room-tag{background:#fff3}.list-view{flex:1;overflow-y:auto;padding:16px}.list-day-section{margin-bottom:20px}.list-day-title{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;padding:0 4px}.list-event{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:5px;transition:all var(--fast)}.list-event:hover{border-color:var(--border-md);background:var(--surface-2);box-shadow:var(--sh-sm)}.list-event-color{width:4px;align-self:stretch;border-radius:2px;flex-shrink:0}.list-event-time{font-size:.75rem;font-weight:700;color:var(--text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:96px}.list-event-name{font-weight:700;font-size:.85rem;color:var(--text-primary)}.list-event-sub{font-size:.73rem;color:var(--text-muted);margin-top:2px}.list-type-badge{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:var(--r-full);flex-shrink:0}.badge-theory{background:var(--blue-50);color:var(--blue-700);border:1px solid var(--blue-200)}[data-theme=dark] .badge-theory{background:#3b82f61a;color:var(--blue-300);border-color:#3b82f633}.badge-practice{background:#10b98114;color:#059669;border:1px solid rgba(16,185,129,.2)}[data-theme=dark] .badge-practice{background:#10b9811a;color:#34d399;border-color:#10b98133}.list-event.has-conflict{background:var(--conflict-bg);border-color:var(--conflict-border)}.list-event.has-conflict:hover{box-shadow:0 4px 12px var(--conflict-stripe);background:var(--conflict-bg)}.list-event.has-conflict .list-event-name{color:var(--conflict-border)}.conflict-warning-badge{display:inline-flex;align-items:center;gap:4px;font-size:.65rem;font-weight:700;color:var(--conflict-border);margin-top:5px}.conflict-type-badge{background:var(--conflict-border)!important;color:#fff!important;border-color:var(--conflict-border)!important}.home-view{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:80px 24px 40px;background:var(--surface-0);position:relative}@media(max-width:1023px){.mobile-academic-dashboard{display:flex;flex-direction:column;gap:14px;width:100%;min-width:0}.mobile-academic-hero{display:flex;flex-direction:column;gap:14px;padding:18px;border-radius:var(--r-lg);border:1px solid var(--border-md);background:linear-gradient(135deg,var(--accent-dim),transparent 58%),var(--surface-1);box-shadow:var(--sh-sm);overflow:hidden}.mobile-academic-hero__body{min-width:0}.mobile-academic-hero__eyebrow{display:inline-flex;margin-bottom:6px;color:var(--accent);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.mobile-academic-hero__title{margin:0;color:var(--text-primary);font-family:var(--font-disp);font-size:1.15rem;font-weight:850;line-height:1.16;overflow-wrap:break-word;word-break:break-word}.mobile-academic-hero__desc{margin:8px 0 0;color:var(--text-secondary);font-size:.82rem;line-height:1.42;overflow-wrap:break-word}.mobile-academic-hero__actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.mobile-academic-primary-btn,.mobile-academic-secondary-btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:var(--r-md);font-family:var(--font);font-size:.82rem;font-weight:800;cursor:pointer;transition:transform var(--fast),border-color var(--fast),background var(--fast)}.mobile-academic-primary-btn{border:1px solid var(--accent);background:var(--accent);color:#fff;box-shadow:var(--sh-blue)}.mobile-academic-secondary-btn{padding:0 12px;border:1px solid var(--border-md);background:var(--surface-0);color:var(--text-secondary)}.mobile-academic-primary-btn:active,.mobile-academic-secondary-btn:active,.mobile-academic-summary-card:active,.mobile-academic-tool:active{transform:scale(.98)}.mobile-academic-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.mobile-academic-summary-card{min-width:0;min-height:92px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);color:var(--text-primary);box-shadow:var(--sh-sm);cursor:pointer;text-align:center}.mobile-academic-summary-card__icon{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:var(--accent-dim);color:var(--accent)}.mobile-academic-summary-card__value{margin-top:3px;font-size:1rem;font-weight:900;line-height:1}.mobile-academic-summary-card__label{color:var(--text-primary);font-size:.67rem;font-weight:800;line-height:1.1}.mobile-academic-summary-card__hint{max-width:100%;color:var(--text-muted);font-size:.61rem;font-weight:700;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-next-class-card{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px;border:1px solid var(--border-md);border-radius:var(--r-lg);background:var(--surface-1);box-shadow:var(--sh-sm)}.mobile-next-class-card__icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--accent-dim);color:var(--accent)}.mobile-next-class-card__body{min-width:0}.mobile-next-class-card__label{display:block;margin-bottom:3px;color:var(--accent);font-size:.66rem;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.mobile-next-class-card__title{margin:0;color:var(--text-primary);font-size:.92rem;font-weight:850;line-height:1.18;overflow-wrap:break-word}.mobile-next-class-card__meta{margin:4px 0 0;color:var(--text-secondary);font-size:.74rem;font-weight:650;line-height:1.34;overflow-wrap:break-word}.mobile-next-class-card__color{width:10px;height:42px;border-radius:var(--r-full);box-shadow:var(--sh-sm)}.mobile-academic-dashboard .hd-pending-section,.mobile-academic-dashboard .hd-courses-section,.mobile-academic-dashboard .hd-news-card{margin:0;padding:16px;border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.mobile-academic-dashboard .hd-pending-section__header,.mobile-academic-dashboard .hd-courses-header{align-items:flex-start;gap:10px}.mobile-academic-dashboard .hd-pending-section__title,.mobile-academic-dashboard .hd-courses-title,.mobile-academic-dashboard .hd-news-title{font-size:1rem;line-height:1.16}.mobile-academic-dashboard .hd-pending-section__sub,.mobile-academic-dashboard .hd-courses-sub{font-size:.75rem;line-height:1.35}.mobile-academic-dashboard .hd-pending-cols,.mobile-academic-dashboard .hd-courses-grid{grid-template-columns:1fr;gap:12px}.mobile-academic-dashboard .hd-sub-section-header{flex-wrap:wrap;gap:7px}.mobile-academic-dashboard .hd-sub-section-title{flex:1 1 150px;min-width:0;line-height:1.2}.mobile-academic-dashboard .hd-sub-section-add-btn{min-height:30px;padding:4px 9px;border-radius:var(--r-sm)}.mobile-academic-dashboard .hd-daily-class-list,.mobile-academic-dashboard .hd-task-list{max-height:none;overflow:visible;padding-right:0;gap:10px}.mobile-academic-dashboard .hd-daily-class-card{grid-template-columns:58px minmax(0,1fr);gap:10px;padding:11px}.mobile-academic-dashboard .hd-daily-class-card__time{padding-right:8px}.mobile-academic-dashboard .hd-daily-class-card__top,.mobile-academic-dashboard .hd-task-card__top,.mobile-academic-dashboard .hd-course-card__footer{flex-wrap:wrap;align-items:flex-start}.mobile-academic-dashboard .hd-task-card{gap:8px;padding:11px}.mobile-academic-dashboard .hd-task-card__icon{width:34px;height:34px}.mobile-academic-dashboard .hd-task-card__subject,.mobile-academic-dashboard .hd-task-card__title,.mobile-academic-dashboard .hd-daily-class-card__subject,.mobile-academic-dashboard .hd-course-card__title{overflow-wrap:break-word;word-break:break-word}.mobile-academic-dashboard .hd-pending-section__footer{justify-content:stretch}.mobile-academic-dashboard .hd-pending-section__all-link,.mobile-academic-dashboard .hd-course-card__btn{min-height:32px;justify-content:center;border-radius:var(--r-sm)}.mobile-academic-dashboard .hd-courses-title-group{min-width:0;align-items:flex-start}.mobile-academic-dashboard .hd-course-card{padding:14px}.mobile-academic-dashboard .hd-course-card__date{min-width:0;overflow-wrap:break-word}.mobile-academic-dashboard .hd-news-list{max-height:none}.mobile-section-header--compact{margin:2px 0 0}.mobile-academic-tools{display:flex;flex-direction:column;gap:10px}.mobile-academic-tools__grid{display:grid;grid-template-columns:1fr;gap:8px}.mobile-academic-tool{min-height:44px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);color:var(--text-primary);font-family:var(--font);font-size:.82rem;font-weight:800;text-align:left;cursor:pointer;box-shadow:var(--sh-sm)}.mobile-academic-tool svg:first-child{color:var(--accent)}.mobile-academic-tool span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}@media(max-width:380px){.mobile-academic-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-academic-hero__actions{grid-template-columns:1fr}.mobile-next-class-card{grid-template-columns:auto minmax(0,1fr)}.mobile-next-class-card__color{display:none}}.home-topright{position:absolute;top:18px;right:18px;display:flex;align-items:center;gap:10px;z-index:100;background:none;border:none;padding:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}@media(max-width:480px){.home-topright{position:relative;margin-left:auto;padding:10px 12px;top:-5px;right:0;gap:8px}}.home-hero{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:40px}.home-hero h1{font-family:var(--font-disp);font-size:2.4rem;font-weight:800;background:linear-gradient(135deg,var(--blue-700),var(--blue-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px;letter-spacing:-.02em}.home-hero p{color:var(--text-secondary);font-size:1rem;max-width:500px;margin:0 auto;overflow-wrap:break-word;word-break:break-word;padding:0 4px}.home-install-btn{margin-bottom:20px;padding:10px 20px;font-size:.95rem;border-radius:var(--r-full);box-shadow:0 8px 16px #3b82f64d;display:inline-flex;align-items:center;gap:8px}.home-logo-wrap{margin-bottom:16px;display:flex;justify-content:center;filter:drop-shadow(0 8px 24px rgba(198,134,66,.25))}.home-logo-img{width:80px;height:80px;object-fit:contain;border-radius:16px}.zone-switcher{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px}.zone-btn{width:64px;height:64px;border-radius:var(--r-xl);border:2px solid var(--border);background:var(--surface-1);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--fast) cubic-bezier(.4,0,.2,1);flex-shrink:0}.zone-btn:hover{background:var(--surface-2);color:var(--text-primary);transform:translateY(-2px);border-color:var(--border-focus)}.zone-btn.active{border-color:var(--accent);color:var(--accent);background:var(--surface-0);box-shadow:0 8px 24px #2563eb33;transform:scale(1.05)}.zone-btn svg{width:28px;height:28px}.zone-switcher .home-logo-wrap{margin:0 8px}.zone-btn-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.zone-label{font-size:.58rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);transition:color var(--fast) ease,text-shadow var(--fast) ease;-webkit-user-select:none;user-select:none;line-height:1}.zone-btn-wrap.active .zone-label{color:var(--accent);text-shadow:0 0 6px var(--accent),0 0 14px var(--accent),0 0 28px color-mix(in srgb,var(--accent) 60%,transparent)}.home-app-title{font-size:2.5rem;margin-bottom:.5rem}.home-app-subtitle{font-size:1.2rem;font-weight:500;color:var(--text-secondary);margin-top:0;margin-bottom:1.5rem}.home-join-btn{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 20px 10px 16px;margin-bottom:6px;margin-top:12px;border:none;border-radius:var(--r-full);cursor:pointer;font-family:var(--font);font-size:.88rem;font-weight:700;letter-spacing:.01em;color:#fff;background:linear-gradient(135deg,#c0f,#5200be 55%,#d400ff);box-shadow:0 4px 18px #b700ff73,0 1px 3px #00000026,inset 0 1px #d400ff33;overflow:hidden;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease;animation:home-join-entrance .6s cubic-bezier(.34,1.56,.64,1) both}@keyframes home-join-entrance{0%{opacity:0;transform:translateY(-12px) scale(.88)}60%{opacity:1;transform:translateY(4px) scale(1.03)}80%{transform:translateY(-2px) scale(.98)}to{transform:translateY(0) scale(1)}}.home-join-btn-shimmer{position:absolute;inset:0;border-radius:inherit;background:linear-gradient(105deg,transparent 30%,rgba(180,148,255,.514) 50%,transparent 70%);background-size:220% 100%;animation:home-join-shimmer 4s ease-in-out infinite;pointer-events:none}@keyframes home-join-shimmer{0%{background-position:190% center}to{background-position:-170% center}}.home-join-btn:before{content:"";position:absolute;inset:-2px;border-radius:var(--r-full);background:linear-gradient(135deg,#003cff38,#0077ff3a);opacity:0;z-index:-1;animation:home-join-glow 2s ease-in-out infinite}@keyframes home-join-glow{0%,to{opacity:0;transform:scale(1);filter:blur(6px)}50%{opacity:.55;transform:scale(1.06);filter:blur(10px)}}.home-join-btn:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 8px 28px #d400ff8c,0 2px 6px #0000002e,inset 0 1px #ffffff40}.home-join-btn:active{transform:scale(.97);box-shadow:0 2px 8px #6366f159,inset 0 1px #ffffff26}.home-join-btn-icon{font-size:1rem;line-height:1;animation:home-join-star 2.4s ease-in-out infinite}@keyframes home-join-star{0%,to{transform:rotate(-10deg) scale(1);opacity:1}25%{transform:rotate(12deg) scale(1.2);opacity:1}50%{transform:rotate(-8deg) scale(.9);opacity:.75}75%{transform:rotate(15deg) scale(1.15);opacity:1}}.home-join-btn-text{position:relative;z-index:1}.home-join-btn-arrow{display:flex;align-items:center;position:relative;z-index:1;opacity:.85;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.home-join-btn:hover .home-join-btn-arrow{transform:translate(4px);opacity:1}.home-join-btn-timer{display:inline-flex;align-items:center;background:#ffffff2e;border:1px solid rgba(255,255,255,.28);border-radius:var(--r-full);padding:1px 8px;margin-left:6px;font-size:.76rem;font-weight:800;letter-spacing:.03em;font-variant-numeric:tabular-nums;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.home-hero-actions{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap;align-items:center}.home-hero-btn-secondary{background:var(--surface-1);border:1px solid var(--border);font-size:.85rem;padding:8px 16px;border-radius:var(--r-full);display:flex;align-items:center;gap:8px;color:var(--text-secondary);cursor:pointer;transition:all var(--fast)}.home-hero-btn-secondary:hover{background:var(--surface-2);border-color:var(--border-focus);color:var(--text-primary)}.home-hero-btn-secondary .btn-emoji{font-size:1.1rem}.home-mi-horario-wrap{display:flex;justify-content:center;margin-top:18px;width:100%}.home-mi-horario-card{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;max-width:440px;padding:14px 18px;background:var(--accent-dim);border:1.5px solid var(--border-focus);border-radius:var(--r-lg);cursor:pointer;text-align:left;transition:all var(--fast)}.home-mi-horario-card:hover{background:color-mix(in srgb,var(--accent) 15%,transparent);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px #6366f12e}.home-mi-horario-left{display:flex;align-items:center;gap:12px;min-width:0}.home-mi-horario-icon{font-size:1.5rem;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface-0);border-radius:var(--r-md);border:1px solid var(--border-focus)}.home-mi-horario-texts{display:flex;flex-direction:column;gap:1px;min-width:0}.home-mi-horario-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.home-mi-horario-name{font-size:.82rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}.home-mi-horario-arrow{color:var(--accent);flex-shrink:0;opacity:.8}.home-whatsapp-card{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;max-width:440px;padding:14px 18px;background:#25d36624;border:1px solid rgba(37,211,102,.9);border-radius:var(--r-lg);cursor:pointer;text-align:left;transition:all var(--fast);text-decoration:none}.home-whatsapp-card:hover{background:#25d36647;border-color:#25d36699;transform:translateY(-2px);box-shadow:0 4px 12px #25d36626}.home-whatsapp-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#25d36626;color:#25d366;border-radius:var(--r-md)}.home-whatsapp-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.home-whatsapp-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px;margin-top:1px}.home-whatsapp-arrow{color:#25d366;flex-shrink:0;opacity:.8;transition:all var(--fast)}.home-whatsapp-card:hover .home-whatsapp-arrow{transform:translate(3px);opacity:1}.home-donation-banner-container{display:flex;justify-content:center;width:100%;margin-top:20px}.home-loading{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);font-size:.9rem}.home-loading .loading-spinner{width:40px;height:40px}.home-semester-group{width:100%;max-width:1000px;margin-bottom:32px}.home-semester-divider{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;gap:10px}.home-semester-line{flex:1;height:1px;background:var(--border)}.home-careers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;width:100%;max-width:1000px}.career-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;text-align:left;transition:all var(--normal)}.career-card:hover{background:var(--surface-2);border-color:var(--border-focus);transform:translateY(-2px);box-shadow:var(--sh-blue)}.career-card.active{border-color:var(--border-focus);background:var(--accent-dim)}.career-card-icon{width:44px;height:44px;border-radius:var(--r-md);background:var(--accent-dim);border:1px solid var(--border-focus);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.career-card-code{font-size:.62rem;font-weight:700;color:var(--accent);letter-spacing:.06em;margin-bottom:3px;font-variant-numeric:tabular-nums}.career-card-name{font-size:.85rem;font-weight:700;color:var(--text-primary);line-height:1.3}.home-nav-dock{display:inline-flex;align-items:center;gap:0;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-md),inset 0 1px #ffffff0f;padding:6px 8px;margin-top:20px;margin-bottom:6px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;position:relative}.home-nav-dock:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(59,130,246,.04) 0%,transparent 60%,rgba(139,92,246,.04) 100%);pointer-events:none}.home-nav-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:9px 18px;border:none;border-radius:var(--r-lg);background:transparent;color:var(--text-muted);cursor:pointer;font-family:var(--font);transition:background var(--fast),color var(--fast),transform .15s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;min-width:64px}.home-nav-item:hover{background:var(--accent-dim);color:var(--accent);transform:translateY(-2px)}.home-nav-item:active{transform:scale(.95)}.home-nav-item.active{background:var(--accent-dim);color:var(--accent);box-shadow:0 2px 8px #3b82f626}.home-nav-item-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-md);background:var(--surface-0);border:1px solid var(--accent);transition:background var(--fast),border-color var(--fast),box-shadow var(--fast)}.home-nav-item:hover .home-nav-item-icon,.home-nav-item.active .home-nav-item-icon{background:var(--accent-dim);border-color:var(--border-md);box-shadow:0 0 0 3px #3b82f61f}.home-nav-item-label{font-size:.64rem;font-weight:700;letter-spacing:.04em;line-height:1}.home-nav-sep{width:1px;height:32px;background:var(--border);flex-shrink:0;margin:0 2px;align-self:center}.home-quick-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:520px;margin:16px auto 0}.home-quick-row:has(.home-quick-card--whatsapp:only-child){grid-template-columns:1fr;max-width:440px}.home-quick-card{box-sizing:border-box;display:flex;align-items:center;gap:11px;padding:13px 14px;border-radius:var(--r-lg);text-decoration:none;cursor:pointer;text-align:left;transition:transform var(--fast),box-shadow var(--fast),border-color var(--fast),background var(--fast)}.home-quick-card--horario{background:var(--accent-dim);border:1.5px solid var(--border-focus);color:inherit}.home-quick-card--horario:hover{transform:translateY(-3px);box-shadow:0 6px 20px #3b82f638;border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.home-quick-card--whatsapp{background:#25d3661f;border:1.5px solid rgba(37,211,102,.55);color:inherit}.home-quick-card--whatsapp:hover{transform:translateY(-3px);box-shadow:0 6px 20px #25d36633;background:#25d36638;border-color:#25d366cc}.home-quick-card-icon{font-size:1.4rem;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--surface-0);border-radius:var(--r-md);border:1px solid var(--border-focus);flex-shrink:0}.home-quick-card-icon--wa{background:#25d3661f;border-color:#25d3664d;color:#25d366}.home-quick-card-body{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.home-quick-card-label{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}.home-quick-card--whatsapp .home-quick-card-label{color:#16a34a}[data-theme=dark] .home-quick-card--whatsapp .home-quick-card-label{color:#4ade80}.home-quick-card-name{font-size:.8rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-quick-card-arrow{color:var(--accent);flex-shrink:0;opacity:.7;transition:transform var(--fast),opacity var(--fast)}.home-quick-card--whatsapp .home-quick-card-arrow{color:#25d366}.home-quick-card--horario:hover .home-quick-card-arrow,.home-quick-card--whatsapp:hover .home-quick-card-arrow{transform:translate(3px);opacity:1}@media(max-width:768px){.home-view{padding:72px 16px 32px}.home-nav-dock{display:flex;align-items:stretch;justify-content:space-between;gap:0;width:100%;padding:6px 3px;border-radius:10px;overflow:hidden}.home-nav-dock::-webkit-scrollbar{display:none}.home-nav-item{min-width:7px;flex:1 1 0;min-width:0;padding:8px 6px;display:flex;flex-direction:column;align-items:center;justify-content:start;gap:6px;text-align:center}.home-nav-item span,.home-nav-item p,.home-nav-item .nav-text{white-space:normal;text-align:center;line-height:1.15;overflow-wrap:break-word}.home-nav-sep{height:24px;margin:0 1px;flex-shrink:0}.home-quick-row{max-width:100%;margin:12px 0 0;gap:8px}.home-quick-row:has(.home-quick-card--whatsapp:only-child){grid-template-columns:1fr;max-width:100%}.home-quick-card{min-width:0;padding:11px 10px;gap:8px}.home-quick-card-icon{width:34px;height:34px}.home-quick-card-name{font-size:.73rem}}@media(max-width:360px){.home-quick-row{grid-template-columns:1fr}.home-nav-item{min-width:60px;padding:6px 10px}.home-nav-item-icon{width:26px;height:26px}.home-nav-item-label{font-size:.58rem}}@media(max-width:768px){.home-nav-scroll-hint{display:block;font-size:.62rem;color:var(--text-muted);text-align:center;letter-spacing:.04em;margin-top:4px;opacity:.65;-webkit-user-select:none;user-select:none}}@media(min-width:769px){.home-nav-scroll-hint{display:none}}.career-search-wrap{width:100%;max-width:600px;margin:0 auto 28px;display:flex;flex-direction:column;align-items:center;gap:10px;animation:anim-up .35s cubic-bezier(.22,1,.36,1) both}.career-search-box{position:relative;width:100%;display:flex;align-items:center;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--r-full);box-shadow:var(--sh-md),inset 0 1px #ffffff0d;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.career-search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent),var(--sh-md);background:var(--surface-0)}.career-search-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:44px;height:44px;color:var(--text-muted);transition:color .2s ease;pointer-events:none}.career-search-box:focus-within .career-search-icon{color:var(--accent)}.career-search-input{flex:1;height:48px;padding:0 8px;border:none;background:transparent;color:var(--text-primary);font-family:var(--font);font-size:.95rem;font-weight:500;outline:none;caret-color:var(--accent)}.career-search-input::placeholder{color:var(--text-muted);font-weight:400}.career-search-clear{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin-right:8px;flex-shrink:0;border:none;border-radius:var(--r-full);background:var(--surface-2);color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease,transform .15s ease;animation:career-clear-pop .2s cubic-bezier(.34,1.56,.64,1) both}@keyframes career-clear-pop{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.career-search-clear:hover{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);transform:scale(1.1)}.career-search-count{font-size:.78rem;font-weight:600;color:var(--text-muted);letter-spacing:.02em;margin:0;padding:3px 12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-full);animation:career-clear-pop .2s ease both}.career-search-empty{width:100%;max-width:460px;margin:0 auto 32px;display:flex;flex-direction:column;align-items:center;gap:10px;padding:36px 24px;background:var(--surface-1);border:1.5px dashed var(--border);border-radius:var(--r-xl);text-align:center;animation:anim-up .3s ease both}.career-search-empty-icon{font-size:2.4rem;filter:grayscale(.2);animation:career-empty-float 3s ease-in-out infinite}@keyframes career-empty-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.career-search-empty p{font-size:.9rem;color:var(--text-secondary);margin:0;line-height:1.5}.career-search-empty strong{color:var(--text-primary)}.career-search-empty-clear{margin-top:4px;padding:7px 18px;border:1.5px solid var(--border-focus);border-radius:var(--r-full);background:transparent;color:var(--accent);font-family:var(--font);font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s ease,transform .15s ease}.career-search-empty-clear:hover{background:var(--accent-dim);transform:translateY(-1px)}@media(max-width:600px){.career-search-wrap{max-width:100%}.career-search-input{font-size:.88rem}}@media(max-width:1023px){.mobile-layout-container{display:flex;flex-direction:column;width:100%;min-height:100vh;box-sizing:border-box}.mobile-layout-content{flex:1;width:100%;box-sizing:border-box;padding-bottom:80px}.mobile-home-view{padding:0 0 100px!important;background:var(--surface-0)!important;display:flex;flex-direction:column;align-items:stretch!important;width:100%;min-height:100vh;box-sizing:border-box}.mobile-header{width:100%;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--surface-0);border-bottom:none;position:sticky;top:0;z-index:100;box-sizing:border-box}.mobile-header-menu-btn,.mobile-header-notif-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:0;position:relative}.mobile-header-actions{display:flex;align-items:center;gap:4px}.mobile-header-logo-wrap{display:flex;align-items:center;gap:8px}.mobile-header-logo{width:32px;height:32px;object-fit:contain}.mobile-header-title{font-family:var(--font-disp);font-weight:800;font-size:1.35rem;color:var(--accent);letter-spacing:-.01em}.mobile-header-notif-badge{position:absolute;top:4px;right:4px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:700;border-radius:var(--r-full);width:15px;height:15px;display:flex;align-items:center;justify-content:center;line-height:1}.mobile-install-btn{background:var(--accent);color:var(--text-on-blue);border:none;border-radius:var(--r-full);padding:10px 24px;font-weight:700;font-size:.88rem;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin:16px auto 0;cursor:pointer;box-shadow:var(--sh-blue);transition:transform var(--fast),background var(--fast)}.mobile-install-btn:active{transform:scale(.97)}.mobile-home-content{display:flex;flex-direction:column;gap:16px;padding:16px;width:100%;box-sizing:border-box}.mobile-welcome-card{position:relative;background:linear-gradient(135deg,var(--accent-dim) 0%,rgba(59,130,246,.03) 100%),var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-lg);padding:18px 20px;display:flex;justify-content:space-between;overflow:hidden;min-height:140px;box-sizing:border-box}.mobile-welcome-card__text{flex:1;display:flex;flex-direction:column;gap:4px;z-index:2}.mobile-welcome-card__title{font-family:var(--font-disp);font-size:1.35rem;font-weight:800;color:var(--accent);margin:0}.mobile-welcome-card__desc{font-size:.8rem;color:var(--text-secondary);line-height:1.35;margin:0;max-width:65%}.mobile-welcome-card__week-subcard{display:flex;align-items:center;gap:8px;background:var(--surface-0);border-radius:var(--r-md);padding:6px 10px;border:1px solid var(--border);margin-top:10px;align-self:flex-start;box-shadow:var(--sh-sm)}.mobile-welcome-card__week-icon{color:var(--accent);display:flex;align-items:center}.mobile-welcome-card__week-info{display:flex;flex-direction:column;gap:1px}.mobile-welcome-card__week-label{font-size:.58rem;color:var(--text-muted);text-transform:uppercase;font-weight:700;letter-spacing:.02em;line-height:1}.mobile-welcome-card__week-dates{font-size:.75rem;font-weight:700;color:var(--text-primary);line-height:1.1}.mobile-welcome-card__visual{position:absolute;right:-8px;bottom:-10px;width:110px;height:110px;z-index:1;opacity:.95}.mobile-welcome-card__img{width:100%;height:100%;object-fit:contain}.mobile-admissions-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff;border-radius:var(--r-lg);cursor:pointer;box-shadow:0 4px 14px #7c3aed38;transition:transform var(--fast);box-sizing:border-box}.mobile-admissions-banner:active{transform:scale(.98)}.mobile-admissions-banner__left{display:flex;align-items:center;gap:6px;font-weight:700;font-size:.82rem}.mobile-admissions-banner__icon{font-size:.9rem}.mobile-admissions-banner__right{display:flex;align-items:center;gap:6px}.mobile-admissions-banner__timer{background:#ffffff2e;border:1px solid rgba(255,255,255,.28);padding:3px 8px;border-radius:var(--r-full);font-size:.7rem;font-weight:800;white-space:nowrap;letter-spacing:.02em}.mobile-admissions-banner__arrow{color:#fffc}.mobile-quick-cards{display:flex;flex-direction:column;gap:10px}.mobile-quick-card{box-sizing:border-box;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-lg);border:1px solid var(--border-md);background:var(--surface-1);cursor:pointer;text-decoration:none;transition:transform var(--fast),background var(--fast)}.mobile-quick-card:active{transform:scale(.98)}.mobile-quick-card--horario{background:var(--accent-dim);border-color:var(--border-focus)}.mobile-quick-card--whatsapp{background:#25d3660f;border-color:#25d36659}.mobile-quick-card__icon-wrap{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--text-on-blue);flex-shrink:0}.mobile-quick-card__icon-wrap--wa{background:#25d366;color:#fff}.mobile-quick-card__decor-img{width:52px;height:52px;object-fit:contain;flex-shrink:0;margin:0 4px;transition:transform var(--fast)}.mobile-quick-card:hover .mobile-quick-card__decor-img{transform:scale(1.08) translateY(-1px)}.mobile-quick-card__body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.mobile-quick-card__label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);line-height:1}.mobile-quick-card__label--wa{color:#16a34a}[data-theme=dark] .mobile-quick-card__label--wa{color:#4ade80}.mobile-quick-card__title{font-size:.8rem;font-weight:800;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.mobile-quick-card__desc{font-size:.68rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.mobile-quick-card__arrow-btn{width:32px;height:32px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;background:var(--surface-0);border:1px solid var(--border-focus);color:var(--accent);flex-shrink:0;box-sizing:border-box}.mobile-quick-card__arrow-btn--horario{border-color:var(--accent);color:var(--accent)}.mobile-quick-card__arrow-btn--wa{border-color:#22c55e;color:#22c55e}.mobile-section-header{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.mobile-section-title{font-family:var(--font-disp);font-size:1.05rem;font-weight:800;color:var(--text-primary);margin:0}.mobile-section-link{font-size:.78rem;font-weight:700;color:var(--accent);background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}.mobile-search-box{position:relative;width:100%;display:flex;align-items:center;background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-full);box-shadow:var(--sh-sm);box-sizing:border-box}.mobile-search-icon{display:flex;align-items:center;position:absolute;left:12px;color:var(--text-muted);pointer-events:none}.mobile-search-input{width:100%;padding:10px 10px 10px 34px;border:none;background:transparent;color:var(--text-primary);font-family:var(--font);font-size:.85rem;outline:none;box-sizing:border-box}.mobile-search-clear{position:absolute;right:8px;width:22px;height:22px;border-radius:var(--r-full);background:var(--surface-3);border:none;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.mobile-careers-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;box-sizing:border-box}.mobile-career-card{display:flex;align-items:center;gap:8px;padding:10px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;text-align:left;transition:transform var(--fast),background var(--fast),border-color var(--fast);min-width:0;box-sizing:border-box}.mobile-career-card:active{transform:scale(.97)}.mobile-career-card--active{border-color:var(--border-focus);background:var(--accent-dim)}.mobile-career-card__icon{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}.mobile-career-card__info{display:flex;flex-direction:column;gap:1px;min-width:0}.mobile-career-card__code{font-size:.58rem;font-weight:700;color:var(--accent);line-height:1}.mobile-career-card__name{font-size:.68rem;font-weight:750;color:var(--text-primary);line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.mobile-bottom-dock{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--surface-1);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:250;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 16px #0000000a;box-sizing:border-box}.mobile-bottom-dock__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;flex:1;transition:color var(--fast)}.mobile-bottom-dock__item--active{color:var(--accent)}.mobile-bottom-dock__label{font-size:.6rem;font-weight:700;line-height:1}.mobile-bottom-dock__fab-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;position:relative;top:-10px;flex:1}.mobile-bottom-dock__fab{width:46px;height:46px;border-radius:var(--r-full);background:var(--accent);color:var(--text-on-blue);border:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-blue);cursor:pointer;transition:transform var(--fast),background var(--fast);padding:0}.mobile-bottom-dock__fab:active{transform:scale(.93)}.mobile-gaming-zone-wrap{padding-bottom:20px}}@media(max-width:1023px){.mobile-layout-container .todo-page{height:auto;min-height:100dvh;padding-bottom:calc(112px + env(safe-area-inset-bottom,0px))}.mobile-layout-container .todo-fab,.mobile-layout-container .lp-fab{bottom:calc(92px + env(safe-area-inset-bottom,0px))}.mobile-layout-container .todo-modal-overlay,.mobile-layout-container .lp-modal-overlay,.mobile-layout-container .pomodoro-modal-overlay{z-index:500}}.hd-topbar{height:var(--header-h);display:flex;align-items:center;gap:16px;padding:0 20px;background:var(--surface-0);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.hd-topbar__left{display:flex;align-items:center;gap:8px;flex-shrink:0}.hd-topbar__burger{display:none;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--r-md);transition:background var(--fast)}.hd-topbar__burger:hover{background:var(--surface-2)}.hd-topbar__search-wrap{flex:1;display:flex;justify-content:center;max-width:480px;margin:0 auto}.hd-topbar__search{display:flex;align-items:center;gap:10px;width:100%;padding:0 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-full);height:38px;transition:border-color var(--fast),box-shadow var(--fast);color:var(--text-muted)}.hd-topbar__search:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.hd-topbar__search-input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.875rem;color:var(--text-primary);outline:none;cursor:pointer}.hd-topbar__search-input::placeholder{color:var(--text-muted)}.hd-topbar__actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.hd-topbar__action-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--r-md);transition:background var(--fast),color var(--fast)}.hd-topbar__action-btn:hover{background:var(--surface-2);color:var(--text-primary)}.hd-topbar__notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;background:var(--accent);color:#fff;border-radius:var(--r-full);font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid var(--surface-0)}.hd-topbar__divider{width:1px;height:24px;background:var(--border);margin:0 4px}.home-dashboard__body{flex:1;display:grid;grid-template-columns:1fr var(--sidebar-w);gap:20px;padding:20px 24px;overflow-y:auto;align-items:start}.home-dashboard__center{display:flex;flex-direction:column;gap:20px;min-width:0}.home-dashboard__aside{display:flex;flex-direction:column;gap:16px;position:sticky;top:0}.home-dashboard__body--aside-collapsed{grid-template-columns:1fr 34px}.hd-aside-rail{position:sticky;top:0;display:flex;justify-content:center;padding-top:2px}.hd-aside-header{display:flex;justify-content:flex-end;margin-bottom:2px}.hd-aside-toggle{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--border-md);background:var(--surface-0);color:var(--text-muted);cursor:pointer;box-shadow:var(--sh-sm);transition:background .15s ease,color .15s ease,border-color .15s ease}.hd-aside-toggle:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--border-focus)}.home-sidebar__mode{display:flex;gap:6px;margin:12px 12px 6px;padding:5px;border-radius:14px;background:var(--surface-2);border:1px solid var(--border-md);flex-shrink:0}.home-sidebar__mode-btn{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 6px;border-radius:10px;border:none;cursor:pointer;background:transparent;color:var(--text-muted);font-family:var(--font-disp);font-weight:800;font-size:.78rem;letter-spacing:.02em;position:relative;overflow:hidden;transition:background .25s cubic-bezier(.16,1,.3,1),color .2s,box-shadow .25s,transform .15s}.home-sidebar__mode-btn:hover:not(.is-active){color:var(--text-primary);background:var(--surface-0)}.home-sidebar__mode-btn:active{transform:scale(.96)}.home-sidebar__mode-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-sidebar__mode-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-sidebar__mode-btn--academy.is-active{background:linear-gradient(135deg,#6f4e37,#8b5e3c);color:#fff;box-shadow:0 3px 12px #6f4e3766}.home-sidebar__mode-btn--arcade.is-active{background:linear-gradient(135deg,#7c3aed,#db2777,#06b6d4 110%);color:#fff;box-shadow:0 3px 16px #db277780}.home-sidebar__mode-btn--arcade.is-active:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35),transparent 70%);transform:translate(-120%);animation:modeShimmer 2.6s ease-in-out infinite}@keyframes modeShimmer{to{transform:translate(120%)}}@media(min-width:1024px){.home-sidebar--rail .home-sidebar__mode{flex-direction:column;margin:12px 10px 6px}.home-sidebar--rail .home-sidebar__mode-btn{padding:10px;gap:0}.home-sidebar--rail .home-sidebar__mode-label{display:none}}.home-arcade{flex:1;overflow-y:auto;padding:16px 24px 32px}.home-arcade__hero{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:30px 28px;margin-bottom:22px;border:1px solid rgba(124,58,237,.4);background:radial-gradient(circle at 12% 18%,rgba(124,58,237,.32),transparent 45%),radial-gradient(circle at 88% 30%,rgba(6,182,212,.26),transparent 45%),radial-gradient(circle at 60% 120%,rgba(219,39,119,.3),transparent 50%),linear-gradient(135deg,#181030,#0d1424);color:#fff;box-shadow:0 12px 40px #7c3aed40;display:flex;align-items:center;justify-content:space-between;gap:20px}.home-arcade__hero-content{position:relative;z-index:2}.home-arcade__badge{display:inline-block;font-size:.68rem;font-weight:800;letter-spacing:.12em;padding:5px 12px;border-radius:var(--r-full);margin-bottom:12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);text-shadow:0 0 12px rgba(124,58,237,.8)}.home-arcade__title{font-family:var(--font-disp);font-size:1.7rem;font-weight:900;margin:0 0 8px;letter-spacing:.01em;text-shadow:0 0 20px rgba(124,58,237,.55)}.home-arcade__sub{margin:0;opacity:.86;font-size:.9rem;max-width:540px}.home-arcade__pixels{position:relative;z-index:2;display:flex;gap:10px;font-size:2rem;flex-shrink:0}.home-arcade__pixels span{animation:arcadeBob 2.4s ease-in-out infinite}.home-arcade__pixels span:nth-child(2){animation-delay:.3s}.home-arcade__pixels span:nth-child(3){animation-delay:.6s}.home-arcade__pixels span:nth-child(4){animation-delay:.9s}@keyframes arcadeBob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.home-arcade__scan{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;background:repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0px,rgba(255,255,255,.04) 1px,transparent 1px,transparent 4px)}.home-arcade .gaming-zone{margin-top:0}@media(max-width:720px){.home-arcade__pixels{display:none}.home-arcade__hero{padding:22px 20px}}.hd-status-pill{display:inline-flex;align-items:center;padding:2px 9px;border-radius:var(--r-full);font-size:.65rem;font-weight:700;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.hd-status-pill--proximo{background:var(--accent-dim);color:var(--accent)}.hd-status-pill--hoy{background:#ef44441f;color:#dc2626}.hd-status-pill--urgente{background:#f59e0b1f;color:#d97706}.hd-status-pill--pendiente{background:var(--surface-3);color:var(--text-muted)}.hd-pending-section{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm)}.hd-pending-section__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.hd-pending-section__icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:var(--r-md);color:var(--accent)}.hd-pending-section__title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 2px;font-family:var(--font-disp)}.hd-pending-section__sub{font-size:.8rem;color:var(--text-muted);margin:0}.hd-pending-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:16px}.hd-pending-col{display:flex;flex-direction:column;gap:8px;min-width:0}.hd-sub-section-header{display:flex;align-items:center;gap:6px;padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:4px}.hd-sub-section-title{font-size:.78rem;font-weight:700;color:var(--accent);letter-spacing:.03em}.hd-pending-section__footer{margin-top:14px;display:flex;justify-content:flex-end}.hd-pending-section__all-link{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--accent);font-family:var(--font);transition:gap var(--fast)}.hd-pending-section__all-link:hover{gap:8px}.hd-exam-card{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--fast),box-shadow var(--fast)}.hd-exam-card:hover{border-color:var(--border-focus);box-shadow:var(--sh-blue)}.hd-exam-card__icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:var(--r-md);font-size:1rem}.hd-exam-card__body{flex:1;min-width:0}.hd-exam-card__top{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:2px}.hd-exam-card__subject{font-size:.82rem;font-weight:700;color:var(--text-primary);truncate:ellipsis}.hd-exam-card__name{font-size:.75rem;color:var(--text-secondary);margin-bottom:5px}.hd-exam-card__meta{display:flex;flex-direction:column;gap:3px}.hd-exam-card__date,.hd-exam-card__time{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-muted)}.hd-task-card{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--fast),box-shadow var(--fast),opacity var(--fast)}.hd-task-card:hover{border-color:var(--border-focus)}.hd-task-card--done{opacity:.5}.hd-task-card__icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md)}.hd-task-card__body{flex:1;min-width:0}.hd-task-card__top{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:2px}.hd-task-card__subject{font-size:.82rem;font-weight:700;color:var(--text-primary)}.hd-task-card__title{font-size:.75rem;color:var(--text-secondary);margin-bottom:5px}.hd-task-card__meta{display:flex;flex-direction:column;gap:3px}.hd-task-card__date,.hd-task-card__time{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-muted)}.hd-task-card__time--urgent{color:#dc2626;font-weight:600}.hd-task-complete-btn{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;width:20px;height:20px;border-radius:var(--r-full);margin-top:8px;flex-shrink:0;outline:none}.hd-task-complete-btn__circle{width:18px;height:18px;border:2px solid var(--border-md);border-radius:50%;display:block;transition:border-color var(--fast),background-color var(--fast),transform var(--fast);position:relative}.hd-task-card:hover .hd-task-complete-btn__circle{border-color:var(--accent);transform:scale(1.08)}.hd-task-complete-btn:focus-visible .hd-task-complete-btn__circle{box-shadow:0 0 0 3px var(--accent-dim);border-color:var(--accent)}.hd-task-card--done .hd-task-complete-btn__circle{background-color:var(--accent);border-color:var(--accent)}.hd-task-card--done .hd-task-complete-btn__circle:after{content:"";position:absolute;top:2px;left:5px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.hd-status-pill--academic{background:#8b5cf61f;color:#8b5cf6}.hd-status-pill--general{background:#10b9811f;color:#10b981}.hd-status-pill--class-now{background:#10b9811f;color:#059669}.hd-status-pill--class-next{background:var(--accent-dim);color:var(--accent)}.hd-status-pill--class-done{background:var(--surface-3);color:var(--text-muted)}.hd-daily-class-card{display:grid;grid-template-columns:66px minmax(0,1fr);gap:12px;padding:12px;background:var(--surface-1);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--r-md);transition:border-color var(--fast),box-shadow var(--fast),opacity var(--fast)}.hd-daily-class-card:hover{border-color:var(--border-focus);box-shadow:var(--sh-sm)}.hd-daily-class-card--done{opacity:.72}.hd-daily-class-card--now{background:linear-gradient(90deg,rgba(16,185,129,.08),var(--surface-1) 48%)}.hd-daily-class-card__time{display:flex;flex-direction:column;justify-content:center;gap:3px;min-width:0;padding-right:10px;border-right:1px solid var(--border)}.hd-daily-class-card__start{font-size:.86rem;font-weight:800;color:var(--text-primary);line-height:1}.hd-daily-class-card__end{font-size:.68rem;font-weight:700;color:var(--text-muted)}.hd-daily-class-card__body{min-width:0}.hd-daily-class-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:5px}.hd-daily-class-card__subject{min-width:0;color:var(--text-primary);font-size:.84rem;font-weight:800;line-height:1.25;overflow-wrap:break-word;word-break:break-word}.hd-daily-class-card__meta{display:flex;flex-wrap:wrap;gap:4px 10px;color:var(--text-secondary);font-size:.73rem;font-weight:650}.hd-daily-class-card__teacher{margin-top:4px;color:var(--text-muted);font-size:.69rem;line-height:1.35;overflow-wrap:break-word;word-break:break-word}.hd-pending-empty{display:flex;flex-direction:column;align-items:center;padding:20px 8px;text-align:center}.hd-pending-empty__icon{font-size:1.8rem;margin-bottom:6px}.hd-pending-empty p{font-size:.78rem;color:var(--text-muted);margin:0 0 8px}.hd-pending-empty__link{background:none;border:none;cursor:pointer;font-size:.75rem;font-weight:600;color:var(--accent);font-family:var(--font)}.hd-schedule-card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}.hd-schedule-card__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 0}.hd-schedule-card__title{display:flex;align-items:center;gap:7px;font-size:.88rem;font-weight:700;color:var(--text-primary)}.hd-schedule-card__badge{padding:2px 10px;background:#10b9811f;color:#059669;border-radius:var(--r-full);font-size:.65rem;font-weight:700}.hd-schedule-card__body{padding:16px}.hd-schedule-card__body--empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}.hd-schedule-card__illustration{margin:4px 0 8px}.hd-schedule-card__empty-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin:0}.hd-schedule-card__empty-sub{font-size:.75rem;color:var(--text-muted);margin:0 0 4px;max-width:220px}.hd-schedule-card__cta{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:var(--r-md);font-size:.85rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:background var(--fast),transform var(--fast);margin-top:4px}.hd-schedule-card__cta:hover{background:var(--blue-700);transform:translateY(-1px)}.hd-schedule-card__link{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-size:.78rem;font-weight:600;color:var(--accent);font-family:var(--font);margin-top:2px;transition:gap var(--fast)}.hd-schedule-card__link:hover{gap:7px}.hd-schedule-card__body--filled{display:flex;flex-direction:column;gap:10px}.hd-schedule-card__career-name{font-size:.88rem;font-weight:700;color:var(--text-primary)}.hd-schedule-card__stats{display:flex;gap:12px;flex-wrap:wrap}.hd-schedule-stat{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary)}.hd-schedule-card__chips{display:flex;flex-wrap:wrap;gap:5px}.hd-schedule-chip{width:18px;height:18px;border-radius:50%}.hd-schedule-chip--more{display:flex;align-items:center;justify-content:center;background:var(--surface-3);color:var(--text-muted);font-size:.6rem;font-weight:700;border-radius:50%;width:18px;height:18px}.hd-community-card{display:flex;flex-direction:column;background:#25d36612;border:1px solid rgba(37,211,102,.3);border-radius:var(--r-lg);padding:16px;text-decoration:none;cursor:pointer;transition:background var(--fast),border-color var(--fast),transform var(--fast);gap:10px}.hd-community-card:hover{background:#25d36624;border-color:#25d36680;transform:translateY(-2px)}.hd-community-card__content{display:flex;gap:12px;align-items:flex-start}.hd-community-card__icon-wrap{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#25d36626;color:#25d366;border-radius:var(--r-md)}.hd-community-card__text{flex:1}.hd-community-card__title{font-size:.88rem;font-weight:700;color:var(--text-primary);margin:0 0 2px}.hd-community-card__sub{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin:0 0 3px}.hd-community-card__desc{font-size:.7rem;color:var(--text-muted);margin:0;line-height:1.4}.hd-community-card__avatars{display:flex;justify-content:center}.hd-community-card__cta{display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;background:#25d366;color:#fff;border-radius:var(--r-md);font-size:.82rem;font-weight:700;transition:background var(--fast)}.hd-community-card:hover .hd-community-card__cta{background:#1db954}.hd-explorer-section{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm)}.hd-explorer-section__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.hd-explorer-section__title-block{display:flex;gap:12px;align-items:flex-start;color:var(--accent)}.hd-explorer-section__title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 2px;font-family:var(--font-disp)}.hd-explorer-section__sub{font-size:.8rem;color:var(--text-muted);margin:0}.hd-explorer-section__controls{display:flex;gap:8px;align-items:center}.hd-explorer-search{display:flex;align-items:center;gap:8px;padding:0 12px;height:34px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-full);color:var(--text-muted);transition:border-color var(--fast);min-width:180px}.hd-explorer-search:focus-within{border-color:var(--border-focus)}.hd-explorer-search__input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.82rem;color:var(--text-primary);outline:none}.hd-explorer-search__input::placeholder{color:var(--text-muted)}.hd-explorer-search__clear{display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;color:var(--text-muted);padding:2px;border-radius:50%}.hd-explorer-search__clear:hover{color:var(--text-primary);background:var(--surface-3)}.hd-faculty-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none}.hd-faculty-tabs::-webkit-scrollbar{display:none}.hd-faculty-tab{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-1);cursor:pointer;white-space:nowrap;font-family:var(--font);transition:all var(--fast)}.hd-faculty-tab:hover{background:var(--surface-2);border-color:var(--border-md)}.hd-faculty-tab--active{background:var(--tab-color, var(--accent));border-color:var(--tab-color, var(--accent));color:#fff}.hd-faculty-tab.hd-faculty-tab--active:hover{background:var(--tab-color, var(--accent));border-color:var(--tab-color, var(--accent));filter:brightness(.92);color:#fff}.hd-faculty-tab__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.hd-faculty-tab--active .hd-faculty-tab__dot{background:#ffffffb3!important}.hd-faculty-tab__short{font-size:.75rem;font-weight:800;letter-spacing:.05em}.hd-faculty-tab__name{font-size:.68rem;color:var(--text-muted);font-weight:500}.hd-faculty-tab--active .hd-faculty-tab__name{color:#fffc}.hd-career-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}.hd-career-grid-wrapper{display:flex;flex-direction:column;gap:14px}.hd-career-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;text-align:left;font-family:var(--font);transition:all var(--fast)}.hd-career-card:hover{background:var(--surface-2);border-color:var(--border-focus);transform:translateY(-2px);box-shadow:var(--sh-blue)}.hd-career-card--active{border-color:var(--accent);background:var(--accent-dim)}.hd-career-card__icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--surface-3);border-radius:var(--r-sm);font-size:1.1rem}.hd-career-card__body{flex:1;min-width:0}.hd-career-card__code{display:block;font-size:.62rem;font-weight:700;color:var(--accent);margin-bottom:2px}.hd-career-card__name{display:block;font-size:.72rem;font-weight:700;color:var(--text-primary);line-height:1.3;text-transform:uppercase;letter-spacing:.01em}.hd-career-card__arrow{color:var(--text-muted);flex-shrink:0;opacity:0;transition:opacity var(--fast),transform var(--fast)}.hd-career-card:hover .hd-career-card__arrow{opacity:1;transform:translate(2px)}.hd-career-grid__empty{display:flex;flex-direction:column;align-items:center;padding:32px;gap:8px;color:var(--text-muted);font-size:.85rem}.hd-career-grid__show-all{display:flex;align-items:center;gap:5px;justify-content:center;background:none;border:none;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--accent);font-family:var(--font);padding:8px;transition:gap var(--fast)}.hd-career-grid__show-all:hover{gap:8px}@media(max-width:1023px){.hd-topbar__burger{display:flex}}.home-sidebar{display:flex;flex-direction:column;width:var(--sidebar-w);min-width:var(--sidebar-w);flex-shrink:0}.home-sidebar__logo{display:flex;align-items:center;gap:10px;padding:16px 14px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.home-sidebar__logo-img{width:28px;height:28px;border-radius:6px;object-fit:contain;flex-shrink:0}.home-sidebar__logo-name{font-family:var(--font-disp);font-size:.95rem;font-weight:800;color:var(--accent);line-height:1}.home-sidebar__logo-sub{font-size:.62rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.home-sidebar__nav{flex:1;display:flex;flex-direction:column;padding:10px 8px;gap:2px;overflow-y:auto}.home-sidebar__nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border:none;background:transparent;cursor:pointer;border-radius:var(--r-md);font-family:var(--font);font-size:.82rem;font-weight:500;color:var(--text-secondary);text-align:left;width:100%;position:relative;transition:background var(--fast),color var(--fast)}.home-sidebar__nav-item:hover{background:var(--surface-2);color:var(--text-primary)}.home-sidebar__nav-item--active{background:var(--accent-dim);color:var(--accent);font-weight:700}.home-sidebar__nav-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.home-sidebar__nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-sidebar__notif-badge{min-width:18px;height:18px;padding:0 4px;background:var(--accent);color:#fff;border-radius:var(--r-full);font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-sidebar__sep{height:1px;background:var(--border);margin:6px 12px;flex-shrink:0}.home-sidebar__bottom{padding:6px 8px}.home-sidebar__admisiones{position:relative;margin:10px 8px 12px;padding:14px 12px;background:linear-gradient(135deg,#6200ea,#3b00c2);border-radius:var(--r-lg);color:#fff;flex-shrink:0;cursor:pointer;transition:transform var(--fast),box-shadow var(--fast),filter var(--fast);box-shadow:0 4px 14px #6200ea40;outline:none;border:1px solid rgba(255,255,255,.08)}.home-sidebar__adm-close{position:absolute;top:6px;right:6px;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;border-radius:var(--r-full);background:#ffffff24;color:#fff;cursor:pointer;opacity:.75;transition:background var(--fast),opacity var(--fast)}.home-sidebar__adm-close:hover{background:#ffffff47;opacity:1}.home-sidebar__admisiones:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 8px 24px #6200ea73}.home-sidebar__admisiones:focus-visible{box-shadow:0 0 0 3px #fff6,0 8px 24px #6200ea73}.home-sidebar__admisiones:active{transform:translateY(0)}.home-sidebar__adm-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.home-sidebar__adm-title{font-size:.72rem;font-weight:700;line-height:1.2}.home-sidebar__adm-sub{font-size:.65rem;opacity:.8;margin-bottom:8px}.home-sidebar__adm-footer-cta{display:flex;align-items:center;justify-content:flex-end;gap:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.9;transition:opacity var(--fast)}.home-sidebar__admisiones:hover .home-sidebar__adm-footer-cta{opacity:1}.home-sidebar__adm-footer-cta svg{transition:transform var(--fast)}.home-sidebar__admisiones:hover .home-sidebar__adm-footer-cta svg{transform:translate(2px)}.home-sidebar__logo-text{display:flex;flex-direction:column;min-width:0}.home-sidebar__collapse{margin-left:auto;width:28px;height:28px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface-0);color:var(--text-muted);cursor:pointer;transition:background var(--fast),color var(--fast),border-color var(--fast)}.home-sidebar__collapse:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--border-focus)}@media(min-width:1024px){.home-sidebar.home-sidebar--rail{width:72px;min-width:72px}.home-sidebar--rail .home-sidebar__logo{flex-direction:column;gap:10px;padding:14px 8px}.home-sidebar--rail .home-sidebar__logo-text{display:none}.home-sidebar--rail .home-sidebar__collapse{margin-left:0}.home-sidebar--rail .home-sidebar__nav{padding:10px}.home-sidebar--rail .home-sidebar__nav-item{justify-content:center;padding:10px;gap:0}.home-sidebar--rail .home-sidebar__nav-label{display:none}.home-sidebar--rail .home-sidebar__notif-badge{position:absolute;top:3px;right:3px;min-width:15px;height:15px;font-size:.55rem}.home-sidebar--rail .home-sidebar__bottom{padding:6px 10px}.home-sidebar--rail .home-sidebar__admisiones{margin:10px;padding:12px 0;text-align:center}.home-sidebar--rail .home-sidebar__adm-header{justify-content:center;margin:0}.home-sidebar--rail .home-sidebar__adm-title,.home-sidebar--rail .home-sidebar__adm-sub,.home-sidebar--rail .home-sidebar__adm-footer-cta{display:none}}@media(max-width:1023px){.home-sidebar__collapse{display:none}}.hd-topbar__search--open{border-color:var(--border-focus)!important;border-bottom-left-radius:0!important;border-bottom-right-radius:0!important;box-shadow:0 4px 12px #0000001a!important}.hd-topbar__search-clear{background:transparent;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:4px;border-radius:50%;transition:background var(--fast),color var(--fast)}.hd-topbar__search-clear:hover{background:var(--surface-3);color:var(--text-primary)}.hd-search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--surface-0);border:1px solid var(--border-focus);border-top:none;border-bottom-left-radius:var(--r-lg);border-bottom-right-radius:var(--r-lg);box-shadow:var(--sh-lg);z-index:100;max-height:380px;overflow-y:auto;padding:8px 0}.hd-search-dropdown__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center;gap:8px;color:var(--text-muted);font-size:.85rem}.hd-search-dropdown__empty span:first-child{font-size:1.5rem}.hd-search-result{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;border:none;background:transparent;cursor:pointer;text-align:left;font-family:var(--font);transition:background var(--fast)}.hd-search-result:hover{background:var(--surface-2)}.hd-search-result__emoji{font-size:1.25rem;flex-shrink:0}.hd-search-result__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.hd-search-result__name{font-size:.82rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hd-search-result__meta{display:flex;align-items:center;gap:8px}.hd-search-result__code{font-size:.68rem;font-weight:600;color:var(--text-muted)}.hd-search-result__faculty{font-size:.6rem;font-weight:800;padding:1px 6px;border-radius:var(--r-sm);letter-spacing:.05em;text-transform:uppercase}.hd-search-result__arrow{color:var(--text-muted);flex-shrink:0;opacity:0;transition:opacity var(--fast),transform var(--fast)}.hd-search-result:hover .hd-search-result__arrow{opacity:1;transform:translate(2px)}.hd-search-dropdown__footer{padding:8px 16px 4px;font-size:.65rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:6px;text-transform:uppercase;letter-spacing:.04em}.hd-add-task-form{background:var(--surface-1);border:1.5px dashed var(--border-focus);border-radius:var(--r-md);padding:16px;display:flex;flex-direction:column;gap:12px;margin-bottom:8px}.hd-add-task-form__title{font-size:.88rem;font-weight:800;color:var(--accent);margin:0 0 2px;font-family:var(--font-disp)}.hd-add-task-form__error{background:#ef44441a;color:#ef4444;padding:8px 12px;border-radius:var(--r-sm);font-size:.75rem;font-weight:600}.hd-add-task-form__field{display:flex;flex-direction:column;gap:5px}.hd-add-task-form__label{font-size:.7rem;font-weight:700;color:var(--text-secondary)}.hd-add-task-form__input,.hd-add-task-form__select{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;font-size:.78rem;color:var(--text-primary);font-family:var(--font);outline:none;transition:border-color var(--fast)}.hd-add-task-form__input:focus,.hd-add-task-form__select:focus{border-color:var(--accent)}.hd-add-task-form__row{display:grid;grid-template-columns:1fr 100px;gap:10px}.hd-add-task-form__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.hd-add-task-form__btn{padding:8px 14px;border-radius:var(--r-sm);border:none;cursor:pointer;font-size:.78rem;font-weight:700;font-family:var(--font);transition:background var(--fast),color var(--fast)}.hd-add-task-form__btn--cancel{background:transparent;color:var(--text-secondary)}.hd-add-task-form__btn--cancel:hover{background:var(--surface-2);color:var(--text-primary)}.hd-add-task-form__btn--submit{background:var(--accent);color:#fff}.hd-add-task-form__btn--submit:hover{background:var(--blue-700)}.hd-sub-section-add-btn{margin-left:auto;background:var(--accent-dim);border:none;color:var(--accent);padding:2px 8px;border-radius:var(--r-sm);font-size:.68rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:background var(--fast),color var(--fast)}.hd-sub-section-add-btn:hover{background:var(--accent);color:#fff}.hd-career-card__fac-badge{font-size:.58rem;font-weight:800;padding:1px 5px;border-radius:4px;margin-left:8px;border:1px solid currentColor;display:inline-block;vertical-align:middle;letter-spacing:.04em;text-transform:uppercase}.hd-schedule-card__badge--active{background:#10b9811f!important;color:#059669!important}.hd-schedule-card__badge--pending{background:#f59e0b1f!important;color:#d97706!important}.hd-schedule-card__pending-text{font-size:.75rem;color:var(--text-secondary);display:flex;gap:8px;line-height:1.4}.hd-schedule-card__pending-icon{font-size:1.1rem;flex-shrink:0}.hd-schedule-card__cta--pending{background:var(--accent)!important}.hd-onboarding-banner{background:linear-gradient(135deg,var(--surface-1),var(--surface-2));border:1px solid var(--border-focus);border-radius:var(--r-xl);padding:24px;margin-bottom:24px;box-shadow:var(--sh-md);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:16px;transition:transform var(--normal),box-shadow var(--normal)}.hd-onboarding-banner:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}.hd-onboarding-banner__content{display:flex;gap:20px;align-items:flex-start}.hd-onboarding-banner__visual{background:var(--accent-dim);color:var(--accent);width:80px;height:80px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.hd-coffee-cup{filter:drop-shadow(0 2px 4px rgba(0,0,0,.06))}.hd-coffee-steam{position:absolute;top:12px;display:flex;gap:4px}.hd-steam-line{width:2px;height:10px;background:var(--accent);border-radius:var(--r-full);opacity:.7;animation:steam-rise 2s infinite ease-in-out}.hd-steam-line:nth-child(2){animation-delay:.4s}.hd-steam-line:nth-child(3){animation-delay:.8s}@keyframes steam-rise{0%{transform:translateY(0) scaleY(1);opacity:.3}50%{transform:translateY(-4px) scaleY(1.3);opacity:.8}to{transform:translateY(-8px) scaleY(.7);opacity:0}}.hd-onboarding-banner__text{flex:1;display:flex;flex-direction:column;gap:6px}.hd-onboarding-banner__title{font-size:1.15rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0}.hd-onboarding-banner__description{font-size:.84rem;color:var(--text-secondary);margin:0;line-height:1.5}.hd-onboarding-banner__description strong{color:var(--accent)}.hd-onboarding-banner__tip{display:flex;align-items:center;gap:6px;font-size:.74rem;font-weight:600;color:var(--text-muted);margin-top:4px}.hd-onboarding-banner__indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding-top:14px;border-top:1px dashed var(--border);color:var(--accent);font-size:.78rem;font-weight:700}.hd-indicator-text{letter-spacing:.02em}.hd-indicator-arrow{animation:arrow-bob 1.5s infinite ease-in-out}@keyframes arrow-bob{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}.hd-onboarding-pulse{animation:pulse-glow 2s infinite ease-in-out;border-color:var(--accent)!important}@keyframes pulse-glow{0%{box-shadow:0 0 #2563eb59}70%{box-shadow:0 0 0 10px #2563eb00}to{box-shadow:0 0 #2563eb00}}.hd-schedule-card__actions-row{display:flex;flex-direction:column;gap:8px;width:100%}.hd-schedule-card__reset-btn{background:transparent;border:none;cursor:pointer;color:var(--text-secondary);font-size:.74rem;font-weight:600;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;border-radius:var(--r-sm);transition:background var(--fast),color var(--fast);width:100%;margin-top:4px}.hd-schedule-card__reset-btn:hover{background:var(--surface-2);color:var(--text-primary)}.hd-schedule-card__reset-btn svg{color:var(--text-muted);transition:transform var(--fast)}.hd-schedule-card__reset-btn:hover svg{transform:rotate(180deg);color:var(--accent)}.activity-modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;z-index:99999;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fade-in .15s ease}.activity-modal{background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-xl);width:100%;max-width:480px;box-shadow:var(--sh-lg);overflow:hidden;animation:slide-up .25s cubic-bezier(.16,1,.3,1) forwards}.activity-modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.activity-modal-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.activity-modal-close{background:transparent;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:4px;border-radius:var(--r-sm);transition:color var(--fast),background-color var(--fast)}.activity-modal-close:hover{color:var(--text-primary);background-color:var(--surface-2)}.activity-modal-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--surface-0);padding:4px 12px 0;gap:8px}.activity-modal-tab{padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--text-muted);transition:color var(--fast),border-color var(--fast)}.activity-modal-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.activity-modal-body{padding:24px}.activity-modal-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.activity-modal-field:last-child{margin-bottom:0}.activity-modal-label{font-size:.78rem;font-weight:600;color:var(--text-secondary)}.activity-modal-input,.activity-modal-select{width:100%;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:.85rem;outline:none;transition:border-color var(--fast),box-shadow var(--fast)}.activity-modal-input:focus,.activity-modal-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.activity-modal-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.activity-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;background:var(--surface-0);border-top:1px solid var(--border)}.activity-modal-btn{padding:10px 18px;border-radius:var(--r-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color var(--fast),color var(--fast),transform var(--fast)}.activity-modal-btn--cancel{background:transparent;border:1px solid var(--border-md);color:var(--text-primary)}.activity-modal-btn--cancel:hover{background:var(--surface-2)}.activity-modal-btn--submit{background:var(--accent);border:none;color:#fff}.activity-modal-btn--submit:hover{background:var(--accent-hover, #1d4ed8)}.activity-modal-btn:active{transform:scale(.98)}.hd-daily-class-list,.hd-task-list{display:flex;flex-direction:column;gap:12px;max-height:290px;overflow-y:auto;padding-right:6px}.hd-daily-class-list::-webkit-scrollbar,.hd-task-list::-webkit-scrollbar{width:5px}.hd-daily-class-list::-webkit-scrollbar-track,.hd-task-list::-webkit-scrollbar-track{background:transparent}.hd-daily-class-list::-webkit-scrollbar-thumb,.hd-task-list::-webkit-scrollbar-thumb{background-color:var(--border-md);border-radius:var(--r-full);transition:background-color var(--fast)}.hd-daily-class-list::-webkit-scrollbar-thumb:hover,.hd-task-list::-webkit-scrollbar-thumb:hover{background-color:var(--accent)}@media(max-width:900px){.hd-pending-cols{grid-template-columns:1fr}}.hd-courses-section{margin-top:10px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-sm)}.hd-courses-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.hd-courses-title-group{display:flex;align-items:center;gap:10px}.hd-courses-icon{width:32px;height:32px;border-radius:var(--r-md);background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center}.hd-courses-title{font-size:1.05rem;font-weight:800;color:var(--text-primary);margin:0}.hd-courses-sub{font-size:.78rem;color:var(--text-muted);margin-top:2px}.hd-courses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}.hd-course-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;justify-content:space-between;height:100%;transition:transform var(--fast),border-color var(--fast),box-shadow var(--fast);cursor:pointer;position:relative;overflow:hidden}.hd-course-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--sh-md)}.hd-course-card__badge{align-self:flex-start;padding:3px 8px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;border-radius:var(--r-full);margin-bottom:12px}.hd-course-card__badge--taller{background:#3b82f61a;color:#3b82f6}.hd-course-card__badge--seminario{background:#8b5cf61a;color:#8b5cf6}.hd-course-card__badge--curso{background:#10b9811a;color:#10b981}.hd-course-card__title{font-size:.88rem;font-weight:700;color:var(--text-primary);line-height:1.3;margin:0 0 6px}.hd-course-card__desc{font-size:.74rem;color:var(--text-secondary);line-height:1.4;margin:0 0 16px;flex-grow:1}.hd-course-card__footer{display:flex;align-items:center;justify-content:space-between;border-top:1px dashed var(--border);padding-top:12px}.hd-course-card__date{font-size:.68rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.hd-course-card__btn{font-size:.72rem;font-weight:700;color:var(--accent);background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:2px;padding:0;transition:color var(--fast)}.hd-course-card:hover .hd-course-card__btn{color:var(--accent-hover, #1d4ed8)}.hd-news-card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);padding:18px;box-shadow:var(--sh-sm)}.hd-news-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.hd-news-title{font-size:.85rem;font-weight:800;color:var(--text-primary);margin:0;text-transform:uppercase;letter-spacing:.03em}.hd-news-list{display:flex;flex-direction:column;gap:12px}.hd-news-item{padding:10px 12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color var(--fast),background-color var(--fast),transform var(--fast)}.hd-news-item:hover{border-color:var(--accent-dim);background-color:var(--surface-2);transform:translate(2px)}.hd-news-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.hd-news-item__tag{font-size:.6rem;font-weight:700;padding:1px 6px;border-radius:var(--r-sm);text-transform:uppercase}.hd-news-item__tag--convocatoria{background:#f59e0b1a;color:#d97706}.hd-news-item__tag--oficial{background:#3b82f61a;color:#3b82f6}.hd-news-item__tag--evento{background:#8b5cf61a;color:#8b5cf6}.hd-news-item__date{font-size:.62rem;color:var(--text-muted)}.hd-news-item__title{font-size:.74rem;font-weight:700;color:var(--text-primary);line-height:1.3}.admin-login-layout{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100vw;background:radial-gradient(circle at 10% 20%,rgba(37,99,235,.08) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(139,92,246,.08) 0%,transparent 40%),var(--surface-0);padding:20px}.admin-login-card{width:100%;max-width:400px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px;box-shadow:var(--sh-lg)}.admin-login-header{text-align:center;margin-bottom:24px}.admin-login-logo{font-size:2.2rem;display:inline-block;margin-bottom:12px}.admin-login-header h3{font-size:1.3rem;font-weight:800;color:var(--text-primary);margin:0 0 6px}.admin-login-header p{font-size:.8rem;color:var(--text-secondary);margin:0}.admin-login-hint{margin-top:20px;padding:12px;background:var(--surface-2);border:1px dashed var(--border-md);border-radius:var(--r-md);display:flex;flex-direction:column;gap:4px}.admin-login-hint span{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.admin-login-hint code{font-size:.72rem;color:var(--accent);font-family:monospace}.admin-login-back-link{display:block;width:100%;text-align:center;background:transparent;border:none;font-size:.76rem;color:var(--text-muted);cursor:pointer;margin-top:20px;transition:color var(--fast)}.admin-login-back-link:hover{color:var(--accent);text-decoration:underline}.admin-workspace-container{padding:24px;max-width:1100px;margin:0 auto}.admin-workspace-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:18px;margin-bottom:20px}.admin-workspace-title{font-size:1.4rem;font-weight:850;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.02em}.admin-workspace-sub{font-size:.82rem;color:var(--text-muted);margin:0}.admin-logout-btn{padding:8px 16px;background:transparent;border:1px solid var(--border-md);color:var(--text-primary);border-radius:var(--r-md);font-size:.78rem;font-weight:700;cursor:pointer;transition:background var(--fast),border-color var(--fast)}.admin-logout-btn:hover{background:var(--surface-2);border-color:var(--text-secondary)}.admin-tabs{display:flex;gap:8px;border-bottom:1px solid var(--border);margin-bottom:24px}.admin-tab{padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.84rem;font-weight:700;cursor:pointer;transition:color var(--fast),border-color var(--fast)}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.admin-card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-sm)}.admin-card-title{font-size:1.05rem;font-weight:800;color:var(--text-primary);margin:0 0 20px}.admin-form-success{padding:12px 16px;background:#10b9811a;border:1px solid #10B981;color:#10b981;border-radius:var(--r-md);font-size:.8rem;font-weight:700}.admin-image-type-selector{display:flex;gap:8px;margin-bottom:12px}.admin-image-type-btn{padding:8px 14px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--r-md);font-size:.78rem;font-weight:600;cursor:pointer;transition:background var(--fast),color var(--fast),border-color var(--fast)}.admin-image-type-btn:hover{background:var(--surface-3);color:var(--text-primary)}.admin-image-type-btn--active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.admin-file-upload-box{border:2px dashed var(--border-md);border-radius:var(--r-lg);padding:20px;text-align:center;background:var(--surface-1);transition:border-color var(--fast)}.admin-file-upload-box:hover{border-color:var(--accent)}.admin-file-upload-label{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}.admin-file-upload-label span{font-size:.82rem;font-weight:700;color:var(--text-primary)}.admin-file-upload-label small{font-size:.7rem;color:var(--text-muted)}.admin-image-preview-wrapper{margin-top:14px;position:relative;display:inline-block;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border)}.admin-image-preview{max-height:150px;max-width:100%;display:block;object-fit:cover}.admin-remove-image-btn{position:absolute;top:8px;right:8px;padding:4px 10px;background:#ef4444e6;border:none;color:#fff;font-size:.65rem;font-weight:700;border-radius:var(--r-sm);cursor:pointer}.admin-remove-image-btn:hover{background:#ef4444}.admin-news-table{display:flex;flex-direction:column;gap:12px}.admin-news-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);transition:transform var(--fast)}.admin-news-row:hover{transform:translate(2px)}.admin-news-row-left{display:flex;align-items:center;gap:16px}.admin-news-thumbnail{width:60px;height:60px;border-radius:var(--r-md);object-fit:cover;border:1px solid var(--border);flex-shrink:0}.admin-news-thumbnail--placeholder{display:flex;align-items:center;justify-content:center;background:var(--surface-2);font-size:1.5rem}.admin-news-row-title{font-size:.88rem;font-weight:800;color:var(--text-primary);margin:0 0 2px}.admin-delete-news-btn{padding:6px 12px;background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#ef4444;border-radius:var(--r-md);font-size:.76rem;font-weight:700;cursor:pointer;transition:background var(--fast),border-color var(--fast)}.admin-delete-news-btn:hover{background:#ef444426;border-color:#ef4444}.notifications-layout-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}@media(max-width:768px){.notifications-layout-grid{grid-template-columns:1fr;gap:16px}.notifications-workspace{padding:16px 12px 32px}.notifications-header{flex-direction:column;align-items:stretch;gap:14px;margin-bottom:16px!important}.notifications-header .admin-workspace-title{font-size:1.25rem}.notifications-header .admin-workspace-sub{font-size:.8rem}.notif-mark-all-btn{width:100%;justify-content:center;padding:12px 16px;font-size:.85rem;border-radius:var(--r-lg)}.notifications-list-card,.notifications-settings-card{padding:16px 14px;border-radius:var(--r-lg);gap:14px}.notif-feed-item{padding:14px 12px;gap:10px;border-radius:var(--r-md)}.notif-feed-item__left{gap:12px;min-width:0}.notif-feed-item__icon{width:36px;height:36px;font-size:1rem}.notif-feed-item__title{font-size:.9rem}.notif-feed-item__msg{font-size:.82rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.notif-feed-item__date{font-size:.72rem}.notif-feed-item__actions{flex-direction:column;gap:6px}.notif-mark-btn,.notif-delete-btn{width:34px;height:34px;font-size:.95rem;border-radius:var(--r-md)}.notifications-settings-card{background:var(--surface-1)}.notif-setting-toggle-box{padding:14px 0}.notif-switch-btn{width:50px;height:28px}.notif-switch-thumb{width:22px;height:22px}.notif-switch-btn--active .notif-switch-thumb{transform:translate(22px)}}.notifications-list-card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:20px}.notifications-list-header{display:flex;align-items:center;justify-content:space-between}.notif-badge-bubble{padding:3px 8px;font-size:.68rem;font-weight:700;background:var(--accent-dim);color:var(--accent);border-radius:var(--r-full)}.notif-feed-container{display:flex;flex-direction:column;gap:12px}.notif-empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.notif-empty-state h4{font-size:.95rem;font-weight:800;color:var(--text-primary);margin:12px 0 4px}.notif-empty-state p{font-size:.78rem;margin:0}.notif-feed-item{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:transform var(--fast),border-color var(--fast),background-color var(--fast);position:relative;overflow:hidden}.notif-feed-item:hover{transform:translateY(-1px);border-color:var(--border-focus)}.notif-feed-item--unread{border-left:4px solid var(--accent);background:linear-gradient(to right,var(--accent-dim),transparent)}.notif-feed-item__left{display:flex;align-items:flex-start;gap:14px}.notif-feed-item__icon{width:32px;height:32px;border-radius:var(--r-md);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.notif-feed-item--unread .notif-feed-item__icon{background:var(--surface-0)}.notif-feed-item__title{font-size:.85rem;font-weight:800;color:var(--text-primary);margin:0 0 4px}.notif-feed-item__msg{font-size:.76rem;color:var(--text-secondary);line-height:1.4;margin:0 0 8px}.notif-feed-item__date{font-size:.68rem;color:var(--text-muted)}.notif-feed-item__actions{display:flex;gap:8px}.notif-mark-btn,.notif-delete-btn{width:24px;height:24px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:.72rem;cursor:pointer;border:1px solid var(--border);background:var(--surface-0);color:var(--text-secondary);transition:background var(--fast),color var(--fast)}.notif-mark-btn:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.notif-delete-btn:hover{background:#ef44441a;color:#ef4444;border-color:#ef44444d}.notifications-settings-card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:16px;height:fit-content}.notifications-settings-desc{font-size:.78rem;color:var(--text-secondary);line-height:1.4;margin:0}.notif-setting-toggle-box{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.notif-setting-toggle-text{display:flex;flex-direction:column;gap:3px}.notif-setting-toggle-label{font-size:.8rem;font-weight:750;color:var(--text-primary)}.notif-setting-toggle-sub{font-size:.68rem;color:var(--text-muted)}.notif-switch-btn{width:44px;height:24px;border-radius:var(--r-full);background:var(--border-md);position:relative;cursor:pointer;border:none;transition:background-color var(--fast);flex-shrink:0}.notif-switch-btn--active{background:var(--accent)}.notif-switch-thumb{width:18px;height:18px;border-radius:var(--r-full);background:#fff;position:absolute;top:3px;left:3px;transition:transform var(--fast);box-shadow:0 2px 4px #0003}.notif-switch-btn--active .notif-switch-thumb{transform:translate(20px)}.notifications-pwa-info{padding:16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg)}.notifications-pwa-info h5{font-size:.78rem;font-weight:800;color:var(--text-primary);margin:0 0 8px}.notifications-pwa-info ul{margin:0;padding-left:16px;display:flex;flex-direction:column;gap:6px}.notifications-pwa-info li{font-size:.72rem;color:var(--text-secondary)}.news-detail-modal{max-width:650px!important;max-height:85vh!important;display:flex;flex-direction:column}.news-detail-header-meta{display:flex;align-items:center;gap:10px}.news-detail-header-date{font-size:.72rem;color:var(--text-muted)}.news-detail-body{overflow-y:auto;padding-right:6px}.news-detail-image-wrapper{margin-bottom:20px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border)}.news-detail-image{width:100%;max-height:280px;object-fit:cover;display:block}.news-detail-title{font-size:1.25rem;font-weight:850;color:var(--text-primary);line-height:1.3;margin:0 0 16px;letter-spacing:-.02em}.news-detail-author-box{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:20px}.news-detail-author-avatar{width:36px;height:36px;border-radius:var(--r-full);background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800}.news-detail-author-info{display:flex;flex-direction:column}.news-detail-author-name{font-size:.8rem;font-weight:750;color:var(--text-primary)}.news-detail-author-title{font-size:.68rem;color:var(--text-muted)}.news-detail-content{display:flex;flex-direction:column;gap:14px}.news-detail-paragraph{font-size:.84rem;color:var(--text-secondary);line-height:1.55;margin:0}.news-detail-footer{border-top:1px solid var(--border)!important}.gaming-zone{width:100%;max-width:1200px;margin-top:1rem;margin-left:auto;margin-right:auto;animation:fadeIn var(--normal) ease}.gaming-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;padding-bottom:3rem}.game-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease;cursor:pointer;text-align:left;display:flex;flex-direction:column;min-width:0}.game-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.game-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #00000026;border-color:var(--accent)}[data-theme=dark] .game-card:hover{box-shadow:0 20px 40px #2563eb33}.game-banner{width:100%;height:140px;background-size:cover;background-position:center;position:relative;border-bottom:1px solid var(--border)}.game-banner-img{width:100%;height:100%;object-fit:cover;display:block}.game-icon-overlay{position:absolute;bottom:-24px;left:20px;width:56px;height:56px;background:var(--surface-0);border:2px solid var(--border);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:var(--sh-md);z-index:2}.game-info{padding:36px 20px 20px;display:flex;flex-direction:column;flex:1}.game-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.game-desc{font-size:.875rem;color:var(--text-secondary);margin-bottom:20px;line-height:1.5;flex:1}.game-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.game-tags{display:flex;gap:8px;flex-wrap:wrap}.game-tag{font-size:.65rem;text-transform:uppercase;font-weight:600;letter-spacing:.5px;padding:4px 8px;background:var(--surface-2);color:var(--text-secondary);border-radius:var(--r-sm)}.btn-play{background:var(--accent);color:var(--text-on-blue);border:none;border-radius:var(--r-md);padding:6px 16px;font-weight:600;font-size:.875rem;transition:filter var(--fast) ease,transform var(--fast) cubic-bezier(.175,.885,.32,1.275);cursor:pointer}.game-card:hover .btn-play{filter:brightness(.9);transform:scale(1.05)}.game-wrapper{max-width:800px;margin:0 auto;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;min-height:100vh}.game-header{width:100%;display:flex;align-items:center;position:relative;margin-bottom:2rem}.game-back-btn{position:absolute;left:0;display:flex;align-items:center;gap:4px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-weight:600;transition:color .2s ease}.game-back-btn:hover{color:var(--text-primary)}.game-header h2{width:100%;text-align:center;margin:0;font-size:1.5rem;color:var(--text-primary)}.sudoku-container{display:flex;flex-direction:column;gap:2rem;align-items:center;background:var(--surface-1);padding:2rem;border-radius:var(--r-xl);border:1px solid var(--border);box-shadow:var(--sh-lg)}.sudoku-board{display:flex;flex-direction:column;border:2px solid var(--text-primary);background:var(--surface-2)}.sudoku-row{display:flex}.sudoku-cell{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);font-size:1.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.sudoku-cell.fixed{color:var(--text-primary);font-weight:700}.sudoku-cell.user-value{color:var(--accent);font-weight:500}.sudoku-cell:hover{background:var(--surface-0)}.sudoku-cell.highlighted{background:#2563eb26}[data-theme=dark] .sudoku-cell.highlighted{background:#3b82f640}.sudoku-cell.border-right{border-right:2px solid var(--text-primary)}.sudoku-cell.border-bottom{border-bottom:2px solid var(--text-primary)}.sudoku-controls{display:flex;flex-direction:column;gap:1rem;align-items:center}.numpad{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.4rem}.numpad-btn{width:35px;height:44px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);font-size:1.25rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .1s ease}.numpad-btn:hover{background:var(--surface-0);border-color:var(--accent)}.numpad-btn:active{transform:scale(.95)}.numpad-btn.blocked{opacity:.25;cursor:not-allowed;background:var(--surface-1);color:var(--text-muted);border-color:var(--border);box-shadow:none;transform:none}.numpad-btn.blocked:hover{background:var(--surface-1);border-color:var(--border);transform:none}.numpad-btn.removable{background:#ef444426;border-color:#ef444466;color:#ef4444}.numpad-btn.removable:hover{background:#ef444440}.numpad-action{width:100%;padding:.75rem;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .2s ease}.numpad-action:hover{background:#ef4444;color:#fff;border-color:#ef4444}@media(max-width:500px){.sudoku-cell{width:32px;height:32px;font-size:1rem}.numpad-btn{width:32px;height:38px}}.sudoku-cell.error-cell{color:#ef4444;font-weight:800;background:#ef444433;animation:shake .3s cubic-bezier(.36,.07,.19,.97) both}.sudoku-cell.error-line{background:#ef44441a}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-2px,0,0)}40%,60%{transform:translate3d(2px,0,0)}}.sudoku-cell.focus-line{background:var(--surface-0)}.sudoku-cell.same-number{background:#3b82f626;color:#60a5fa!important;font-weight:800}.game-settings-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-full);background:transparent;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--fast) ease}.game-settings-btn:hover{color:var(--text-primary);background:var(--surface-2);transform:rotate(30deg)}.sudoku-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn var(--fast) ease}.sudoku-modal{background:var(--surface-1);padding:1.5rem;border-radius:var(--r-xl);border:1px solid var(--border);box-shadow:var(--sh-lg);width:90%;max-width:360px;display:flex;flex-direction:column;gap:1rem;animation:popIn var(--normal) cubic-bezier(.175,.885,.32,1.275)}.sudoku-modal h3{margin:0;font-size:1.125rem;color:var(--text-primary)}.sudoku-modal p{margin:0;font-size:.875rem;color:var(--text-secondary)}.sudoku-modal-options{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.sudoku-modal-option{display:flex;align-items:center;gap:.75rem;color:var(--text-primary);cursor:pointer;padding:10px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);transition:all var(--fast) ease}.sudoku-modal-option:hover{border-color:var(--accent)}.sudoku-modal-option input[type=radio]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.sudoku-modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:1.5rem}.sudoku-modal-btn{background:var(--accent);color:var(--text-on-blue);border:none;padding:.6rem 1.25rem;font-weight:600;border-radius:var(--r-md);cursor:pointer;transition:filter var(--fast) ease,transform var(--fast) ease}.sudoku-modal-btn:hover{filter:brightness(.9);transform:scale(.98)}.win-modal{text-align:center;align-items:center}.win-icon{font-size:4rem;margin-bottom:-10px;animation:bouncePop .6s cubic-bezier(.175,.885,.32,1.275) both;animation-delay:.1s}@keyframes bouncePop{0%{transform:scale(0)}80%{transform:scale(1.2)}to{transform:scale(1)}}.diff-btn{padding:8px 16px;border-radius:var(--r-full);background:var(--surface-1);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;font-weight:600;font-size:.9rem;transition:all var(--fast) ease}.diff-btn:hover{background:var(--surface-2);color:var(--text-primary)}.diff-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px rgba(var(--accent-rgb, 37, 99, 235),.3)}.tictactoe-container{display:flex;flex-direction:column;gap:1rem;align-items:center;background:var(--surface-1);padding:1rem .75rem;border-radius:var(--r-xl);border:1px solid var(--border);box-shadow:var(--sh-lg);width:100%;max-width:440px;margin:.75rem auto}.tictactoe-status{font-size:1.25rem;font-weight:600;color:var(--text-secondary);text-align:center;min-height:28px}.status-win{color:var(--text-primary);animation:popIn var(--normal) cubic-bezier(.175,.885,.32,1.275)}.status-draw{color:#f59e0b}.color-x{color:#ef4444}.color-o{color:#3b82f6}.tictactoe-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--border);padding:8px;border-radius:var(--r-lg);width:100%}.tictactoe-cell{width:100%;aspect-ratio:1;background:var(--surface-0);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:clamp(2rem,10vw,3.5rem);font-weight:700;cursor:default;transition:all var(--fast) ease;-webkit-user-select:none;user-select:none;box-shadow:var(--sh-sm)}.tictactoe-cell.active{cursor:pointer}.tictactoe-cell.active:hover{background:var(--surface-1);transform:translateY(-2px);box-shadow:var(--sh-md)}.tictactoe-cell.winning-cell{background:var(--surface-3);animation:popCenter .4s cubic-bezier(.175,.885,.32,1.275) both}@keyframes popCenter{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.btn-reset{width:100%;padding:.75rem;font-size:1rem;margin-top:1rem}.ttt-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn var(--fast) ease}.ttt-modal{background:var(--surface-1);padding:2rem;border-radius:var(--r-xl);border:1px solid var(--border);box-shadow:var(--sh-lg);width:90%;max-width:360px;display:flex;flex-direction:column;gap:1rem;text-align:center;animation:popIn var(--normal) cubic-bezier(.175,.885,.32,1.275)}.ttt-btn{background:var(--accent);color:var(--text-on-blue);border:none;padding:.75rem 1.25rem;font-weight:600;border-radius:var(--r-md);cursor:pointer;transition:filter var(--fast) ease,transform var(--fast) ease;width:100%}.ttt-btn:hover{filter:brightness(.9);transform:scale(.98)}.ttt-actions{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:1rem}.ttt-btn--online{background:linear-gradient(135deg,#3b82f6,#6366f1);display:flex;align-items:center;justify-content:center;gap:8px}.ttt-btn--share{background:linear-gradient(135deg,#10b981,#3b82f6);display:flex;align-items:center;justify-content:center;gap:8px}.ttt-btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.ttt-btn--ghost:hover{background:var(--surface-2);color:var(--text-primary);filter:none}.ttt-conn-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;font-size:.82rem;font-weight:700;border-bottom:1px solid var(--border);background:var(--surface-1);color:var(--text-muted);min-height:38px}.ttt-conn-banner--connected{background:#10b98114;color:#10b981;border-bottom-color:#10b98133}.ttt-conn-banner--disconnected,.ttt-conn-banner--error{background:#ef444414;color:#ef4444;border-bottom-color:#ef444433}.ttt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ttt-dot--green{background:#10b981;box-shadow:0 0 6px #10b98199}.ttt-dot--red{background:#ef4444;box-shadow:0 0 6px #ef444499}.ttt-spinner{display:inline-block;width:16px;height:16px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:tttSpin .7s linear infinite;flex-shrink:0}.ttt-spinner--lg{width:36px;height:36px;border-width:3px}@keyframes tttSpin{to{transform:rotate(360deg)}}.ttt-lobby{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;text-align:center}.ttt-lobby__icon{font-size:2.5rem}.ttt-lobby__title{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:0}.ttt-lobby__subtitle{font-size:.82rem;color:var(--text-muted);line-height:1.55;margin:0;max-width:280px}.ttt-lobby__loading{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:.85rem}.ttt-lobby__actions{display:flex;flex-direction:column;gap:8px;width:100%}.ttt-invite-url{width:100%;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;overflow:hidden}.ttt-invite-url__text{font-size:.72rem;color:var(--accent);word-break:break-all;font-family:monospace}.ttt-qr-wrapper{background:#fff;padding:12px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}.ttt-actions-top{display:flex;flex-direction:column;gap:8px;width:100%}.ttt-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.ttt-btn--sm{padding:.55rem .5rem;font-size:.85rem;display:flex;align-items:center;justify-content:center;gap:5px}.ttt-btn--cpu{background:linear-gradient(135deg,#8b5cf6,#6366f1)}.ttt-btn--mode-active{box-shadow:0 0 0 2px #8b5cf6}.ttt-hist-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--accent);color:var(--text-on-blue);border-radius:9px;font-size:.65rem;font-weight:800;margin-left:2px}.ttt-hist-modal{max-width:380px;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;gap:12px}.ttt-hist-title{font-size:1.2rem;font-weight:800;color:var(--text-primary);margin:0;text-align:left}.ttt-hist-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;width:100%}.ttt-hist-stat{background:var(--surface-0);border-radius:var(--r-md);padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;border:1px solid var(--border)}.ttt-hist-stat--win{border-color:#10b9814d}.ttt-hist-stat--draw{border-color:#f59e0b4d}.ttt-hist-stat--loss{border-color:#ef44444d}.ttt-hist-stat__num{font-size:1.6rem;font-weight:800;line-height:1}.ttt-hist-stat--win .ttt-hist-stat__num{color:#10b981}.ttt-hist-stat--draw .ttt-hist-stat__num{color:#f59e0b}.ttt-hist-stat--loss .ttt-hist-stat__num{color:#ef4444}.ttt-hist-stat__label{font-size:.68rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}.ttt-hist-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto;max-height:300px;width:100%;padding-right:2px}.ttt-hist-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--surface-0);border-radius:var(--r-md);border:1px solid var(--border);font-size:.84rem}.ttt-hist-item__date{margin-left:auto;color:var(--text-muted);font-size:.72rem;white-space:nowrap}.ttt-hist-tag{padding:2px 7px;border-radius:4px;font-size:.7rem;font-weight:700;background:var(--surface-2);color:var(--text-muted);white-space:nowrap}.ttt-hist-tag--cpu{background:#8b5cf626;color:#8b5cf6}.ttt-hist-tag--online{background:#3b82f626;color:#3b82f6}.popcorn-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:calc(100vh - 64px);background-color:var(--surface-0);padding:16px;box-sizing:border-box;position:relative;overflow:hidden}.popcorn-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px;box-shadow:var(--sh-lg);z-index:10;width:100%;max-width:400px;text-align:center}.popcorn-menu h2{font-size:24px;margin-bottom:24px;color:var(--text-primary)}.popcorn-classes{display:flex;gap:16px;margin-bottom:24px;justify-content:center}.popcorn-class-btn{display:flex;flex-direction:column;align-items:center;background:var(--surface-2);border:2px solid transparent;padding:16px;border-radius:var(--r-lg);cursor:pointer;transition:all var(--fast) ease;color:var(--text-primary);position:relative}.popcorn-class-btn:hover{background:var(--surface-3);transform:translateY(-2px)}.popcorn-class-btn.active{border-color:var(--accent);background:var(--accent-dim)}.popcorn-class-icon{font-size:32px;margin-bottom:8px}.popcorn-start-btn{width:100%;padding:16px;font-size:18px;background:var(--accent);color:#fff;border:none;border-radius:var(--r-md);cursor:pointer;transition:background var(--fast)}.popcorn-start-btn:hover{background:var(--border-focus)}.popcorn-canvas-wrapper{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);background:#111}.popcorn-canvas{display:block;width:100%;max-width:800px;cursor:crosshair}.popcorn-hud{position:absolute;top:16px;left:16px;right:16px;display:flex;justify-content:space-between;pointer-events:none;z-index:10}.popcorn-hearts{display:flex;gap:4px;font-size:24px}.popcorn-boss-hp{display:flex;flex-direction:column;align-items:flex-end;color:#fff;font-weight:700}.popcorn-boss-bar{width:200px;height:12px;background:#fff3;border-radius:var(--r-full);overflow:hidden;margin-top:4px}.popcorn-boss-bar-fill{height:100%;background:#e74c3c;transition:width .2s ease}.popcorn-skill-hud{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#00000080;padding:8px 16px;border-radius:var(--r-full);color:#fff;font-weight:700;display:flex;align-items:center;gap:8px;pointer-events:none}.popcorn-skill-hud .key{background:#fff;color:#000;padding:2px 8px;border-radius:4px;font-size:14px}.popcorn-game-over{position:absolute;inset:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:20}.popcorn-game-over h2{font-size:32px;margin-bottom:8px;color:#e74c3c}.popcorn-game-over.victory h2{color:#f1c40f}:root{--t-board-bg: #bbada0;--t-empty: rgba(238, 228, 218, .38);--t-text-dark: #776e65;--t-text-light: #f9f6f2}.game__container{max-width:460px;margin:0 auto 2rem;padding:1.5rem;gap:0;border-radius:var(--r-xl);background:var(--surface-1);box-shadow:var(--sh-md);display:flex;flex-direction:column}.game__header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.game__header{flex:1;margin:0}.game__title{font-size:3rem;font-weight:800;color:var(--text-primary);margin:0;line-height:1;letter-spacing:-2px}.game__subtitle{font-size:.82rem;color:var(--text-secondary);margin:6px 0 0}.scoreboard{width:auto;margin:0}.scoreboard__container{display:flex;gap:8px}.scoreboard__score,.scoreboard__best{background:var(--t-board-bg);color:var(--t-text-light);padding:8px 14px;border-radius:var(--r-md);text-align:center;min-width:66px;box-shadow:inset 0 -2px #00000026}.scoreboard__label{font-size:.68rem;font-weight:700;text-transform:uppercase;color:#ffffffbf;letter-spacing:.04em;margin-bottom:2px}.scoreboard__value{font-size:1.25rem;font-weight:800;color:#fff}.game__controls{width:100%;margin-bottom:1.25rem}.game__button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:#fff;border:none;padding:12px 20px;border-radius:var(--r-lg);font-size:1rem;font-weight:700;cursor:pointer;transition:filter var(--fast) ease,transform var(--fast) ease,box-shadow var(--fast) ease;box-shadow:0 4px color-mix(in srgb,var(--accent) 60%,black);letter-spacing:.01em}.game__button:hover{filter:brightness(1.08);transform:translateY(-2px);box-shadow:0 6px color-mix(in srgb,var(--accent) 60%,black)}.game__button:active{transform:translateY(2px);box-shadow:0 2px color-mix(in srgb,var(--accent) 60%,black)}.game__button--retry{background:#f65e3b;box-shadow:0 4px #c44527}.game__button--retry:hover{box-shadow:0 6px #c44527}.game__button--retry:active{box-shadow:0 2px #c44527}.game__button--continue{background:#edcf72;color:var(--t-text-dark);box-shadow:0 4px #c8a83c;flex:1}.game__button--continue:hover{box-shadow:0 6px #c8a83c}.game__board-container{position:relative;width:100%;margin-bottom:0}.board{background:var(--t-board-bg);border-radius:var(--r-xl);padding:10px;box-sizing:border-box;width:100%;box-shadow:0 6px 20px #0000002e,inset 0 2px 4px #0000001a}.board__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:10px;width:100%;aspect-ratio:1}.tile{display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);font-weight:800;transition:background-color .1s ease;position:relative;box-sizing:border-box;width:100%;height:100%}.tile--empty{background:var(--t-empty)}.tile--filled{animation:tileAppear .15s ease-in-out;box-shadow:0 2px 4px #0000001f}.tile__value{font-weight:800;-webkit-user-select:none;user-select:none;line-height:1}@keyframes tileAppear{0%{opacity:0;transform:scale(.5)}60%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes tileMerge{0%{transform:scale(1)}40%{transform:scale(1.18)}to{transform:scale(1)}}.tile--merged{animation:tileMerge .2s ease-in-out}.game__overlay{position:absolute;inset:0;background:#0f172ab8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.game__overlay--won{background:#141e0ac7}.game__overlay-content{text-align:center;padding:28px 24px;background:var(--surface-1);border-radius:var(--r-xl);border:1px solid var(--border);box-shadow:var(--sh-lg);width:82%;max-width:280px}.game__overlay-title{font-size:2rem;font-weight:800;color:var(--text-primary);margin:0 0 8px}.game__overlay-score{font-size:1rem;color:var(--text-secondary);margin:0 0 20px}.game__overlay-buttons{display:flex;flex-direction:column;gap:10px}.game__mobile-controls{display:none;flex-direction:column;align-items:center;gap:8px;margin-top:1.25rem}.game__arrows-row{display:flex;gap:8px}.game__arrow{width:58px;height:58px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:1.4rem;font-weight:700;cursor:pointer;transition:background .12s ease,transform .1s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 0 var(--border-md)}.game__arrow:hover{background:var(--surface-3);transform:translateY(-2px)}.game__arrow:active{transform:translateY(1px);box-shadow:none}@media(max-width:500px){.game__container{padding:1rem}.game__title{font-size:2.25rem}.board{padding:8px}.board__grid{gap:8px}.scoreboard__score,.scoreboard__best{min-width:56px;padding:6px 10px}.game__mobile-controls{display:flex}}@media(max-width:340px){.game__title{font-size:1.75rem}}@media(hover:none)and (pointer:coarse){.game__mobile-controls{display:flex}.game__button:hover{filter:none;transform:none}.game__arrow:hover{background:var(--surface-2);transform:none}}:root{--ms-bg: #c0c0c0;--ms-light: #ffffff;--ms-mid: #808080;--ms-dark: #404040;--ms-cell-size: 30px;--ms-bw: 3px;--ms-1: #0000ff;--ms-2: #007b00;--ms-3: #ff0000;--ms-4: #00007b;--ms-5: #7b0000;--ms-6: #007b7b;--ms-7: #000000;--ms-8: #7b7b7b}.ms-page{display:flex;flex-direction:column;align-items:center;gap:16px;padding-bottom:2rem}.ms-difficulty{display:flex;gap:0;border:2px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface-2)}.ms-diff-btn{padding:7px 16px;font-size:.8rem;font-weight:700;background:var(--surface-2);color:var(--text-secondary);border:none;border-right:1px solid var(--border);cursor:pointer;transition:background var(--fast) ease,color var(--fast) ease;white-space:nowrap}.ms-diff-btn:last-child{border-right:none}.ms-diff-btn:hover{background:var(--surface-3);color:var(--text-primary)}.ms-diff-btn--active{background:var(--accent);color:#fff}.ms-diff-btn--active:hover{background:var(--accent-hover)}.ms-scroll{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.ms-panel{background:var(--ms-bg);border-width:var(--ms-bw);border-style:solid;border-color:var(--ms-light) var(--ms-dark) var(--ms-dark) var(--ms-light);padding:10px;display:inline-flex;flex-direction:column;gap:6px;-webkit-user-select:none;user-select:none}.ms-panel--won .ms-grid{animation:msWonGlow 1s ease-in-out 3}.ms-header{display:flex;align-items:center;justify-content:space-between;background:var(--ms-bg);border-width:var(--ms-bw);border-style:solid;border-color:var(--ms-dark) var(--ms-light) var(--ms-light) var(--ms-dark);padding:6px 8px;gap:8px}.ms-display{background:#000;color:red;font-family:Courier New,Lucida Console,monospace;font-size:24px;font-weight:700;letter-spacing:2px;padding:2px 6px;min-width:56px;text-align:right;border-width:2px;border-style:solid;border-color:var(--ms-dark) var(--ms-light) var(--ms-light) var(--ms-dark);line-height:1}.ms-reset-btn{background:var(--ms-bg);border-width:var(--ms-bw);border-style:solid;border-color:var(--ms-light) var(--ms-mid) var(--ms-mid) var(--ms-light);width:38px;height:38px;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0;transition:border-color .05s}.ms-reset-btn:active{border-color:var(--ms-mid) var(--ms-light) var(--ms-light) var(--ms-mid)}.ms-grid{border-width:var(--ms-bw);border-style:solid;border-color:var(--ms-dark) var(--ms-light) var(--ms-light) var(--ms-dark);display:grid;line-height:0}.ms-cell{width:var(--ms-cell-size);height:var(--ms-cell-size);border-width:var(--ms-bw);border-style:solid;border-color:var(--ms-light) var(--ms-mid) var(--ms-mid) var(--ms-light);background:var(--ms-bg);display:flex;align-items:center;justify-content:center;font-family:Courier New,monospace;font-size:14px;font-weight:700;cursor:pointer;box-sizing:border-box;transition:border-color .05s}.ms-cell:active:not(.ms-cell--revealed):not(.ms-cell--flagged){border-color:var(--ms-mid)}.ms-cell--revealed{border-width:1px;border-color:var(--ms-mid);cursor:default;animation:msReveal .12s ease-out}.ms-cell--mine-hit{background:red;border-width:1px;border-color:var(--ms-mid);cursor:default;animation:msExplode .4s ease-out}.ms-cell--mine,.ms-cell--wrong-flag{border-width:1px;border-color:var(--ms-mid);cursor:default}.ms-cell--n1{color:var(--ms-1)}.ms-cell--n2{color:var(--ms-2)}.ms-cell--n3{color:var(--ms-3)}.ms-cell--n4{color:var(--ms-4)}.ms-cell--n5{color:var(--ms-5)}.ms-cell--n6{color:var(--ms-6)}.ms-cell--n7{color:var(--ms-7)}.ms-cell--n8{color:var(--ms-8)}@keyframes msReveal{0%{transform:scale(.88);opacity:.6}to{transform:scale(1);opacity:1}}@keyframes msExplode{0%{transform:scale(1)}30%{transform:scale(1.25)}65%{transform:scale(.9)}to{transform:scale(1)}}@keyframes msWonGlow{0%,to{background:var(--ms-bg)}50%{background:#d4f0d4}}.ms-instructions{font-size:.78rem;color:var(--text-muted);text-align:center;line-height:1.6}@media(max-width:400px){:root{--ms-cell-size: 26px}.ms-display{font-size:20px;min-width:46px}}.doom-page-body{width:100%;max-width:960px;display:flex;flex-direction:column;align-items:center;padding:1rem 1rem 3rem;flex:1}.doom-root{display:flex;flex-direction:column;align-items:center;width:100%}.doom-launcher{width:100%;max-width:860px;min-height:440px;background:radial-gradient(ellipse 70% 60% at 50% 100%,rgba(180,0,0,.18) 0%,transparent 70%),#0b0b0b;border:1.5px solid rgba(200,0,0,.5);border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;padding:3rem 2rem;text-align:center;box-shadow:0 0 0 1px #ff00000f,0 0 60px #b4000026,0 24px 48px #0009}.doom-eye-wrap{position:relative;width:90px;height:90px;display:flex;align-items:center;justify-content:center}.doom-eye-ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(200,0,0,.5);animation:doom-pulse 2.4s ease-in-out infinite;box-shadow:0 0 20px #c8000066}@keyframes doom-pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:1}}.doom-loader{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.doom-loader-ring{position:absolute;inset:0;border-radius:50%;border:3px solid rgba(200,0,0,.15);border-top-color:#c00;animation:doom-spin .9s linear infinite}@keyframes doom-spin{to{transform:rotate(360deg)}}.doom-skull{font-size:3rem;line-height:1}.doom-title{font-family:Courier New,Courier,monospace;font-size:2.6rem;font-weight:900;color:#d00;letter-spacing:.18em;text-transform:uppercase;text-shadow:0 0 12px rgba(255,0,0,.5),0 0 40px rgba(255,0,0,.2);margin:0}.doom-sub{font-family:Courier New,Courier,monospace;font-size:.9rem;color:#888;margin:0;letter-spacing:.06em}.doom-hint{font-family:Courier New,Courier,monospace;font-size:.72rem;color:#444;margin:0;letter-spacing:.04em}.doom-start-btn{font-family:Courier New,Courier,monospace;font-weight:700;font-size:1rem;color:#fff;background:linear-gradient(135deg,#b80000,#8b0000);border:1px solid rgba(255,80,80,.25);padding:13px 40px;border-radius:6px;cursor:pointer;letter-spacing:.12em;text-transform:uppercase;transition:transform .14s ease,box-shadow .14s ease,background .14s ease;margin-top:.25rem}.doom-start-btn:hover{background:linear-gradient(135deg,#d40000,#a80000);transform:scale(1.05);box-shadow:0 0 24px #dc000073,0 6px 16px #0006}.doom-start-btn:active{transform:scale(.97)}.doom-progress{width:220px;height:3px;background:#ffffff0f;border-radius:9999px;overflow:hidden}.doom-progress-bar{height:100%;width:40%;background:#c00;border-radius:9999px;animation:doom-slide 1.4s ease-in-out infinite alternate}@keyframes doom-slide{0%{transform:translate(-100%)}to{transform:translate(300%)}}.doom-game-layout{display:flex;align-items:stretch;width:100%;max-width:920px;border-radius:12px;overflow:hidden}.doom-game-layout--fs,.doom-game-layout:fullscreen{max-width:100vw;width:100vw;height:100vh;border-radius:0;background:#000}.doom-game-layout--fs .doom-canvas-wrap,.doom-game-layout:fullscreen .doom-canvas-wrap{max-width:none;height:100%;border:none;border-radius:0;box-shadow:none;aspect-ratio:auto}.doom-canvas-area{position:relative;flex:1;min-width:0;display:flex}.doom-controls-panel{display:flex;flex-direction:column;align-items:center;width:56px;flex-shrink:0;background:#0d0d0d;border:1px solid rgba(200,0,0,.25);border-right:none;border-radius:12px 0 0 12px;padding:10px 0;z-index:20}.doom-game-layout--fs .doom-controls-panel,.doom-game-layout:fullscreen .doom-controls-panel{border-radius:0;border-left:none;position:relative}.dcp-section{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;width:100%}.dcp-label{font-family:Courier New,Courier,monospace;font-size:.45rem;color:#555;letter-spacing:.06em;text-transform:uppercase}.dcp-value{font-family:Courier New,Courier,monospace;font-size:.55rem;color:#c00;font-weight:700}.dcp-hint{font-family:Courier New,Courier,monospace;font-size:.42rem;color:#444;text-align:center;line-height:1.2}.dcp-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#aaa;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.dcp-btn:hover{background:#c8000040;border-color:#c8000080;color:#fff}.dcp-btn--active{background:#c800004d;border-color:#c80000b3;color:#f44}.dcp-divider{width:70%;height:1px;background:#ffffff0d;margin:2px 0}.dcp-slider{-webkit-appearance:none;appearance:none;writing-mode:vertical-lr;direction:rtl;width:4px;height:54px;background:#ffffff14;border-radius:9999px;outline:none;cursor:pointer}.dcp-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#c00;cursor:pointer;box-shadow:0 0 6px #c8000099}.doom-capture-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;font-family:Courier New,Courier,monospace;font-size:.9rem;font-weight:700;color:#fff;background:#8c0000e0;border:1.5px solid rgba(255,80,80,.35);border-radius:8px;padding:11px 24px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .13s ease;white-space:nowrap}.doom-capture-overlay:hover{background:#c80000f2}.doom-pause-overlay{position:absolute;inset:0;z-index:15;background:#000000b8;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.doom-pause-card{display:flex;flex-direction:column;align-items:center;gap:1rem}.doom-pause-title{font-family:Courier New,Courier,monospace;font-size:1.6rem;font-weight:900;color:#d00;letter-spacing:.2em;margin:0;text-shadow:0 0 20px rgba(255,0,0,.4)}.doom-canvas-wrap{width:100%;max-width:860px;background:#000;border:1px solid var(--border-md);border-radius:12px;overflow:hidden;box-shadow:var(--sh-lg);position:relative;aspect-ratio:4 / 3}.jsdos-rso .sidebar,.jsdos-rso .sidebar-thin{display:none!important}.jsdos-rso .emulator-mouse-overlay,.jsdos-rso .emulator-click-to-start-overlay,.jsdos-rso .emulator-options{display:none!important;opacity:0!important;pointer-events:none!important}.doom-canvas-wrap>div{width:100%!important;height:100%!important}.jsdos-rso .frame,.jsdos-rso>div{padding-left:0!important;margin-left:0!important}.doom-canvas-wrap canvas,.jsdos-rso canvas{margin:0 auto!important;width:100%!important;height:100%!important;display:block!important;object-fit:contain!important;image-rendering:pixelated}.doom-game-layout:not(.mouse-captured) .doom-canvas-wrap canvas,.doom-game-layout:not(.mouse-captured) .jsdos-rso canvas{cursor:default!important}.emulator-cursor{display:none!important}@media(max-width:540px){.doom-title{font-size:1.9rem}.doom-start-btn{font-size:.9rem;padding:11px 28px}.doom-launcher{min-height:340px;padding:2rem 1rem;gap:1rem}.doom-canvas-wrap{border-radius:8px}}.bib-page .emulator-main{max-width:1060px!important}.emulator-main{width:100%;display:grid;grid-template-columns:1fr 290px;gap:20px;align-items:center}@media(max-width:800px){.emulator-main{grid-template-columns:1fr}}.emulator-left{display:flex;flex-direction:column;gap:16px}.emulator-right{display:flex;flex-direction:column;gap:20px}.emulator-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px}.emu-divider{height:1px;background:var(--border);width:100%}@keyframes emulatorPulse{0%,to{opacity:1}50%{opacity:.4}}@media(max-width:640px){.bib-page:has(.emulator-rom-bar){padding:0;gap:0;height:100dvh;overflow:hidden;align-items:stretch}.bib-page:has(.emulator-rom-bar) .bib-nav{min-height:50px;padding:0 12px;flex-shrink:0;border-bottom:1px solid var(--border)}.emulator-main{grid-template-columns:1fr;padding:0;gap:0}.bib-page:has(.emulator-rom-bar) .emulator-main{flex:1;min-height:0;display:flex;flex-direction:column;padding:0;gap:0}.bib-page:has(.emulator-rom-bar) .emulator-left{flex:1;min-height:0;display:flex;flex-direction:column;gap:0;width:100%}.bib-page:has(.emulator-rom-bar) .emulator-right{display:none}}@media(orientation:landscape)and (max-width:1024px){.bib-page:has(.emulator-rom-bar){padding:0;gap:0;height:100dvh;overflow:hidden;align-items:stretch}.bib-page:has(.emulator-rom-bar) .bib-nav{min-height:44px;padding:0 12px;flex-shrink:0;border-bottom:1px solid var(--border)}.emulator-main{grid-template-columns:1fr;padding:0;gap:0}.bib-page:has(.emulator-rom-bar) .emulator-main{flex:1;min-height:0;display:flex;flex-direction:column;padding:0;gap:0}.bib-page:has(.emulator-rom-bar) .emulator-left{flex:1;min-height:0;display:flex;flex-direction:column;gap:0;width:100%}.bib-page:has(.emulator-rom-bar) .emulator-right{display:none}}.emulator-rom-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg)}.emulator-rom-icon{width:32px;height:32px;border-radius:var(--r-sm);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.emulator-rom-info{flex:1;min-width:0}.emulator-rom-name{font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.emulator-rom-meta{font-size:.75rem;color:var(--text-muted)}.emulator-badge{display:inline-block;padding:3px 8px;border-radius:var(--r-full);font-size:.7rem;font-weight:600;letter-spacing:.3px;flex-shrink:0}.emulator-badge--running{background:#2563eb1f;color:var(--accent);border:1px solid var(--accent)}.emulator-badge--paused{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.emulator-screen-box{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}.emulator-screen-area{background:#000;display:flex;align-items:center;justify-content:center;padding:16px;min-height:240px}.emulator-screen-controls{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.emulator-screen-hint{font-size:.75rem;color:var(--text-muted)}.emulator-error-msg{font-size:.75rem;color:#ef4444}.emu-canvas-wrapper{position:relative;display:flex;align-items:center;justify-content:center;border-radius:var(--r-lg);overflow:hidden;background:#000;max-width:100%}.emu-canvas{display:block;width:100%;height:100%}.emu-canvas-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000c;gap:8px}.emu-canvas-overlay-text{font-family:monospace;font-size:.85rem;color:var(--text-muted)}.emu-canvas-overlay-text--paused{color:#facc15;text-transform:uppercase;letter-spacing:4px}.emu-canvas-overlay-text--error{color:#ef4444}.emu-canvas-overlay-text--loading{animation:emulatorPulse 1s ease-in-out infinite}.emulator-screen-box:fullscreen,.emulator-screen-box:-webkit-full-screen{display:flex!important;flex-direction:column!important;width:100vw!important;height:100vh!important;background:#000!important;border:none!important;border-radius:0!important;overflow:hidden!important}.emulator-screen-box:fullscreen .emulator-screen-area,.emulator-screen-box:-webkit-full-screen .emulator-screen-area{flex:1!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;min-height:0!important;background:#000!important;overflow:hidden!important}.emulator-screen-box:fullscreen .emu-canvas-wrapper,.emulator-screen-box:-webkit-full-screen .emu-canvas-wrapper{width:auto!important;height:100%!important;max-height:calc(100vh - 52px)!important;aspect-ratio:256 / 240!important;background:#000!important;border-radius:0!important}.emulator-screen-box:fullscreen .emu-canvas,.emulator-screen-box:-webkit-full-screen .emu-canvas{width:100%!important;height:100%!important;image-rendering:pixelated;image-rendering:crisp-edges}.emulator-screen-box:fullscreen .emulator-screen-controls,.emulator-screen-box:-webkit-full-screen .emulator-screen-controls{flex-shrink:0!important;background:#000000d9!important;border-top:1px solid rgba(255,255,255,.08)!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;padding:8px 16px!important;min-height:52px!important;box-sizing:border-box!important}.emulator-screen-box:fullscreen .emu-btn,.emulator-screen-box:-webkit-full-screen .emu-btn{background:#ffffff1a!important;border-color:#fff3!important;color:#fff!important}.emulator-screen-box:fullscreen .emu-btn:hover:not(:disabled),.emulator-screen-box:-webkit-full-screen .emu-btn:hover:not(:disabled){background:#ffffff2e!important}.emulator-screen-box:fullscreen .emu-btn--primary,.emulator-screen-box:-webkit-full-screen .emu-btn--primary{background:var(--accent)!important;border-color:var(--accent)!important}.emulator-screen-box:fullscreen .emulator-screen-hint,.emulator-screen-box:-webkit-full-screen .emulator-screen-hint{color:#ffffff80!important}@media(max-width:640px){.emulator-rom-bar{padding:6px 12px;flex-shrink:0;border-radius:0;border-left:none;border-right:none}.emulator-rom-icon{width:28px;height:28px;font-size:14px}.emulator-rom-name{font-size:.8rem}.bib-page:has(.emulator-rom-bar) .emulator-screen-box{flex:1;min-height:0;display:flex;flex-direction:column;border-radius:0;border-left:none;border-right:none;overflow:visible}.bib-page:has(.emulator-rom-bar) .emulator-screen-area{flex:1;min-height:0;padding:0;position:relative;overflow:hidden}.bib-page:has(.emulator-rom-bar) .emu-canvas-wrapper{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;max-width:100%!important;aspect-ratio:unset!important;display:flex!important;align-items:center!important;justify-content:center!important;background:#000!important;border-radius:0!important;overflow:hidden!important}.bib-page:has(.emulator-rom-bar) .emu-canvas{width:100%!important;height:auto!important;max-height:100%!important;aspect-ratio:256 / 240!important;image-rendering:pixelated;image-rendering:crisp-edges;display:block!important}.bib-page:has(.emulator-rom-bar) .emulator-screen-controls{display:none}}@media(orientation:landscape)and (max-width:1024px){.emulator-rom-bar{padding:4px 12px;flex-shrink:0;border-radius:0;border-left:none;border-right:none}.bib-page:has(.emulator-rom-bar) .emulator-screen-box{flex:1;min-height:0;display:flex;flex-direction:column;border-radius:0;border-left:none;border-right:none;overflow:hidden;position:relative}.bib-page:has(.emulator-rom-bar) .emulator-screen-area{flex:1;min-height:0;padding:0;position:relative;overflow:hidden}.bib-page:has(.emulator-rom-bar) .emu-canvas-wrapper{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;max-width:100%!important;aspect-ratio:unset!important;display:flex!important;align-items:center!important;justify-content:center!important;background:#000!important;border-radius:0!important;overflow:hidden!important}.bib-page:has(.emulator-rom-bar) .emu-canvas{height:100%!important;width:auto!important;max-width:100%!important;aspect-ratio:256 / 240!important;image-rendering:pixelated;image-rendering:crisp-edges;display:block!important}.bib-page:has(.emulator-rom-bar) .emulator-screen-controls{position:absolute;top:6px;right:6px;z-index:25;background:transparent;border:none;padding:0;gap:0}.bib-page:has(.emulator-rom-bar) .emulator-screen-controls .emulator-screen-hint,.bib-page:has(.emulator-rom-bar) .emulator-screen-controls .emu-btn:not(.emu-btn--icon),.bib-page:has(.emulator-rom-bar) .emulator-screen-controls .emu-btn-spacer,.bib-page:has(.emulator-rom-bar) .emulator-screen-controls .emulator-error-msg{display:none}.bib-page:has(.emulator-rom-bar) .emulator-screen-controls .emu-btn--icon{background:#0000008c;border-color:#ffffff4d;color:#fff}}.emu-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--r-md);font-size:.8rem;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--surface-1);color:var(--text-primary);transition:background var(--fast) ease,border-color var(--fast) ease,transform var(--fast) ease}.emu-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-focus);transform:translateY(-1px)}.emu-btn:disabled{opacity:.5;cursor:not-allowed}.emu-btn--primary{background:var(--accent);border-color:var(--accent);color:var(--text-on-blue)}.emu-btn--primary:hover:not(:disabled){background:var(--accent);filter:brightness(1.1)}.emu-btn--icon{padding:6px 8px;color:var(--text-muted);flex-shrink:0}.emu-btn--icon:hover:not(:disabled){color:var(--text-primary);transform:none}.emu-btn-spacer{flex:1}.emulator-gamepad{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);padding:16px;display:flex;align-items:center;justify-content:space-between;gap:16px}.emu-dpad{display:grid;grid-template-columns:repeat(3,36px);grid-template-rows:repeat(3,36px);gap:2px}.emu-dpad-btn{width:36px;height:36px;border-radius:6px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;transition:background var(--fast) ease,transform 75ms ease}.emu-dpad-btn:active{transform:scale(.9);background:var(--surface-2);filter:brightness(.85)}.emu-dpad-center{width:36px;height:36px;border-radius:6px;background:var(--surface-2);border:1px solid var(--border);opacity:.35}.emu-sys-btns{display:flex;gap:10px}.emu-sys-btn{height:28px;padding:0 14px;border-radius:var(--r-full);background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);font-size:.65rem;font-weight:600;letter-spacing:.5px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;transition:background var(--fast) ease,transform 75ms ease}.emu-sys-btn:active{transform:scale(.9);filter:brightness(.85)}.emu-action-btns{display:grid;grid-template-columns:repeat(2,40px);grid-template-rows:repeat(2,40px);gap:8px}.emu-action-btn{width:40px;height:40px;border-radius:50%;background:var(--accent);border:1px solid var(--accent);color:var(--text-on-blue);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;box-shadow:var(--sh-md);transition:transform 75ms ease,filter 75ms ease}.emu-action-btn:active{transform:scale(.9);filter:brightness(.85)}@media(max-width:640px){.bib-page:has(.emulator-rom-bar) .emulator-gamepad{position:absolute;bottom:0;left:0;right:0;z-index:20;background:transparent;border:none;border-radius:0;padding:0 16px 14px;align-items:flex-end;justify-content:space-between}.emu-dpad{grid-template-columns:repeat(3,52px);grid-template-rows:repeat(3,52px);gap:3px}.emu-dpad-btn{width:52px;height:52px;border-radius:8px;font-size:18px;background:#14141eb8;border-color:#ffffff2e;color:#ffffffe6}.emu-dpad-center{width:52px;height:52px;border-radius:8px;background:transparent;border-color:transparent;opacity:1}.emu-sys-btns{flex-direction:column;justify-content:center;gap:8px;align-self:center}.emu-sys-btn{height:32px;padding:0 14px;font-size:.65rem;background:#14141eb8;border-color:#ffffff2e;color:#fffc}.emu-action-btns{grid-template-columns:repeat(2,52px);grid-template-rows:repeat(2,52px);gap:8px}.emu-action-btn{width:52px;height:52px;font-size:1rem;box-shadow:0 2px 12px #00000080}}@media(orientation:landscape)and (max-width:1024px){.bib-page:has(.emulator-rom-bar) .emulator-gamepad{position:absolute;width:100vw;bottom:0;right:0;z-index:20;background:transparent;border:none;border-radius:0;padding:0 12px;align-items:center;justify-content:space-between;pointer-events:none}.bib-page:has(.emulator-rom-bar) .emulator-gamepad>*{pointer-events:auto}.emu-dpad{grid-template-columns:repeat(3,48px);grid-template-rows:repeat(3,48px);gap:3px}.emu-dpad-btn{width:48px;height:48px;border-radius:8px;font-size:16px;background:#14141eb8;border-color:#ffffff2e;color:#ffffffe6}.emu-dpad-center{width:48px;height:48px;border-radius:8px;background:transparent;border-color:transparent;opacity:1}.emu-sys-btns{flex-direction:row;gap:8px;align-self:flex-end;padding-bottom:12px}.emu-sys-btn{height:32px;padding:0 14px;font-size:.65rem;background:#14141eb8;border-color:#ffffff2e;color:#fffc}.emu-action-btns{grid-template-columns:repeat(2,48px);grid-template-rows:repeat(2,48px);gap:8px}.emu-action-btn{width:48px;height:48px;font-size:.9rem;box-shadow:0 2px 12px #00000080}}.emu-uploader{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;border:2px dashed var(--border);border-radius:var(--r-xl);background:var(--surface-1);text-align:center;cursor:pointer;transition:border-color var(--fast) ease,background var(--fast) ease}.emu-uploader:hover,.emu-uploader--dragging{border-color:var(--accent);background:var(--accent-dim)}.emu-uploader--disabled{pointer-events:none;opacity:.5}.emu-uploader-icon{width:52px;height:52px;border-radius:50%;background:#2563eb1a;display:flex;align-items:center;justify-content:center;font-size:24px}.emu-uploader-text{font-size:.875rem;font-weight:500;color:var(--text-primary);margin:0}.emu-uploader-hint{font-size:.75rem;color:var(--text-muted);margin:0}.emu-systems{display:flex;flex-direction:column;gap:8px}.emu-system-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1)}.emu-system-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.emu-system-ext{font-size:.65rem;font-family:monospace;padding:3px 7px;border-radius:var(--r-sm);font-weight:700;letter-spacing:.3px}.emu-system-ext--gb{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.emu-system-ext--nes{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.emu-icon-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-1);color:var(--text-muted);cursor:pointer;font-size:12px;transition:background var(--fast) ease,color var(--fast) ease}.emu-icon-btn:hover{background:var(--surface-2);color:var(--text-primary)}.emu-modal-overlay{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn var(--fast) ease}.emu-modal{background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-xl);width:100%;max-width:380px;max-height:85dvh;overflow-y:auto;box-shadow:var(--sh-lg);animation:popIn var(--normal) cubic-bezier(.175,.885,.32,1.275);scrollbar-width:none}.emu-modal::-webkit-scrollbar{display:none}.emu-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-weight:700;font-size:.95rem;color:var(--text-primary);position:sticky;top:0;background:var(--surface-1);z-index:2}.emu-modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--r-sm);background:none;color:var(--text-muted);cursor:pointer;font-size:14px;transition:background var(--fast) ease,color var(--fast) ease}.emu-modal-close:hover{background:var(--surface-2);color:var(--text-primary)}.emu-modal-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 20px;position:sticky;top:57px;background:var(--surface-1);z-index:1}.emu-modal-tab{padding:10px 14px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-weight:500;font-size:.82rem;cursor:pointer;transition:color var(--fast) ease,border-color var(--fast) ease;margin-bottom:-1px;white-space:nowrap}.emu-modal-tab:hover{color:var(--text-primary)}.emu-modal-tab--active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.emu-modal-body{padding:20px;display:flex;flex-direction:column;gap:20px}.emu-modal-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px}.emu-config-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);gap:12px}.emu-config-row:last-child{border-bottom:none}.emu-config-label{font-size:.85rem;color:var(--text-secondary);flex-shrink:0}.emu-zoom-slider{-webkit-appearance:none;appearance:none;width:96px;height:4px;border-radius:2px;background:var(--border);outline:none;cursor:pointer;flex-shrink:0}.emu-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 0 3px #2563eb33;transition:box-shadow var(--fast) ease}.emu-zoom-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;box-shadow:0 0 0 3px #2563eb33}.emu-zoom-slider:hover::-webkit-slider-thumb{box-shadow:0 0 0 5px #2563eb40}.emu-zoom-value{font-size:.82rem;font-weight:700;color:var(--accent);min-width:24px;text-align:center;flex-shrink:0}.emu-toggle{position:relative;width:40px;height:22px;flex-shrink:0}.emu-toggle input{opacity:0;width:0;height:0;position:absolute}.emu-toggle-track{position:absolute;inset:0;border-radius:var(--r-full);background:var(--border);cursor:pointer;transition:background var(--fast) ease}.emu-toggle input:checked+.emu-toggle-track{background:var(--accent)}.emu-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--fast) ease;box-shadow:0 1px 3px #0003}.emu-toggle input:checked+.emu-toggle-track:after{transform:translate(18px)}.emu-keybind-table{display:flex;flex-direction:column;gap:0}.emu-keybind-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.emu-keybind-row:last-child{border-bottom:none}.emu-keybind-label{font-size:.82rem;color:var(--text-secondary)}.emu-keybind-key{font-family:monospace;font-size:.72rem;padding:3px 8px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--text-primary);cursor:pointer;min-width:58px;text-align:center;transition:background var(--fast) ease,border-color var(--fast) ease}.emu-keybind-key:hover{background:var(--surface-0);border-color:var(--accent);color:var(--accent)}.emu-keybind-key--listening{background:var(--accent);border-color:var(--accent);color:var(--text-on-blue);animation:emulatorPulse .8s ease-in-out infinite}.emu-save-slots{display:flex;flex-direction:column;gap:8px}.emu-save-slot{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);transition:border-color var(--fast) ease}.emu-save-slot:hover{border-color:var(--border-md)}.emu-save-slot-info{flex:1;min-width:0}.emu-save-slot-label{font-size:.82rem;font-weight:600;color:var(--text-primary);margin:0}.emu-save-slot-date{font-size:.72rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0}.emu-save-slot-actions{display:flex;gap:4px;flex-shrink:0}.mame-emulator-page{min-height:100dvh;width:100%;overflow-y:auto;background:var(--surface-0);color:var(--text-primary);padding:1.25rem 1.5rem 4rem;box-sizing:border-box}.mame-emulator-page::-webkit-scrollbar{width:10px}.mame-emulator-page::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:var(--r-full)}.mame-nav{max-width:1220px;margin:0 auto 1rem}.mame-nav-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.mame-shell{width:100%;max-width:1220px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.mame-hero,.mame-panel,.mame-stage-panel,.mame-side-panel{border:1px solid var(--border);background:var(--surface-1);box-shadow:var(--sh-sm)}.mame-hero{border-radius:var(--r-lg);padding:1.25rem;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1rem;align-items:end}.mame-kicker{grid-column:1 / -1;display:inline-flex;align-items:center;gap:.45rem;color:var(--accent);font-size:.78rem;font-weight:800}.mame-hero-copy{min-width:0}.mame-hero h1{margin:0;color:var(--text-primary);font-family:var(--font-disp);font-size:clamp(1.8rem,4vw,3.1rem);line-height:1.02;letter-spacing:0}.mame-hero p{max-width:760px;margin:.65rem 0 0;color:var(--text-secondary);font-size:.98rem;line-height:1.65}.mame-hero-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.mame-privacy-pill{display:inline-flex;align-items:center;gap:.45rem;min-height:34px;padding:0 .75rem;border-radius:var(--r-full);background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);font-size:.8rem;font-weight:700;white-space:nowrap}.mame-workspace{display:grid;grid-template-columns:minmax(310px,390px) minmax(0,1fr) 250px;gap:1rem;align-items:start}.mame-panel,.mame-stage-panel,.mame-side-panel{border-radius:var(--r-lg)}.mame-panel,.mame-side-panel{padding:1rem}.mame-loader-panel{display:flex;flex-direction:column;gap:1rem}.mame-panel-header,.mame-stage-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.mame-stage-actions{display:inline-flex;align-items:center;gap:.45rem;flex-shrink:0}.mame-section-eyebrow{margin:0 0 .25rem;color:var(--text-muted);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:0}.mame-panel h2,.mame-stage-header h2{margin:0;color:var(--text-primary);font-size:1rem;line-height:1.2}.mame-core-selector{display:grid;gap:.5rem}.mame-core-option{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.25rem .65rem;align-items:start;min-height:76px;padding:.75rem;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);cursor:pointer;transition:border-color var(--fast),background var(--fast),transform var(--fast)}.mame-core-option:hover,.mame-core-option--active{border-color:var(--border-focus);background:var(--accent-dim)}.mame-core-option:has(input:focus-visible){outline:2px solid var(--accent);outline-offset:2px}.mame-core-option input{margin-top:.15rem;accent-color:var(--accent)}.mame-core-label{color:var(--text-primary);font-size:.88rem;font-weight:800}.mame-core-detail{grid-column:2;color:var(--text-muted);font-size:.78rem;line-height:1.45}.mame-file-grid{display:grid;gap:.65rem}.mame-file-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);overflow:hidden}.mame-file-card--ready{border-color:var(--border-md)}.mame-file-card--invalid{border-color:var(--danger)}.mame-file-drop{display:grid;grid-template-columns:42px minmax(0,1fr);gap:.7rem;min-height:104px;padding:.85rem;cursor:pointer}.mame-file-drop input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.mame-file-icon{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--surface-2);color:var(--accent)}.mame-file-content{min-width:0;display:flex;flex-direction:column;gap:.28rem}.mame-file-title{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-size:.9rem;font-weight:800}.mame-required{border-radius:var(--r-full);background:var(--accent-dim);color:var(--accent);padding:.15rem .45rem;font-size:.65rem;font-weight:800}.mame-file-description,.mame-file-helper{color:var(--text-secondary);font-size:.78rem;line-height:1.4}.mame-file-helper{color:var(--text-muted)}.mame-file-meta{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:.5rem;align-items:center;padding:.55rem .75rem;border-top:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.76rem}.mame-file-meta span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mame-file-checks{display:grid;gap:.35rem;padding:.6rem .75rem .7rem;border-top:1px solid var(--border);background:var(--surface-0)}.mame-file-check{display:flex;align-items:flex-start;gap:.4rem;margin:0;font-size:.75rem;line-height:1.35}.mame-file-check svg{flex-shrink:0;margin-top:.05rem}.mame-file-check--ok{color:var(--success)}.mame-file-check--info{color:var(--text-muted)}.mame-file-check--warning{color:color-mix(in srgb,var(--warning) 78%,var(--text-primary))}.mame-file-check--error{color:var(--danger)}.mame-inline-action{border:0;background:transparent;color:var(--accent);font:inherit;font-weight:800;cursor:pointer}.mame-inline-action:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mame-alert{display:flex;align-items:flex-start;gap:.55rem;border-radius:var(--r-md);padding:.75rem;font-size:.82rem;line-height:1.45}.mame-alert--warning{background:color-mix(in srgb,var(--warning) 12%,var(--surface-0));color:var(--text-primary);border:1px solid color-mix(in srgb,var(--warning) 30%,transparent)}.mame-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.65rem}.mame-primary-button,.mame-secondary-button,.mame-icon-button{border:1px solid transparent;min-height:40px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font:inherit;font-weight:800;cursor:pointer;transition:transform var(--fast),box-shadow var(--fast),background var(--fast),color var(--fast)}.mame-primary-button{background:var(--accent);color:var(--text-on-blue);box-shadow:var(--sh-blue)}.mame-secondary-button,.mame-icon-button{background:var(--surface-0);border-color:var(--border);color:var(--text-primary)}.mame-primary-button:hover,.mame-secondary-button:hover,.mame-icon-button:hover:not(:disabled){transform:translateY(-1px)}.mame-primary-button:focus-visible,.mame-secondary-button:focus-visible,.mame-icon-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mame-secondary-button:disabled,.mame-icon-button:disabled{opacity:.45;cursor:not-allowed}.mame-stage-panel{min-width:0;padding:1rem;display:flex;flex-direction:column;gap:.85rem}.mame-icon-button{width:40px;padding:0;flex-shrink:0}.mame-stage{width:100%;aspect-ratio:4 / 3;min-height:420px;overflow:hidden;border-radius:var(--r-md);background:var(--surface-4);border:1px solid var(--border)}.mame-stage:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.mame-stage:fullscreen{border-radius:0;border:0;background:var(--surface-0)}.mame-frame{width:100%;height:100%;display:block;border:0;background:var(--surface-0)}.mame-stage-empty{width:100%;height:100%;min-height:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;padding:1.5rem;text-align:center;color:var(--text-secondary);box-sizing:border-box}.mame-stage-empty svg{color:var(--accent)}.mame-stage-empty p{margin:0;color:var(--text-primary);font-weight:800}.mame-stage-empty span{max-width:420px;color:var(--text-muted);font-size:.84rem;line-height:1.5}.mame-status-row{min-height:38px;display:flex;align-items:center;gap:.55rem;padding:.65rem .75rem;border-radius:var(--r-md);background:var(--surface-2);color:var(--text-secondary);font-size:.82rem;line-height:1.45}.mame-status-dot{width:.55rem;height:.55rem;flex-shrink:0;border-radius:var(--r-full);background:var(--success);box-shadow:0 0 0 4px color-mix(in srgb,var(--success) 14%,transparent)}.mame-status-row--info .mame-status-dot{background:var(--info);box-shadow:0 0 0 4px color-mix(in srgb,var(--info) 14%,transparent)}.mame-status-row--warning .mame-status-dot{background:var(--warning);box-shadow:0 0 0 4px color-mix(in srgb,var(--warning) 16%,transparent)}.mame-status-row--error .mame-status-dot{background:var(--danger);box-shadow:0 0 0 4px color-mix(in srgb,var(--danger) 14%,transparent)}.mame-side-panel{display:grid;gap:.85rem}.mame-tip{display:flex;flex-direction:column;gap:.25rem;padding-bottom:.85rem;border-bottom:1px solid var(--border)}.mame-tip:last-child{padding-bottom:0;border-bottom:0}.mame-tip strong{color:var(--text-primary);font-size:.93rem}.mame-tip span{color:var(--text-secondary);font-size:.8rem;line-height:1.5}@media(max-width:1100px){.mame-workspace{grid-template-columns:minmax(300px,380px) minmax(0,1fr)}.mame-side-panel{grid-column:1 / -1;grid-template-columns:repeat(3,minmax(0,1fr))}.mame-tip{padding-bottom:0;border-bottom:0;border-right:1px solid var(--border);padding-right:.85rem}.mame-tip:last-child{border-right:0;padding-right:0}}@media(max-width:820px){.mame-emulator-page{padding:.9rem 1rem 3rem}.mame-hero{grid-template-columns:1fr;align-items:start}.mame-hero-actions{justify-content:flex-start}.mame-workspace,.mame-side-panel{grid-template-columns:1fr}.mame-tip{border-right:0;padding-right:0;padding-bottom:.85rem;border-bottom:1px solid var(--border)}.mame-stage,.mame-stage-empty{min-height:320px}}@media(max-width:560px){.mame-nav{min-height:52px;margin-bottom:.7rem}.mame-hero,.mame-panel,.mame-stage-panel,.mame-side-panel{border-radius:var(--r-md)}.mame-hero h1{font-size:1.75rem}.mame-file-drop{grid-template-columns:1fr}.mame-file-icon{width:38px;height:38px}.mame-file-meta{grid-template-columns:1fr auto}.mame-file-meta .mame-inline-action{grid-column:1 / -1;justify-self:start}.mame-actions{grid-template-columns:1fr}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center;color:var(--text-muted);flex:1}.empty-state svg{opacity:.25;color:var(--accent)}.empty-state h3{color:var(--text-secondary);font-size:1rem}.empty-state p{font-size:.85rem;max-width:280px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--r-md);border:none;font-size:.82rem;font-weight:600;transition:all var(--fast);cursor:pointer;white-space:nowrap}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:#fff;box-shadow:var(--sh-blue)}.btn-primary:hover{filter:brightness(1.08)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-md)}.btn-danger{background:#ef444414;color:var(--danger);border:1px solid rgba(239,68,68,.25)}.btn-danger:hover{background:#ef444429}.btn-icon{display:flex;align-items:center;width:32px;height:32px;padding:0;justify-content:center;border-radius:var(--r-md);border:1px solid var(--border);background:transparent;color:var(--text-muted)}.btn-icon:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-md)}.stats-bar{display:flex;align-items:center;gap:16px;padding:0 16px;height:36px;background:var(--surface-1);border-bottom:1px solid var(--border);font-size:.75rem;color:var(--text-muted);flex-shrink:0;overflow-x:auto}.stat-item{display:flex;align-items:center;gap:5px;white-space:nowrap}.stat-val{color:var(--accent);font-weight:700;font-variant-numeric:tabular-nums}.stat-sep{color:var(--border-md)}.toast-wrap{position:fixed;bottom:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:6px;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:10px 14px;background:color-mix(in srgb,var(--surface-0) 25%,transparent);border:1px solid color-mix(in srgb,var(--border-md) 60%,transparent);border-radius:var(--r-md);font-size:.82rem;font-weight:500;box-shadow:var(--sh-md),0 4px 30px #0000001a;animation:toast-in var(--normal) ease,toast-out .3s ease 2.7s forwards;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--text-primary)}.toast-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{to{opacity:0;transform:translate(16px)}}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex-center{display:flex;align-items:center;justify-content:center}.divider{height:1px;background:var(--border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.anim-fade{animation:fadeIn var(--normal) ease}.anim-up{animation:slideUp var(--normal) ease forwards}.grid-bg-pattern{background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:32px 32px}.modal-backdrop{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn var(--fast) ease}.modal-window{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:440px;box-shadow:var(--sh-lg);display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.form-group input.search-input{background:var(--surface-1)}.splash-screen{position:fixed;inset:0;z-index:999999;background-color:var(--surface-0);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease-out,visibility .5s ease-out}.splash-screen.hide{opacity:0;visibility:hidden;pointer-events:none}.splash-image{width:200px;height:auto;object-fit:contain;animation:popIn .5s cubic-bezier(.16,1,.3,1) forwards}.export-dropdown{position:absolute;top:calc(100% + 8px);right:0;z-index:1000;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:0 8px 32px #0000002e,0 2px 8px #0000001a;padding:6px;min-width:260px;animation:dropdown-in .15s ease}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.export-option{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;border-radius:var(--r-md);border:none;background:transparent;color:var(--text-primary);cursor:pointer;text-align:left;transition:background var(--fast),color var(--fast)}.export-option:hover{background:var(--accent-dim);color:var(--accent)}.export-option svg{flex-shrink:0;opacity:.75}.export-option-title{font-size:.84rem;font-weight:600;line-height:1.3}.export-option-sub{font-size:.72rem;color:var(--text-muted);margin-top:1px;line-height:1.3}.export-option:hover .export-option-sub{color:var(--accent);opacity:.8}.coming-soon-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;text-align:center;padding:24px;background:var(--surface-0);position:relative;overflow:hidden}.cs-blob{position:absolute;filter:blur(80px);border-radius:50%;z-index:0;opacity:.5;animation:blob-float 10s infinite alternate cubic-bezier(.4,0,.2,1)}.cs-blob-1{width:300px;height:300px;background:var(--blue-400);top:-50px;left:-100px}.cs-blob-2{width:250px;height:250px;background:#a855f7;bottom:-50px;right:-50px;animation-delay:-5s}[data-theme=dark] .cs-blob{opacity:.25}@keyframes blob-float{0%{transform:translateY(0) scale(1)}to{transform:translateY(40px) scale(1.1)}}.cs-card{position:relative;z-index:10;background:rgba(var(--surface-0-rgb, 255, 255, 255),.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--r-xl);padding:40px 30px;max-width:440px;width:100%;box-shadow:var(--sh-lg);display:flex;flex-direction:column;align-items:center}[data-theme=dark] .cs-card{background:#0b112099}.cs-icon-wrapper{width:80px;height:80px;background:linear-gradient(135deg,var(--surface-0),var(--surface-2));border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:3rem;box-shadow:0 8px 32px #00000014;margin-bottom:24px;border:1px solid var(--border)}.cs-title{font-size:1.8rem;font-weight:800;margin-bottom:12px;background:linear-gradient(135deg,var(--text-primary),var(--text-muted));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}.cs-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:30px}.cs-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,var(--accent),#a855f7);color:#fff;padding:8px 20px;border-radius:var(--r-full);font-size:.8rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:40px;box-shadow:0 4px 16px var(--accent-glow)}.cs-badge{animation:floating 3s ease-in-out infinite}@keyframes floating{0%{transform:translateY(0)}50%{transform:translateY(-5px)}to{transform:translateY(0)}}.cs-blob-404-1{width:320px;height:320px;background:radial-gradient(circle,#38bdf8,#3b82f6);top:-80px;left:-80px;opacity:.4;animation:blob-float 9s infinite alternate cubic-bezier(.4,0,.2,1)}.cs-blob-404-2{width:260px;height:260px;background:radial-gradient(circle,#818cf8,#6366f1);bottom:-60px;right:-60px;opacity:.35;animation:blob-float 12s infinite alternate-reverse cubic-bezier(.4,0,.2,1)}.cs-blob-404-3{width:180px;height:180px;background:radial-gradient(circle,#22d3ee,#38bdf8);top:40%;right:10%;opacity:.25;animation:blob-float 7s infinite alternate cubic-bezier(.4,0,.2,1);animation-delay:-3s}[data-theme=dark] .cs-blob-404-1,[data-theme=dark] .cs-blob-404-2,[data-theme=dark] .cs-blob-404-3{opacity:.18}.nf-card{max-width:480px;gap:0}.nf-number-wrap{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:20px;position:relative}.nf-number{font-family:var(--font-disp);font-size:5.5rem;font-weight:900;line-height:1;letter-spacing:-.04em;background:linear-gradient(135deg,#38bdf8,#3b82f6,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 4px 24px rgba(59,130,246,.4));animation:nf-pulse 3.5s ease-in-out infinite}@keyframes nf-pulse{0%,to{filter:drop-shadow(0 4px 24px rgba(59,130,246,.35))}50%{filter:drop-shadow(0 4px 40px rgba(59,130,246,.7))}}.nf-circle-icon{color:#3b82f6;opacity:.85;display:flex;align-items:center;margin:0 4px;animation:floating 3s ease-in-out infinite}[data-theme=dark] .nf-circle-icon{color:#60a5fa}.nf-title{font-size:1.5rem!important;margin-bottom:10px}.nf-desc{margin-bottom:28px;font-size:.9rem!important}.nf-code{display:inline-block;background:#3b82f614;border:1px solid rgba(59,130,246,.25);border-radius:var(--r-sm);padding:1px 7px;font-family:Courier New,monospace;font-size:.82em;color:#2563eb;word-break:break-all}[data-theme=dark] .nf-code{color:#60a5fa;background:#3b82f61f;border-color:#3b82f64d}.nf-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:20px;width:100%}.nf-btn-home{padding:11px 24px!important;border-radius:var(--r-full)!important;display:flex!important;align-items:center;gap:8px}.nf-btn-back{padding:11px 20px!important;border-radius:var(--r-full)!important;display:flex!important;align-items:center;gap:8px;border:1.5px solid var(--border)}.nf-hint{font-size:.78rem;color:var(--text-muted);margin:0}.nf-link{background:none;border:none;color:var(--accent);font-size:inherit;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:3px;transition:opacity var(--fast)}.nf-link:hover{opacity:.75}.aulas-page{display:flex;flex-direction:row;height:100vh;background:var(--surface-0);overflow:hidden;padding:0}.aulas-sidebar{width:320px;background:var(--surface-1);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:10;box-shadow:var(--sh-md);transition:width .3s ease}.aulas-sidebar-header{padding:24px;border-bottom:1px solid var(--border)}.aulas-sidebar-logo{display:flex;align-items:center;gap:12px}.aulas-logo-icon{font-size:1.5rem}.aulas-menu-btn,.aulas-sidebar-overlay,.aulas-sidebar-close{display:none}.aulas-logo-text{font-family:var(--font-disp);font-size:1.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.aulas-logo-text small{font-size:.75rem;color:var(--accent);text-transform:uppercase;background:var(--accent-dim);padding:2px 6px;border-radius:4px;margin-left:4px}.aulas-sidebar-content{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:32px}.aulas-sidebar-section{display:flex;flex-direction:column;gap:12px}.aulas-sidebar-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.aulas-sidebar-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.aulas-mode-toggle-group{display:flex;background:var(--surface-2);padding:4px;border-radius:var(--r-md);border:1px solid var(--border)}.aulas-mode-toggle-btn{flex:1;padding:8px;border:none;background:transparent;border-radius:calc(var(--r-md) - 2px);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--fast)}.aulas-mode-toggle-btn:hover:not(.active){background:var(--surface-3);color:var(--text-primary)}.aulas-mode-toggle-btn.active{background:var(--accent);color:#fff;box-shadow:var(--sh-sm)}.aulas-sidebar-search-wrap{position:relative}.aulas-sidebar-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.aulas-sidebar-search-input{width:100%;background:var(--surface-2);border:1px solid var(--border);padding:12px 12px 12px 40px;border-radius:var(--r-md);color:var(--text-primary);font-size:.9rem;font-family:var(--font);transition:all var(--fast)}.aulas-sidebar-search-input:focus{outline:none;border-color:var(--accent);background:var(--surface-1);box-shadow:0 0 0 3px var(--accent-dim)}.aulas-sidebar-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-md);box-shadow:var(--sh-lg);z-index:100;max-height:240px;overflow-y:auto}.aulas-suggestion-item{width:100%;padding:10px 14px;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:.85rem;cursor:pointer}.aulas-suggestion-item:last-child{border-bottom:none}.aulas-suggestion-item:hover{background:var(--accent-dim)}.aulas-suggestion-mark{background:var(--accent);color:#fff;border-radius:2px;padding:0 2px}.aulas-sidebar-filters{display:flex;flex-direction:column;gap:16px;transition:opacity .3s ease}.aulas-sidebar-filters.disabled{opacity:.4;pointer-events:none}.aulas-filter-toggle{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:4px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);cursor:pointer}.aulas-filter-toggle.active{background:var(--success);border-color:var(--success);color:#fff}.aulas-filter-group{display:flex;flex-direction:column;gap:8px;flex:1}.aulas-filter-sublabel{font-size:.7rem;color:var(--text-muted);font-weight:600}.aulas-day-picker{display:flex;gap:4px}.aulas-day-btn{flex:1;aspect-ratio:1;padding:0;border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);border-radius:4px;font-size:.75rem;font-weight:700;cursor:pointer}.aulas-day-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.aulas-filter-row{display:flex;gap:12px}.aulas-sidebar-select{width:100%;background:var(--surface-2);border:1px solid var(--border);color:var(--text-primary);padding:8px 12px;border-radius:6px;font-size:.9rem;transition:all var(--fast)}.aulas-sidebar-select:focus{outline:none;border-color:var(--accent);background:var(--surface-1);box-shadow:0 0 0 3px var(--accent-dim)}input[type=time].aulas-sidebar-select{font-family:var(--font-mono, monospace);letter-spacing:.05em}input[type=time].aulas-sidebar-select::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity var(--fast);filter:invert(.8)}[data-theme=dark] input[type=time].aulas-sidebar-select{color-scheme:dark}input[type=time].aulas-sidebar-select::-webkit-calendar-picker-indicator:hover{opacity:1}.aulas-sidebar-info{margin-top:8px;padding:10px;background:var(--accent-dim);border-radius:8px;color:var(--accent);font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:8px}.aulas-sidebar-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto;padding-right:4px}.aulas-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--fast)}.aulas-list-item:hover{background:var(--surface-3);border-color:var(--accent);color:var(--text-primary);transform:translate(4px)}.aulas-list-item.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.aulas-list-item svg{opacity:0;transition:opacity var(--fast)}.aulas-list-item:hover svg{opacity:1}.aulas-sidebar-hint{font-size:.8rem;color:var(--text-muted);font-style:italic;padding:12px;background:var(--surface-2);border-radius:8px;border:1px dashed var(--border)}.aulas-sidebar-footer{padding:16px 24px;border-top:1px solid var(--border);font-size:.7rem;color:var(--text-muted);text-align:center}.aulas-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.aulas-topbar{height:64px;padding:0 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface-0);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:5}.aulas-back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;padding:8px 12px;border-radius:var(--r-md);transition:all var(--fast);text-decoration:none}.aulas-back-btn:hover{background:var(--accent-dim);color:var(--accent)}.aulas-back-btn svg{flex-shrink:0}.event-block-occupied{transition:all var(--fast)}.event-block-occupied:hover{background:#ef44444d!important;border-color:#ef4444!important;transform:scale(1.01);z-index:10!important;box-shadow:0 4px 12px #ef444433}.aulas-results-container{flex:1;display:flex;flex-direction:column;overflow:hidden;animation:animFadeIn .4s ease}.aulas-results-top{padding:24px;background:var(--surface-0)}.aulas-results-title{font-family:var(--font-disp);font-size:1.5rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin:0 0 8px}.aulas-results-title .accent-text{color:var(--accent)}.aulas-results-legend{display:flex;align-items:center;gap:16px;font-size:.8rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:6px}.dot{width:8px;height:8px;border-radius:2px}.dot.busy{background:var(--danger)}.dot.free{background:var(--success)}.legend-count{margin-left:auto;font-weight:600;color:var(--accent);background:var(--accent-dim);padding:2px 8px;border-radius:4px}.aulas-grid-wrapper{flex:1;overflow:auto;padding:0 24px 24px}.aulas-results-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;gap:16px;padding:40px}.aulas-empty-icon{font-size:4rem;opacity:.5}.aulas-results-placeholder h3{font-size:1.25rem;color:var(--text-secondary);margin:0}.aulas-no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text-muted)}.aulas-no-results h3{color:var(--text-primary);margin:0}.aulas-clear-btn{margin-top:16px;padding:10px 24px;background:transparent;border:1px solid var(--border-md);color:var(--text-secondary);border-radius:var(--r-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--fast)}.aulas-clear-btn:hover{background:var(--surface-2);border-color:var(--text-primary);color:var(--text-primary)}@keyframes animFadeIn{0%{opacity:0}to{opacity:1}}@keyframes animUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.aulas-page{flex-direction:column;height:100dvh;overflow:hidden}.aulas-main{display:contents}.aulas-topbar{order:1;height:60px;padding:0 16px;background:var(--surface-0);border-bottom:1px solid var(--border);z-index:20}.aulas-menu-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;border-radius:var(--r-md);transition:background var(--fast)}.aulas-menu-btn:hover{background:var(--surface-2)}.aulas-sidebar-overlay{display:block;position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;opacity:0;animation:animFadeIn .3s forwards}.aulas-sidebar{position:fixed;top:0;left:0;width:85%;max-width:320px;height:100dvh;max-height:none;border-right:1px solid var(--border-md);border-bottom:none;border-radius:0;background:var(--surface-1);z-index:50;box-shadow:var(--sh-lg);transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;overflow-x:hidden}.aulas-sidebar.open{transform:translate(0)}.aulas-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.aulas-sidebar-close{display:flex;background:var(--surface-2);border:none;color:var(--text-primary);padding:8px;border-radius:50%;cursor:pointer;transition:background var(--fast)}.aulas-sidebar-close:hover{background:var(--surface-3)}.aulas-sidebar-content{padding:16px;gap:16px}.aulas-sidebar-footer{display:none}.aulas-results-container,.aulas-results-placeholder{order:3;flex:1;background:var(--surface-0);z-index:5;overflow-y:auto;margin-top:0;border-radius:0}.aulas-results-top{padding:16px}.aulas-results-title{font-size:1.25rem}.aulas-grid-wrapper{padding:0;overflow-x:auto}.aulas-sidebar-suggestions{max-height:200px}.aulas-no-results{margin:0 3rem;text-align:center}}.home-donation-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 16px;background:linear-gradient(135deg,#2563eb0e,#6366f10a);border:1px solid rgba(37,99,235,.16);border-radius:var(--r-lg);max-width:440px;width:100%;cursor:pointer;transition:all var(--normal);position:relative;overflow:hidden}.home-donation-banner:before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);background:linear-gradient(90deg,transparent 0%,rgba(37,99,235,.04) 50%,transparent 100%);transform:translate(-100%);transition:transform .6s ease}.home-donation-banner:hover:before{transform:translate(100%)}.home-donation-banner:hover{background:linear-gradient(135deg,#2563eb1a,#6366f112);border-color:#2563eb4d;transform:translateY(-1px);box-shadow:0 6px 20px #2563eb1f}.home-donation-left{display:flex;align-items:center;gap:10px;min-width:0}.home-donation-icon{font-size:1.2rem;line-height:1;flex-shrink:0}.home-donation-texts{display:flex;flex-direction:column;gap:2px;min-width:0}.home-donation-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.home-donation-desc{font-size:.82rem;color:var(--text-secondary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-donation-cta{font-size:.78rem;font-weight:700;color:#fff;background:var(--accent);border:none;border-radius:var(--r-full);padding:6px 16px;white-space:nowrap;cursor:pointer;transition:all var(--fast);flex-shrink:0;box-shadow:0 2px 8px #2563eb4d}.home-donation-cta:hover{background:var(--blue-700);box-shadow:0 4px 14px #2563eb66;transform:scale(1.04)}[data-theme=dark] .home-donation-banner{background:linear-gradient(135deg,#3b82f617,#6366f10f);border-color:#3b82f633}.topbar-donate-btn{display:flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;color:var(--text-muted);background:transparent;border:1px solid var(--border);border-radius:var(--r-full);padding:4px 11px;cursor:pointer;transition:all var(--fast);white-space:nowrap}.topbar-donate-btn:hover{color:var(--accent);border-color:#2563eb59;background:var(--accent-dim)}.topbar-donate-btn svg{opacity:.7;transition:transform var(--fast)}.topbar-donate-btn:hover svg{transform:scale(1.2);opacity:1}.donacion-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 48px 64px;background:var(--surface-0);position:relative;overflow:clip}.donacion-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}.donacion-blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.45;animation:blobFloat 12s ease-in-out infinite}[data-theme=dark] .donacion-blob{opacity:.2}.donacion-blob-1{width:500px;height:500px;top:-120px;left:-120px;background:radial-gradient(circle,#2563eb59,#6366f126);animation-duration:14s}.donacion-blob-2{width:400px;height:400px;bottom:-100px;right:-80px;background:radial-gradient(circle,#3b82f64d,#8b5cf61f);animation-duration:10s;animation-delay:-4s}.donacion-blob-3{width:280px;height:280px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(37,99,235,.12),transparent);animation-duration:18s;animation-delay:-7s}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(18px,-24px) scale(1.04)}66%{transform:translate(-14px,18px) scale(.97)}}.donacion-back-btn{position:absolute;top:20px;left:20px;display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--text-muted);background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-full);padding:7px 14px;cursor:pointer;transition:all var(--fast);z-index:10}.donacion-back-btn:hover{color:var(--accent);border-color:var(--border-focus);background:var(--accent-dim);transform:translate(-2px)}.donacion-layout{display:flex;flex-wrap:wrap;gap:64px;align-items:flex-start;max-width:900px;width:100%;position:relative;z-index:1}.donacion-left-header,.donacion-left-features{flex:1 1 calc(50% - 32px);min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:0}.donacion-right-col{flex:1 1 calc(50% - 32px);min-width:0;display:flex;align-items:center;justify-content:center;align-self:stretch}.donacion-left-col{flex:1 1 calc(50% - 32px);min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:0}.donacion-logo-wrap{width:64px;height:64px;border-radius:18px;background:var(--accent-dim);border:1px solid var(--border-focus);display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 8px 24px #2563eb2e}.donacion-logo{width:46px;height:46px;object-fit:contain;border-radius:10px}.donacion-badge{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(37,99,235,.18);border-radius:var(--r-full);padding:4px 14px;margin-bottom:16px;display:inline-block}.donacion-title{font-family:var(--font-disp);font-size:2.6rem;font-weight:800;background:linear-gradient(135deg,var(--blue-700) 0%,var(--blue-500) 50%,#818cf8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 14px;line-height:1.15;letter-spacing:-.03em}.donacion-subtitle{font-size:1rem;color:var(--text-secondary);line-height:1.65;margin:0 0 28px;max-width:380px}.donacion-subtitle strong{color:var(--accent);font-weight:700}.donacion-features{display:flex;flex-direction:column;gap:12px;width:100%;margin-bottom:28px}.donacion-feature-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);transition:all var(--fast)}.donacion-feature-item:hover{border-color:var(--border-focus);background:var(--accent-dim);transform:translate(4px)}.donacion-feature-icon{font-size:1.3rem;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:var(--r-sm)}.donacion-feature-title{font-size:.88rem;font-weight:700;color:var(--text-primary);line-height:1.2}.donacion-feature-sub{font-size:.76rem;color:var(--text-muted);margin-top:2px}.donacion-footer-note{font-size:.82rem;color:var(--text-muted);line-height:1.5;margin:0}.donacion-right-col{display:flex;align-items:center;justify-content:center}.donacion-qr-card{background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-xl);padding:28px;display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:300px;box-shadow:var(--sh-lg),0 0 0 1px var(--border);position:relative;overflow:hidden}.donacion-qr-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-500),#818cf8,var(--blue-400));border-radius:var(--r-xl) var(--r-xl) 0 0}.donacion-qr-card-top{display:flex;align-items:center;justify-content:space-between;width:100%}.donacion-qr-label{font-size:.85rem;font-weight:700;color:var(--text-secondary)}.donacion-qr-amount{font-size:.73rem;font-weight:700;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(37,99,235,.18);border-radius:var(--r-full);padding:3px 10px}.donacion-qr-wrap{width:210px;height:210px;border-radius:var(--r-lg);overflow:hidden;border:2px solid var(--border-md);background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px #2563eb24,inset 0 0 0 4px #fff}.donacion-qr-img{width:100%;height:100%;padding:10px;object-fit:contain}.donacion-qr-hint{font-size:.78rem;color:var(--text-muted);text-align:center;margin:0;line-height:1.5}.donacion-qr-divider{width:100%;height:1px;background:var(--border)}.donacion-qr-footer-row{display:flex;align-items:center;gap:8px;font-size:.74rem;color:var(--text-muted);font-weight:500}.donacion-qr-dot{opacity:.4}@media(max-width:900px){.donacion-page{padding:80px 32px 64px}.donacion-layout{gap:40px}}@media(max-width:640px){.donacion-page{min-height:100dvh;overflow:visible;padding:64px 0 48px;justify-content:flex-start;align-items:stretch}.donacion-bg{opacity:.6}.donacion-back-btn{top:12px;left:12px;font-size:.8rem;padding:6px 12px}.donacion-layout{flex-direction:column;gap:20px;padding:0 16px;width:100%;box-sizing:border-box;align-items:center}.donacion-left-header{order:1;align-items:center;text-align:center;width:100%;flex:none}.donacion-right-col{order:2;width:100%;flex:none}.donacion-left-features{order:3;align-items:center;text-align:center;width:100%;flex:none}.donacion-left-col{order:1;align-items:center;text-align:center;gap:0;width:100%;flex:none}.donacion-logo-wrap{width:52px;height:52px;border-radius:14px;margin-bottom:14px}.donacion-logo{width:36px;height:36px}.donacion-badge{font-size:.68rem;padding:3px 12px;margin-bottom:12px}.donacion-title{font-size:1.75rem;margin-bottom:10px;letter-spacing:-.02em}.donacion-subtitle{font-size:.9rem;max-width:100%;margin-bottom:20px;line-height:1.55}.donacion-features{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;margin-bottom:20px}.donacion-feature-item{padding:10px 12px;gap:8px;align-items:center;box-sizing:border-box;overflow:hidden;text-align:left}.donacion-feature-icon{width:30px;height:30px;font-size:1rem;flex-shrink:0}.donacion-feature-title{font-size:.78rem;line-height:1.3;white-space:normal}.donacion-feature-sub{font-size:.68rem;white-space:normal;line-height:1.3}.donacion-footer-note{font-size:.78rem;line-height:1.5;text-align:center;padding:0 8px}.donacion-right-col{width:100%;display:flex;justify-content:center}.donacion-qr-card{width:auto;max-width:300px;box-sizing:border-box;padding:20px;gap:12px}.donacion-qr-wrap{width:180px;height:180px}.donacion-qr-label{font-size:.82rem}.donacion-qr-hint{font-size:.75rem}.donacion-qr-footer-row{font-size:.72rem;flex-wrap:wrap;justify-content:center;gap:6px}.home-donation-banner{flex-wrap:wrap;gap:8px;max-width:100%}.home-donation-desc{white-space:normal}}.donacion-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:donFadeIn .15s ease}@keyframes donFadeIn{0%{opacity:0}to{opacity:1}}.donacion-modal{background:var(--surface-0);border:1px solid var(--border-md);border-radius:var(--r-xl);padding:32px 28px 28px;max-width:360px;width:100%;position:relative;box-shadow:var(--sh-lg),0 0 0 1px var(--border);animation:donSlideUp .22s cubic-bezier(.34,1.56,.64,1);text-align:center;overflow:hidden}.donacion-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-500),#818cf8,var(--blue-400))}@keyframes donSlideUp{0%{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.donacion-modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-1);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--fast)}.donacion-modal-close:hover{background:var(--surface-2);color:var(--text-primary)}.donacion-modal-icon{font-size:2.4rem;margin-bottom:10px}.donacion-modal-title{font-family:var(--font-disp);font-size:1.4rem;font-weight:800;color:var(--text-primary);margin:0 0 10px;line-height:1.2}.donacion-modal-text{font-size:.88rem;color:var(--text-secondary);line-height:1.65;margin:0 0 18px}.donacion-modal-text strong{color:var(--accent)}.donacion-modal-pills{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:24px}.donacion-modal-pills span{font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full);padding:4px 12px}.donacion-modal-actions{display:flex;flex-direction:column;gap:8px}.donacion-modal-btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:#fff;border:none;border-radius:var(--r-md);font-size:.9rem;font-weight:700;cursor:pointer;transition:all var(--fast);box-shadow:var(--sh-blue)}.donacion-modal-btn-primary:hover{background:linear-gradient(135deg,var(--blue-700),var(--blue-600));transform:translateY(-1px);box-shadow:0 6px 20px #2563eb61}.donacion-modal-btn-ghost{padding:9px 20px;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--r-md);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--fast)}.donacion-modal-btn-ghost:hover{background:var(--surface-1);color:var(--text-secondary)}.bib-page{min-height:100dvh;background:var(--surface-0);display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1.25rem 1.5rem 4rem;width:100%;box-sizing:border-box;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.bib-page::-webkit-scrollbar{display:none}.bib-page>*{width:100%;max-width:900px;flex-shrink:0}.bib-nav{display:flex;align-items:center;gap:.8rem;min-height:64px;padding:0;width:100%;max-width:1200px;margin:0 auto;box-sizing:border-box}.bib-back-arrow{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--r-md);color:var(--text-muted);text-decoration:none;flex-shrink:0;background:none;border:none;padding:0;cursor:pointer;transition:background var(--fast),color var(--fast)}.bib-back-arrow:hover{background:var(--accent-dim);color:var(--accent)}.bib-breadcrumb{display:flex;align-items:center;list-style:none;margin:0;padding:0;gap:0;flex-wrap:nowrap;overflow:hidden}.bib-bc-item{display:inline-flex;align-items:center;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.bib-bc-item a{color:var(--text-muted);text-decoration:none;transition:color var(--fast)}.bib-bc-item>span[aria-current=page]{color:var(--text-primary);font-weight:600;overflow:hidden;text-overflow:ellipsis}.bib-bc-sep{color:var(--text-muted);opacity:.4;margin:0 .3rem;flex-shrink:0}.bib-cover{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);line-height:0;flex-shrink:0}.bib-cover-img{width:100%;height:220px;object-fit:cover;object-position:center;display:block}.bib-section-heading{font-family:var(--font-disp);font-size:1.4rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin:0}.bib-step-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-radius:var(--r-lg);background:var(--surface-1);border:1px solid var(--border);border-left:3px solid var(--fac-c2, var(--accent));overflow:hidden;position:relative}.bib-step-header:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(var(--fac-c1),.06) 0%,transparent 70%);pointer-events:none}.bib-step-logo-wrap{width:52px;height:52px;flex-shrink:0;border-radius:var(--r-md);overflow:hidden;background:linear-gradient(135deg,var(--fac-c1, #1e3a8a),var(--fac-c2, #2563eb));display:flex;align-items:center;justify-content:center;border:1px solid var(--border-md)}.bib-step-logo{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.bib-step-info{flex:1;min-width:0}.bib-step-fac{font-size:.72rem;color:var(--text-muted);letter-spacing:.02em}.bib-step-title{font-family:var(--font-disp);font-size:1.1rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bib-fac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.bib-fac-card{position:relative;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--r-xl);border:1px solid var(--border);cursor:pointer;text-align:left;background:var(--surface-1);animation:animUp .45s cubic-bezier(.16,1,.3,1) both;transition:transform var(--normal),box-shadow var(--normal),border-color var(--normal)}.bib-fac-card:hover{transform:translateY(-7px) scale(1.015);border-color:var(--fac-c2);box-shadow:0 20px 60px var(--fac-glow),0 4px 20px #00000040}.bib-fac-visual{height:180px;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--fac-c1),var(--fac-c2));overflow:hidden}.bib-fac-img{width:115px;height:115px;object-fit:contain;position:relative;z-index:2;filter:drop-shadow(0 8px 24px rgba(0,0,0,.45)) brightness(1.05);transition:transform var(--normal)}.bib-fac-card:hover .bib-fac-img{transform:scale(1.08) translateY(-3px)}.bib-fac-shine{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 15% 10%,rgba(255,255,255,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 85% 95%,rgba(0,0,0,.2) 0%,transparent 55%)}.bib-fac-info{padding:14px 16px 36px;display:flex;flex-direction:column;gap:3px;flex:1}.bib-fac-short{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fac-c2)}.bib-fac-name{font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.35}.bib-fac-count{font-size:.72rem;color:var(--text-muted);margin-top:2px}.bib-fac-arrow{position:absolute;bottom:12px;right:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);background:var(--surface-2);border:1px solid var(--border);color:var(--fac-c2, var(--accent));transition:transform var(--fast),background var(--fast)}.bib-fac-card:hover .bib-fac-arrow{transform:translate(3px);background:var(--accent-dim)}.bib-career-list{display:flex;flex-direction:column;gap:.45rem}.bib-career-row{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;text-align:left;color:inherit;animation:animUp .3s cubic-bezier(.16,1,.3,1) both;transition:border-color var(--fast),background var(--fast),transform var(--fast),box-shadow var(--fast)}.bib-career-row:hover{border-color:var(--fac-c2, var(--accent));background:var(--accent-dim);transform:translate(5px);box-shadow:-4px 0 0 var(--fac-c2, var(--accent))}.bib-career-dot{width:8px;height:8px;border-radius:var(--r-full);flex-shrink:0;background:var(--fac-c2, var(--accent));box-shadow:0 0 6px var(--fac-c2, var(--accent))}.bib-career-info{flex:1;min-width:0}.bib-career-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.bib-career-sub{font-size:.72rem;color:var(--text-muted);margin-top:2px}.bib-career-arrow{color:var(--text-muted);flex-shrink:0;transition:transform var(--fast),color var(--fast)}.bib-career-row:hover .bib-career-arrow{transform:translate(3px);color:var(--fac-c2, var(--accent))}.bib-materials{display:flex;flex-direction:column;gap:.75rem}.bib-nav-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.bib-drive-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.9rem;padding:1rem;border-radius:var(--r-lg);border:1px solid var(--border);border-left:4px solid var(--drive-accent, var(--accent));background:linear-gradient(90deg,var(--accent-dim),transparent 64%),var(--surface-1);color:var(--text-primary);text-decoration:none;box-shadow:var(--sh-sm);transition:transform var(--fast),border-color var(--fast),box-shadow var(--fast),background var(--fast)}.bib-drive-card:hover{transform:translateY(-2px);border-color:var(--drive-accent, var(--accent));box-shadow:var(--sh-md);background:linear-gradient(90deg,var(--accent-dim),transparent 74%),var(--surface-2)}.bib-drive-icon{width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--surface-2);color:var(--drive-accent, var(--accent));border:1px solid var(--border);flex-shrink:0}.bib-drive-info{min-width:0;display:flex;flex-direction:column;gap:.2rem}.bib-drive-provider{width:fit-content;font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--drive-accent, var(--accent))}.bib-drive-title{font-size:.95rem;line-height:1.25;color:var(--text-primary)}.bib-drive-desc{font-size:.78rem;line-height:1.35;color:var(--text-muted)}.bib-drive-action{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .7rem;border-radius:var(--r-full);color:var(--drive-accent, var(--accent));background:var(--surface-2);border:1px solid var(--border);font-size:.76rem;font-weight:800;white-space:nowrap}.bib-level{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface-1);transition:border-color var(--fast),box-shadow var(--fast)}.bib-level.open{border-color:var(--border-md);box-shadow:var(--sh-sm)}.bib-level-header{display:flex;align-items:center;gap:.75rem;padding:0 1rem 0 0;background:none;border:none;cursor:pointer;width:100%;text-align:left;color:inherit;min-height:54px;transition:background var(--fast)}.bib-level-header:hover{background:var(--accent-dim)}.bib-level-strip{width:4px;align-self:stretch;flex-shrink:0;border-radius:2px 0 0 2px;min-height:54px}.bib-level-name{flex:1;font-weight:600;font-size:.9rem;color:var(--text-primary);padding:1rem 0}.bib-level-meta{font-size:.72rem;color:var(--text-muted);white-space:nowrap;padding-right:.5rem}.bib-level-body{padding:.75rem 1rem 1rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1rem}.bib-level-empty{font-size:.8rem;color:var(--text-muted);font-style:italic}.bib-cat-label{display:flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.45rem}.bib-files{display:flex;flex-direction:column;gap:.3rem}.bib-file{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--r-md);text-decoration:none;color:var(--text-secondary);font-size:.85rem;background:var(--surface-2);border:1px solid var(--border);transition:border-color var(--fast),background var(--fast),color var(--fast)}.bib-file:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.bib-file-icon{font-size:.9rem}.bib-file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bib-file-year{font-size:.7rem;color:var(--text-muted);background:var(--surface-3);padding:.1rem .45rem;border-radius:var(--r-full);white-space:nowrap}.bib-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.bib-empty span:first-child{font-size:2.75rem}.bib-empty-hint{font-size:.78rem;opacity:.7}.bib-promo-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.bib-promo-card{display:flex;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);min-height:148px;position:relative;box-shadow:0 4px 24px #0000001a;transition:transform .22s cubic-bezier(.16,1,.3,1),box-shadow .22s ease}button.bib-promo-card{width:100%;padding:0;text-align:left;color:inherit;cursor:pointer;background:none}.bib-promo-card:hover{transform:translateY(-4px);box-shadow:0 10px 36px #0000002e}.bib-promo-card--locked{cursor:not-allowed}.bib-promo-card--locked .bib-promo-art,.bib-promo-card--locked .bib-promo-body{opacity:.6}.bib-promo-card--locked .bib-promo-art{filter:grayscale(.3)}.bib-promo-lock-badge{position:absolute;top:12px;right:12px;z-index:10;display:inline-flex;align-items:center;gap:5px;padding:3px 10px 3px 7px;border-radius:var(--r-full);border:1px solid rgba(255,255,255,.15);background:#0000008c;color:#fde68a;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.bib-promo-lock-badge span{font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.bib-promo-art{width:116px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.bib-promo-art-glow{position:absolute;inset:0;pointer-events:none}.bib-promo-main-icon{position:relative;z-index:2}.bib-promo-float-icon{position:absolute;z-index:2;animation:bib-promo-float 3s ease-in-out infinite;pointer-events:none;-webkit-user-select:none;user-select:none}.bib-promo-fi-1{top:16%;left:10%;font-size:.95rem;opacity:.7;animation-delay:0s}.bib-promo-fi-2{bottom:18%;right:8%;font-size:.8rem;opacity:.6;animation-delay:1.1s}.bib-promo-fi-3{top:52%;left:12%;font-size:.72rem;opacity:.55;animation-delay:.55s}@keyframes bib-promo-float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(8deg)}}.bib-promo-body{flex:1;padding:1rem 1rem 1rem .85rem;display:flex;flex-direction:column;justify-content:center;gap:.3rem;background:var(--surface-1)}.bib-promo-badge{display:inline-flex;align-items:center;width:fit-content;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;padding:2px 8px;border-radius:var(--r-full)}.bib-promo-badge-amber{background:#f59e0b24;color:#d97706;border:1px solid rgba(245,158,11,.28)}.bib-promo-badge-purple{background:#7c3aed1f;color:#7c3aed;border:1px solid rgba(124,58,237,.24)}.bib-promo-title{margin:0;font-family:var(--font-disp);font-size:1rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.bib-promo-desc{margin:0;font-size:.74rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.bib-promo-cta{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;cursor:default;width:fit-content;padding:4px 10px;border-radius:var(--r-full);margin-top:.15rem}.bib-promo-cta-amber{background:#f59e0b1f;color:#d97706;border:1px solid rgba(245,158,11,.22)}.bib-promo-cta-purple{background:#7c3aed1a;color:#7c3aed;border:1px solid rgba(124,58,237,.2)}.bib-promo-cta-locked{background:#64646426;color:var(--text-muted);border:1px solid var(--border)}.bib-promo-study .bib-promo-art{background:linear-gradient(145deg,#0f2547,#1e5799 55%,#163a70)}.bib-promo-study .bib-promo-art-glow{background:radial-gradient(ellipse at 65% 35%,rgba(251,191,36,.28) 0%,transparent 65%)}.bib-promo-study .bib-promo-main-icon{color:#fbbf24eb;filter:drop-shadow(0 0 14px rgba(251,191,36,.45))}.bib-promo-surprise .bib-promo-art{background:linear-gradient(145deg,#1a0533,#5b21b6 55%,#2d0f5e)}.bib-promo-surprise .bib-promo-art-glow{background:radial-gradient(ellipse at 40% 60%,rgba(196,181,253,.3) 0%,transparent 65%)}.bib-promo-surprise .bib-promo-main-icon{color:#c4b5fdf2;filter:drop-shadow(0 0 16px rgba(139,92,246,.55))}.bib-contrib-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .8rem;border-radius:var(--r-full);border:1px solid color-mix(in srgb,var(--fac-c2, var(--accent)) 40%,transparent);background:color-mix(in srgb,var(--fac-c2, var(--accent)) 10%,transparent);color:var(--fac-c2, var(--accent));font-size:.75rem;font-weight:700;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background var(--fast),border-color var(--fast),transform var(--fast)}.bib-contrib-btn:hover{background:color-mix(in srgb,var(--fac-c2, var(--accent)) 18%,transparent);border-color:var(--fac-c2, var(--accent));transform:translateY(-1px)}.bib-contrib-section{display:flex;flex-direction:column;gap:1rem}.bib-contrib-header{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:0 .25rem}.bib-contrib-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.bib-contrib-card{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);animation:animUp .3s cubic-bezier(.16,1,.3,1) both}.bib-contrib-avatar{width:40px;height:40px;flex-shrink:0;border-radius:var(--r-full);background:linear-gradient(135deg,var(--fac-c1, #1e3a8a),var(--fac-c2, #2563eb));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:#fff;letter-spacing:.02em}.bib-contrib-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}@media(max-width:680px){.bib-page{padding:1rem 1rem 3rem;gap:1.25rem}.bib-hero{padding:2rem 1.25rem 1.75rem}.bib-hero-title{font-size:1.85rem}.bib-fac-grid{grid-template-columns:1fr;gap:.75rem}.bib-fac-card{flex-direction:row;border-radius:var(--r-lg)}.bib-fac-visual{width:96px;height:auto;min-height:88px;flex-shrink:0;border-radius:0}.bib-fac-img{width:64px;height:64px}.bib-fac-info{padding:12px 40px 12px 14px}.bib-fac-shine{border-radius:0}.bib-promo-grid{grid-template-columns:1fr}.bib-fac-arrow{bottom:50%;right:12px;transform:translateY(50%)}.bib-fac-card:hover .bib-fac-arrow{transform:translateY(50%) translate(3px)}.bib-fac-card:hover{transform:translateY(-3px) scale(1.01)}.bib-step-title{font-size:.95rem}.bib-drive-card{grid-template-columns:auto minmax(0,1fr);align-items:start}.bib-drive-action{grid-column:2;width:fit-content}}@media(max-width:420px){.bib-hero-title{font-size:1.5rem}.bib-hero-icon-wrap{font-size:2.5rem}}.en-grupo{display:flex;flex-direction:column;gap:10px}.en-grupo-titulo{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);display:flex;align-items:center;gap:7px;margin:0}.en-grid{display:grid;grid-template-columns:1fr;gap:8px}@media(min-width:540px){.en-grid{grid-template-columns:1fr 1fr}}.en-card{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);text-decoration:none;color:inherit;transition:background var(--fast),border-color var(--fast),transform var(--fast),box-shadow var(--fast)}.en-card:hover{background:var(--surface-2);border-color:var(--border-focus);transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.en-card:hover .en-arrow{color:var(--accent);transform:translate(2px,-2px)}.en-card--imp{border-color:color-mix(in srgb,var(--accent) 28%,var(--border));background:color-mix(in srgb,var(--accent) 4%,var(--surface-1))}.en-card--imp:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface-1))}.en-card-icon{width:40px;height:40px;border-radius:var(--r-md);background:var(--accent-dim);border:1px solid var(--border-focus);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;transition:transform var(--fast)}.en-card:hover .en-card-icon{transform:scale(1.08)}.en-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.en-nombre-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.en-nombre{font-size:.875rem;font-weight:700;color:var(--text-primary);line-height:1.2}.en-tag{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:99px;letter-spacing:.05em;flex-shrink:0}.en-tag--principal{background:color-mix(in srgb,#3B82F6 15%,transparent);color:#3b82f6;border:1px solid color-mix(in srgb,#3B82F6 35%,transparent)}.en-tag--importante{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent)}.en-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.en-arrow{color:var(--text-muted);flex-shrink:0;transition:color var(--fast),transform var(--fast)}.en-footer{font-size:.72rem;color:var(--text-muted);text-align:center;padding-top:8px;border-top:1px solid var(--border);line-height:1.5}.tools-fac-banner-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform var(--normal)}.bib-fac-card:hover .tools-fac-banner-img{transform:scale(1.05)}.bib-bc-item a{text-decoration:none;color:var(--text-muted)}.bib-bc-item a:hover{color:var(--accent)}.tool-locked-overlay{position:absolute;inset:0;background:#00000073;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:8px;font-weight:600;font-size:.95rem;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);transition:opacity var(--normal)}.pomodoro-wrapper-outer{position:relative;width:100%;display:flex;justify-content:center}.pomodoro-wrapper{display:flex;flex-direction:column;align-items:center;background:var(--surface-0);border-radius:var(--r-xl);padding:4rem 2rem 3rem;box-shadow:0 8px 32px #0000000a,0 0 0 1px var(--border);width:100%;max-width:720px;box-sizing:border-box;margin:1rem 0;position:relative;overflow:hidden;min-height:600px}[data-theme=dark] .pomodoro-wrapper{background:var(--surface-1);box-shadow:0 16px 48px #0003,0 0 0 1px var(--border)}.pomodoro-top-actions{position:absolute;top:24px;right:24px;display:flex;gap:8px;z-index:5}.pomodoro-top-btn{background:transparent;border:1px solid transparent;border-radius:var(--r-md);width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:all var(--fast)}.pomodoro-top-btn:hover{color:var(--text-primary);background:var(--surface-2);border-color:var(--border)}.pomodoro-wrapper:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 50% 0%,var(--fac-glow, rgba(178, 36, 239, .05)) 0%,transparent 60%);pointer-events:none;z-index:0;opacity:.5;transition:background .5s ease}.pomodoro-tabs{display:flex;gap:.35rem;background:var(--surface-2);padding:.35rem;border-radius:var(--r-md);border:1px solid var(--border);margin-bottom:2rem;z-index:1}.pomodoro-tab{padding:.5rem 1.25rem;border-radius:var(--r-sm);font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:transparent;transition:all var(--fast)}.pomodoro-tab.active{background:var(--surface-0);color:var(--text-primary);box-shadow:var(--sh-sm);font-weight:600}[data-theme=dark] .pomodoro-tab.active{background:var(--surface-3);box-shadow:none}.pomodoro-circle-container{position:relative;width:320px;height:320px;margin:1rem auto;z-index:1}.pomodoro-circle-svg{transform:rotate(-90deg);width:100%;height:100%;filter:drop-shadow(0 0 12px var(--fac-glow, rgba(178, 36, 239, .15)))}.pomodoro-circle-bg{fill:none;stroke:var(--surface-2);stroke-width:8}.pomodoro-circle-progress{fill:none;stroke:url(#pomodoro-gradient);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s linear}.pomodoro-inner{position:absolute;inset:20px;background:var(--surface-0);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:inset 0 0 20px #00000005}[data-theme=dark] .pomodoro-inner{background:var(--surface-1);box-shadow:inset 0 0 30px #0003}.pomodoro-time{font-size:5rem;font-weight:700;color:var(--text-primary);font-family:var(--font-disp);line-height:1;letter-spacing:-2px;transition:color .5s ease}.pomodoro-label{font-size:.9rem;color:var(--text-secondary);margin-top:8px;font-weight:600;text-transform:uppercase;letter-spacing:2px}.pomodoro-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:1.5rem;margin-bottom:2.5rem;z-index:1}.pomodoro-btn-main{background:var(--fac-c2, var(--accent));color:#fff;border:none;border-radius:var(--r-full);width:auto;min-width:220px;padding:0 2rem;height:60px;display:flex;gap:12px;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px var(--fac-glow, rgba(178, 36, 239, .25));transition:transform .2s cubic-bezier(.175,.885,.32,1.275),box-shadow .2s,background var(--fast);font-size:1.05rem;font-weight:700;letter-spacing:.5px}[data-theme=dark] .pomodoro-btn-main{background:var(--fac-c2, var(--accent));color:#fff}.pomodoro-btn-main:hover{transform:translateY(-2px);box-shadow:0 12px 32px var(--fac-glow, rgba(178, 36, 239, .4));background:var(--fac-c1, var(--accent))}.pomodoro-btn-main:active{transform:translateY(1px);box-shadow:0 4px 12px var(--fac-glow, rgba(178, 36, 239, .15))}.pomodoro-btn-side{background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--r-md);width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast)}.pomodoro-btn-side:hover{background:var(--surface-2);color:var(--text-primary)}.pomodoro-top-left{position:absolute;top:24px;left:24px;display:flex;gap:8px;z-index:5}.pomodoro-restart-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;color:var(--text-muted);border:none;border-radius:var(--r-md);cursor:pointer;font-weight:600;transition:background var(--fast),color var(--fast)}.pomodoro-restart-btn:hover{background:var(--surface-2);color:var(--text-primary)}.pomodoro-restart-text{display:inline}@media(max-width:680px){.pomodoro-restart-text{display:none}.pomodoro-restart-btn{padding:8px}}.pomodoro-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:100;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pomodoro-modal{background:var(--surface-0);border-radius:var(--r-lg);padding:1.5rem;width:90%;max-width:420px;box-shadow:var(--sh-xl);border:1px solid var(--border);max-height:90vh;overflow-y:auto}.pomo-mod-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.pomo-mod-header h3{font-size:1.25rem;margin:0;color:var(--text-primary)}.pomo-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px}.pomo-close-btn:hover{background:var(--surface-2);color:var(--text-primary)}.pomo-form-group{margin-bottom:1rem}.pomo-form-group label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:6px;font-weight:600}.pomo-form-group input,.pomo-form-group select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);color:var(--text-primary);font-family:var(--font);box-sizing:border-box}.pomo-preset-btn{display:flex;flex-direction:column;text-align:left;width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);color:var(--text-primary);cursor:pointer;margin-bottom:8px;transition:background var(--fast),border-color var(--fast)}.pomo-preset-btn:hover{background:var(--surface-2);border-color:var(--accent)}.pomo-preset-name{font-weight:600;font-size:.95rem;margin-bottom:4px}.pomo-preset-desc{font-size:.75rem;color:var(--text-muted)}.pomo-preset-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px}.pomo-preset-delete:hover{background:#dc26261a;color:#ef4444}.pomo-save-btn{width:100%;padding:12px;background:var(--text-primary);color:var(--surface-0);border:none;border-radius:var(--r-md);font-weight:600;cursor:pointer;margin-top:1rem;transition:background var(--fast)}.pomo-save-btn:hover{background:var(--accent);color:#fff}.pomo-save-btn.secondary{background:var(--surface-2);color:var(--text-primary);margin-top:.5rem}.pomo-save-btn.secondary:hover{background:var(--surface-3)}.pomodoro-footer{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:auto;padding-top:2rem;border-top:1px solid var(--border);z-index:1}.pomodoro-session-dots{display:flex;gap:10px;align-items:center}.pomodoro-dot{width:12px;height:12px;border-radius:50%;background:var(--surface-3);transition:all var(--fast)}.pomodoro-dot.active{background:var(--fac-c1, #b224ef);box-shadow:0 0 10px var(--fac-glow, rgba(178, 36, 239, .6));transform:scale(1.2)}.pomodoro-footer-text{font-size:.95rem;color:var(--text-muted);font-weight:600}@media(max-width:680px){.pomodoro-wrapper{padding:3.5rem 1.2rem 1.5rem;min-height:auto;margin:.5rem auto;border-radius:var(--r-lg)}.pomodoro-top-left{top:14px;left:14px}.pomodoro-top-actions{top:14px;right:14px;gap:4px}.pomodoro-top-btn{width:34px;height:34px}.pomodoro-tabs{margin-bottom:1rem;padding:.25rem;gap:.2rem}.pomodoro-tab{padding:.45rem 1rem;font-size:.8rem}.pomodoro-circle-container{width:240px;height:240px;margin:.5rem auto}.pomodoro-time{font-size:3.8rem;letter-spacing:-2px}.pomodoro-label{font-size:.72rem;letter-spacing:1.5px;margin-top:4px}.pomodoro-controls{gap:1rem;margin-top:1.2rem;margin-bottom:1.2rem}.pomodoro-btn-main{width:100%;min-width:unset;height:54px;font-size:.95rem;padding:0 1.5rem}.pomodoro-footer{margin-top:.5rem;padding-top:1rem}.pomodoro-dot{width:10px;height:10px}.pomodoro-footer-text{font-size:.82rem}.pomodoro-restart-text{display:none}.pomodoro-restart-btn{padding:8px}}.raffle-mode-bar,.raffle-container,.raffle-bulk-grid,.raffle-action,.raffle-results{width:100%;max-width:860px;margin-left:auto;margin-right:auto}.raffle-container{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:12px;align-items:start}@media(max-width:768px){.raffle-container{grid-template-columns:1fr}}.raffle-column{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--sh-sm)}.raffle-column-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.raffle-column-title{margin:0;font-family:var(--font-disp);font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.15}.raffle-column-count{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:.72rem;font-weight:700;white-space:nowrap}.raffle-input-wrap{display:flex;gap:10px}.raffle-input-wrap input{flex:1;min-height:44px;padding:0 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font-size:.95rem;transition:border-color var(--fast),box-shadow var(--fast),background var(--fast)}.raffle-input-wrap input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.raffle-add-btn{width:44px;height:44px;border:none;border-radius:var(--r-md);background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--sh-blue);transition:transform var(--fast),filter var(--fast),box-shadow var(--fast)}.raffle-add-btn:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 8px 20px #2563eb38}.raffle-column ul{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto;max-height:320px}.raffle-item{padding:10px 12px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;color:var(--text-primary);font-size:.92rem;animation:fadeIn .3s ease-out}.raffle-action{margin-top:24px;grid-column:1 / -1;display:flex;justify-content:center;align-items:center;position:relative}.raffle-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#b224ef,#7579ff);color:#fff;border:none;min-height:52px;padding:0 28px;font-size:1rem;font-weight:700;border-radius:var(--r-full);cursor:pointer;box-shadow:0 8px 22px #b224ef47;transition:transform var(--fast),box-shadow var(--fast);letter-spacing:-.01em}.raffle-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px #b224ef5c}.raffle-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.raffle-clear-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid #ef4444;border-radius:var(--r-full);min-height:38px;padding:0 14px;font-size:.82rem;font-weight:600;color:#ef4444;cursor:pointer;transition:all var(--fast);position:absolute;right:0}@media(max-width:680px){.raffle-action{flex-direction:column;gap:12px;position:static}.raffle-btn{width:100%;justify-content:center}.raffle-clear-btn{position:static}.raffle-mode-bar{flex-direction:column;align-items:stretch}.raffle-switch{width:100%;justify-content:space-between}.raffle-column{padding:14px}.raffle-column-header{align-items:flex-start;flex-direction:column;gap:6px}.raffle-input-wrap input{min-height:42px}.raffle-add-btn{width:42px;height:42px}.raffle-column ul{max-height:260px}}.raffle-clear-btn:hover{background:#ef44441a;color:#dc2626}.raffle-mode-bar{display:flex;align-items:center;justify-content:space-between;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 14px;gap:12px;flex-wrap:wrap;box-shadow:var(--sh-sm)}.raffle-mode-info{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary);font-weight:600}.raffle-switch{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.raffle-switch input{position:absolute;opacity:0;width:0;height:0}.raffle-switch-track{position:relative;width:42px;height:22px;background:var(--surface-3);border-radius:9999px;border:1px solid var(--border-md);transition:background var(--fast);flex-shrink:0}.raffle-switch input:checked+.raffle-switch-track{background:#7579ff}.raffle-switch-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 1px 4px #00000040;transition:transform var(--fast)}.raffle-switch input:checked+.raffle-switch-track .raffle-switch-thumb{transform:translate(20px)}.raffle-switch-label{font-size:.82rem;color:var(--text-secondary);font-weight:600}.raffle-bulk-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}@media(max-width:680px){.raffle-bulk-grid{grid-template-columns:1fr}}.raffle-bulk-col{display:flex;flex-direction:column;gap:8px}.raffle-bulk-label{font-size:.74rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.raffle-bulk-textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);color:var(--text-primary);font-size:.92rem;font-family:var(--font);resize:vertical;box-sizing:border-box;transition:border-color var(--fast);line-height:1.55}.raffle-bulk-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.raffle-bulk-textarea::placeholder{color:var(--text-muted);white-space:pre-line}.raffle-bulk-chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0}.raffle-chip{display:inline-flex;align-items:center;gap:4px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent);border-radius:var(--r-full);font-size:.78rem;font-weight:600;padding:3px 10px}.raffle-chip-x{background:none;border:none;color:currentColor;cursor:pointer;padding:0;display:flex;align-items:center;opacity:.7}.raffle-chip-x:hover{opacity:1}.raffle-bulk-apply{grid-column:1 / -1;display:flex;justify-content:center}.raffle-apply-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--surface-2);border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text-primary);font-weight:600;font-size:.95rem;cursor:pointer;transition:background var(--fast),border-color var(--fast),color var(--fast)}.raffle-apply-btn:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.raffle-apply-btn:disabled{opacity:.4;cursor:not-allowed}.raffle-result-card{background:#7579ff0f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(117,121,255,.25);box-shadow:0 8px 32px #0000001a;border-radius:var(--r-md);padding:14px;margin-bottom:12px;animation:slideInRaffle .5s cubic-bezier(.175,.885,.32,1.275)}.raffle-result-name{font-weight:700;font-size:1rem;color:var(--text-primary);margin-bottom:6px}.raffle-result-topic{font-size:.88rem;color:var(--text-secondary);margin-left:10px;display:flex;align-items:center;gap:6px;line-height:1.45}.raffle-result-topic:before{content:"•";color:var(--accent);font-size:20px}@keyframes slideInRaffle{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}.raffle-results{margin-top:28px}.raffle-results-title{margin:0 0 14px;font-family:var(--font-disp);font-size:1rem;font-weight:700;color:var(--text-primary)}.qr-page{--qr-violet: #7579ff;--qr-magenta: #b224ef}.qr-nav-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.qr-hero{max-width:1180px;margin-left:auto;margin-right:auto}.qr-hero-copy{margin:4px 0 0;color:var(--text-secondary);font-size:.88rem;line-height:1.35}.qr-mode-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-width:640px;margin:18px auto 24px}.qr-mode-card{display:flex;align-items:center;gap:12px;min-height:72px;padding:14px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface-1);color:var(--text-primary);text-align:left;cursor:pointer;transition:transform var(--fast),border-color var(--fast),background var(--fast),box-shadow var(--fast)}.qr-mode-card:hover{transform:translateY(-1px);border-color:var(--border-md);background:var(--surface-2)}.qr-mode-card--active{border-color:var(--accent);background:linear-gradient(135deg,#2563eb1f,#7579ff1a);box-shadow:var(--sh-blue)}.qr-mode-icon{width:42px;height:42px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;background:var(--surface-0);color:var(--accent);border:1px solid var(--border);flex-shrink:0}.qr-mode-card--active .qr-mode-icon{background:var(--accent);border-color:var(--accent);color:var(--text-on-blue)}.qr-mode-card strong{display:block;font-size:.95rem;line-height:1.15}.qr-mode-card small{display:block;margin-top:4px;color:var(--text-muted);font-weight:600;line-height:1.2}.qr-tool-layout{display:flex;flex-direction:column;gap:24px;max-width:1180px;margin:0 auto}.qr-main-stack{min-width:0;width:100%}.qr-generate-grid,.qr-scan-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.92fr);gap:20px;align-items:stretch}.qr-card,.qr-panel,.qr-history-panel{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.qr-card,.qr-panel{padding:22px}.qr-generate-grid .qr-card{min-height:360px}.qr-generate-grid .qr-card:first-child{display:flex;flex-direction:column}.qr-card-head,.qr-panel-header{display:flex;align-items:center;gap:10px;color:var(--text-primary)}.qr-card-head{margin-bottom:16px}.qr-card-head--center{justify-content:center;text-align:center}.qr-card-icon{width:38px;height:38px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;background:var(--accent-dim);color:var(--accent);flex-shrink:0}.qr-card h2,.qr-history-panel h2{margin:0;color:var(--text-primary);font-size:1.12rem;line-height:1.15}.qr-eyebrow{display:inline-block;margin-bottom:3px;color:var(--text-muted);font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.qr-textarea{width:100%;min-height:50px;padding:16px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font-size:.96rem;line-height:1.55;resize:vertical;font-family:inherit;box-sizing:border-box;outline:none}.qr-generate-grid .qr-card:first-child .qr-textarea{flex:1;min-height:185px}.qr-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.qr-input-meta{display:flex;justify-content:space-between;gap:10px;margin-top:10px;color:var(--text-muted);font-size:.78rem;line-height:1.35}.qr-designer{margin-top:16px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);padding:12px}.qr-designer-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.qr-designer-head h3{margin:0;color:var(--text-primary);font-size:.98rem;line-height:1.15}.qr-designer-toggle{display:none;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-1);color:var(--accent);padding:7px 11px;font-size:.78rem;font-weight:800;cursor:pointer}.qr-designer-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.qr-designer-tool{min-width:0;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);padding:11px}.qr-designer-tool--frames{grid-column:1 / -1}.qr-designer-tool-head{display:flex;align-items:center;gap:8px;margin-bottom:10px;color:var(--text-primary)}.qr-designer-tool-head span{width:24px;height:24px;border-radius:var(--r-full);display:inline-flex;align-items:center;justify-content:center;background:var(--accent-dim);color:var(--accent);font-size:.7rem;font-weight:900;flex-shrink:0}.qr-designer-tool-head strong{font-size:.84rem;line-height:1.2}.qr-designer-tool-head em{margin-left:auto;color:var(--text-muted);font-size:.72rem;font-style:normal;font-weight:800}.qr-shape-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.qr-shape-choice{min-width:0;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);padding:8px;text-align:left;cursor:pointer;transition:border-color var(--fast),box-shadow var(--fast)}.qr-shape-choice:hover{border-color:var(--border-focus)}.qr-shape-choice--active{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.qr-shape-mini{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;width:100%;height:42px;margin-bottom:7px;padding:8px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-1);box-sizing:border-box}.qr-shape-mini:before,.qr-shape-mini:after{content:""}.qr-shape-mini{background-image:radial-gradient(circle at 12px 12px,var(--text-primary) 0 4px,transparent 4.5px),radial-gradient(circle at 24px 12px,var(--text-primary) 0 4px,transparent 4.5px),radial-gradient(circle at 36px 12px,var(--text-primary) 0 4px,transparent 4.5px),radial-gradient(circle at 12px 24px,var(--text-primary) 0 4px,transparent 4.5px),radial-gradient(circle at 30px 24px,var(--text-primary) 0 4px,transparent 4.5px),radial-gradient(circle at 18px 34px,var(--text-primary) 0 4px,transparent 4.5px),radial-gradient(circle at 36px 34px,var(--text-primary) 0 4px,transparent 4.5px);background-repeat:no-repeat}.qr-shape-mini--square{background-image:linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary));background-size:9px 9px;background-position:8px 8px,22px 8px,36px 8px,8px 22px,28px 22px,16px 34px,38px 34px}.qr-shape-mini--rounded,.qr-shape-mini--soft{filter:saturate(1.02)}.qr-shape-mini--horizontal{background-image:linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary));background-size:26px 5px,34px 5px,22px 5px,30px 5px;background-position:8px 10px,18px 21px,8px 32px,24px 38px;border-radius:var(--r-sm)}.qr-shape-mini--vertical{background-image:linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary)),linear-gradient(var(--text-primary),var(--text-primary));background-size:5px 25px,5px 34px,5px 20px,5px 30px,5px 18px;background-position:10px 8px,22px 8px,34px 13px,46px 8px,56px 20px}.qr-shape-mini--diamond{background-image:linear-gradient(45deg,transparent 35%,var(--text-primary) 35% 65%,transparent 65%),linear-gradient(45deg,transparent 35%,var(--text-primary) 35% 65%,transparent 65%),linear-gradient(45deg,transparent 35%,var(--text-primary) 35% 65%,transparent 65%),linear-gradient(45deg,transparent 35%,var(--text-primary) 35% 65%,transparent 65%);background-size:16px 16px;background-position:8px 8px,30px 8px,18px 25px,45px 27px}.qr-shape-mini--tiny{background-size:4px 4px}.qr-shape-choice strong,.qr-shape-choice small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-shape-choice strong{font-size:.75rem}.qr-shape-choice small{margin-top:2px;color:var(--text-muted);font-size:.66rem;font-weight:700}.qr-color-panels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.qr-color-panel,.qr-frame-text-label{display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:.72rem;font-weight:800}.qr-color-panel{min-width:0;padding:9px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0)}.qr-color-panel input[type=color]{width:100%;height:34px;padding:3px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);cursor:pointer}.qr-swatch-row{display:flex;gap:6px;flex-wrap:wrap}.qr-swatch{width:24px;height:24px;border-radius:var(--r-full);border:2px solid var(--surface-1);background:var(--qr-swatch);box-shadow:0 0 0 1px var(--border);cursor:pointer}.qr-swatch--bg{border-color:var(--border)}.qr-swatch--active{box-shadow:0 0 0 2px var(--accent)}.qr-frame-picker{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.qr-frame-choice{min-width:0;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);padding:9px;text-align:left;cursor:pointer;transition:border-color var(--fast),box-shadow var(--fast),transform var(--fast)}.qr-frame-choice:hover{border-color:var(--border-focus)}.qr-frame-choice--active{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.qr-frame-mini{display:block;width:100%;height:34px;margin-bottom:7px;border-radius:var(--r-sm);background:linear-gradient(135deg,var(--surface-1),var(--accent-dim));border:1px solid var(--border);position:relative;overflow:hidden}.qr-frame-mini:after{content:"";position:absolute;width:16px;height:16px;right:8px;bottom:7px;background:linear-gradient(90deg,var(--text-primary) 45%,transparent 45%),linear-gradient(var(--text-primary) 45%,transparent 45%);background-size:6px 6px;opacity:.75}.qr-frame-mini--topLabel:before,.qr-frame-mini--bubble:before,.qr-frame-mini--card:before{content:"";position:absolute;inset:0 0 auto;height:12px;background:var(--accent)}.qr-frame-mini--bottomLabel:before,.qr-frame-mini--phone:before,.qr-frame-mini--device:before{content:"";position:absolute;inset:auto 8px 6px;height:10px;border-radius:var(--r-sm);background:var(--text-muted)}.qr-frame-mini--phone,.qr-frame-mini--device{border:3px solid var(--text-muted)}.qr-frame-mini--corners{background:linear-gradient(var(--text-muted),var(--text-muted)) 10px 9px / 20px 3px no-repeat,linear-gradient(var(--text-muted),var(--text-muted)) 10px 9px / 3px 18px no-repeat,linear-gradient(var(--text-muted),var(--text-muted)) calc(100% - 10px) 9px / 20px 3px no-repeat,linear-gradient(var(--text-muted),var(--text-muted)) calc(100% - 10px) 9px / 3px 18px no-repeat,var(--surface-1)}.qr-frame-choice strong,.qr-frame-choice small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qr-frame-choice strong{font-size:.78rem}.qr-frame-choice small{margin-top:2px;color:var(--text-muted);font-size:.68rem;font-weight:700}.qr-frame-text-label{margin-top:10px}.qr-frame-text-label input{height:38px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);padding:0 11px;font:inherit;font-size:.85rem;outline:none}.qr-frame-text-label input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.qr-output-card{display:flex;flex-direction:column;justify-content:space-between}.qr-preview{margin:0 auto;width:min(100%,286px);aspect-ratio:1;padding:18px;background:#fff;border-radius:var(--r-md);box-shadow:0 16px 40px #0f172a1f;box-sizing:border-box}.qr-preview>svg{width:100%;height:auto;display:block}.qr-preview--artwork{width:min(100%,334px);aspect-ratio:auto;padding:0;background:transparent;border-radius:0;box-shadow:none}.qr-artwork{width:100%;height:auto;border-radius:var(--r-lg);filter:drop-shadow(0 16px 34px rgba(15,23,42,.12))}.qr-action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:18px}.qr-action-grid .btn,.qr-cam-controls .btn,.qr-result-actions .btn,.qr-full-btn{justify-content:center;min-height:42px;white-space:normal;text-align:center}.qr-panel{display:flex;flex-direction:column;gap:14px}.qr-panel-header{font-weight:800;font-size:.95rem;padding-bottom:12px;border-bottom:1px solid var(--border)}.qr-panel-badge{margin-left:auto;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:var(--r-full);background:#7579ff1a;color:var(--qr-violet);border:1px solid rgba(117,121,255,.28)}.qr-cam-select-wrap{width:100%}.qr-cam-select{width:100%;padding:11px 14px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:.9rem;outline:none}.qr-cam-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.qr-viewfinder-wrap{position:relative;width:100%;aspect-ratio:4 / 3;background:var(--surface-0);border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border)}.qr-viewfinder-video{width:100%;height:100%;object-fit:cover}.qr-viewfinder-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-muted);font-size:.9rem;text-align:center;padding:18px}.qr-viewfinder-success{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;padding:22px;text-align:center;color:var(--text-primary);background:linear-gradient(135deg,#10b98114,#2563eb14)}.qr-viewfinder-success-icon{width:54px;height:54px;border-radius:var(--r-full);display:inline-flex;align-items:center;justify-content:center;color:#fff;background:var(--success);box-shadow:0 12px 28px #10b9813d}.qr-viewfinder-success strong{font-size:1rem;line-height:1.2}.qr-viewfinder-success p{max-width:260px;margin:0;color:var(--text-secondary);font-size:.86rem;line-height:1.45}.qr-viewfinder-placeholder svg,.qr-dropzone svg,.qr-history-empty svg{opacity:.55;color:var(--accent)}.qr-viewfinder-overlay{position:absolute;inset:0;pointer-events:none}.qr-scan-line{position:absolute;left:12%;right:12%;height:2px;background:linear-gradient(90deg,transparent,var(--qr-violet),var(--qr-magenta),var(--qr-violet),transparent);box-shadow:0 0 8px #7579ffe6;animation:scanLine 2s linear infinite;top:10%}@keyframes scanLine{0%{top:10%;opacity:1}90%{top:90%;opacity:1}to{top:90%;opacity:0}}.qr-viewfinder-corners:before,.qr-viewfinder-corners:after{content:"";position:absolute;width:28%;height:28%;border:3px solid var(--qr-violet)}.qr-viewfinder-corners:before{top:10%;left:10%;border-right:none;border-bottom:none;border-radius:4px 0 0}.qr-viewfinder-corners:after{right:10%;bottom:10%;border-left:none;border-top:none;border-radius:0 0 4px}.qr-cam-controls{display:flex;gap:10px;flex-wrap:wrap}.qr-cam-controls .btn{flex:1 1 150px}.qr-cam-controls--result .btn{flex-basis:100%}.qr-scan-again-btn{min-height:48px;font-size:.9rem}.qr-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--r-md);padding:10px 14px;font-size:.85rem;color:var(--danger)}.qr-result-box{background:#7579ff12;border:1px solid rgba(117,121,255,.28);border-radius:var(--r-md);padding:14px 16px;display:flex;flex-direction:column;gap:9px;animation:fadeIn .3s ease-out}.qr-result-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--qr-violet)}.qr-result-text{font-size:.9rem;color:var(--text-primary);word-break:break-word;overflow-wrap:anywhere;line-height:1.5}.qr-result-text a{display:inline-flex;align-items:center;gap:5px;color:var(--accent);text-decoration:underline}.qr-result-actions{display:flex;gap:8px;margin-top:4px;flex-wrap:wrap}.qr-dropzone{border:2px dashed var(--border-md);border-radius:var(--r-md);padding:22px;text-align:center;cursor:pointer;transition:border-color var(--fast),background var(--fast),transform var(--fast);background:var(--surface-0);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:220px;position:relative;overflow:hidden}.qr-dropzone:hover,.qr-drop-active{border-color:var(--accent);background:var(--accent-dim);transform:translateY(-1px)}.qr-dropzone p{margin:12px 0 4px;color:var(--text-secondary);font-size:.9rem;line-height:1.35}.qr-dropzone small{color:var(--text-muted);font-size:.76rem}.qr-drop-preview{max-width:100%;max-height:240px;object-fit:contain;border-radius:var(--r-sm)}.qr-full-btn{width:100%}.qr-loading{flex-direction:row;align-items:center;gap:12px}.qr-spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:var(--qr-violet);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.qr-history-panel{padding:22px;overflow:hidden}.qr-history-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.qr-history-clear{border:1px solid rgba(239,68,68,.22);background:#ef444414;color:var(--danger);border-radius:var(--r-full);padding:5px 10px;font-size:.75rem;font-weight:800;cursor:pointer}.qr-history-stats{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:10px;margin:16px 0;max-width:440px}.qr-history-stats span{padding:9px;border-radius:var(--r-md);background:var(--surface-0);border:1px solid var(--border);color:var(--text-muted);font-size:.76rem;text-align:center}.qr-history-stats strong{color:var(--text-primary)}.qr-history-empty{min-height:190px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;color:var(--text-muted);font-size:.86rem;line-height:1.45}.qr-history-empty p{margin:0;max-width:210px}.qr-history-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;max-height:none;overflow:visible;padding-right:0}.qr-history-item{padding:12px;border-radius:var(--r-md);background:var(--surface-0);border:1px solid var(--border)}.qr-history-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;color:var(--text-muted);font-size:.68rem;font-weight:700}.qr-history-kind{padding:2px 7px;border-radius:var(--r-full);color:var(--accent);background:var(--accent-dim)}.qr-history-kind--scanned{color:var(--qr-violet);background:#7579ff1f}.qr-history-value{margin:9px 0 10px;color:var(--text-primary);font-size:.86rem;font-weight:650;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere}.qr-history-actions{display:grid;grid-template-columns:minmax(0,1fr) 34px 34px;gap:7px;align-items:center}.qr-history-action,.qr-icon-button{height:34px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-1);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;font-size:.75rem;font-weight:800;transition:background var(--fast),color var(--fast),border-color var(--fast)}.qr-history-action:hover,.qr-icon-button:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.qr-icon-button--danger{color:var(--danger)}.qr-icon-button--danger:hover{background:#ef44441a;color:var(--danger);border-color:#ef44444d}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1100px){.qr-history-list{grid-template-columns:repeat(2,minmax(0,1fr))}.qr-history-stats{max-width:none}}@media(max-width:860px){.qr-generate-grid,.qr-scan-layout,.qr-designer-body{grid-template-columns:1fr}.qr-designer-tool--frames{grid-column:auto}.qr-history-list,.qr-action-grid{grid-template-columns:1fr}}@media(max-width:520px){.qr-page .bib-step-header{align-items:flex-start}.qr-mode-switch{gap:8px;margin-top:14px;margin-bottom:18px}.qr-mode-card{flex-direction:column;align-items:flex-start;min-height:112px;padding:12px}.qr-mode-icon{width:38px;height:38px}.qr-card,.qr-panel,.qr-history-panel{padding:16px}.qr-textarea{min-height:118px}.qr-generate-grid .qr-card{min-height:0}.qr-generate-grid .qr-card:first-child .qr-textarea{min-height:118px}.qr-designer{padding:10px}.qr-designer-head{margin-bottom:0}.qr-designer-toggle{display:inline-flex;align-items:center;justify-content:center}.qr-designer-body{display:none;margin-top:12px}.qr-designer--open .qr-designer-body{display:grid}.qr-frame-picker{grid-template-columns:1fr}.qr-preview{width:min(100%,250px);padding:14px}.qr-input-meta,.qr-history-head{flex-direction:column}}.imgconv-layout{display:flex;gap:24px;max-width:1100px;margin:32px auto 0;align-items:flex-start}.imgconv-settings-panel{flex:0 0 240px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:20px}.imgconv-panel-title{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0}.imgconv-field{display:flex;flex-direction:column;gap:6px}.imgconv-label{font-size:.85rem;font-weight:600;color:var(--text-primary);display:flex;justify-content:space-between;align-items:center}.imgconv-label-sub{font-weight:400;opacity:.55;font-size:.78rem}.imgconv-quality-val{font-weight:700;color:var(--accent)}.imgconv-select{padding:9px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font-size:.9rem;outline:none;cursor:pointer;transition:border-color var(--fast)}.imgconv-select:focus{border-color:var(--accent)}.imgconv-range{width:100%;accent-color:var(--accent);cursor:pointer}.imgconv-range-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-muted);margin-top:-2px}.imgconv-number-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font-size:.9rem;outline:none;width:100%;box-sizing:border-box;transition:border-color var(--fast)}.imgconv-number-input:focus{border-color:var(--accent)}.imgconv-hint{font-size:.74rem;color:var(--text-muted);margin:0;line-height:1.4}.imgconv-privacy-note{display:flex;align-items:center;gap:7px;font-size:.76rem;color:var(--text-muted);padding:10px 12px;background:var(--surface-0);border-radius:var(--r-md);border:1px solid var(--border)}.imgconv-engine-badge{margin-left:auto;display:flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:99px;background:#ffffff26;color:#fff;white-space:nowrap}.imgconv-engine-badge.wasm{background:#fff3}.imgconv-engine-badge.loading{opacity:.7}.imgconv-main{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:16px}.imgconv-dropzone{background:var(--surface-1);border:2px dashed var(--border);border-radius:var(--r-lg);padding:40px 24px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;transition:border-color var(--fast),background var(--fast)}.imgconv-dropzone:hover,.imgconv-dropzone.dragover{border-color:var(--accent);background:var(--surface-2)}.imgconv-drop-icon{color:var(--text-muted)}.imgconv-drop-text{font-size:.95rem;color:var(--text-primary)}.imgconv-drop-hint{font-size:.78rem;color:var(--text-muted)}.imgconv-file-list{display:flex;flex-direction:column;gap:8px}.imgconv-file-row{display:flex;align-items:center;gap:12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;transition:border-color var(--fast)}.imgconv-file-row.status-done{border-color:#22c55e55}.imgconv-file-row.status-processing{border-color:var(--accent)}.imgconv-file-row.status-error{border-color:var(--danger, #ef4444)}.imgconv-thumb{width:44px;height:44px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0}.imgconv-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.imgconv-file-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.imgconv-file-meta{font-size:.78rem;color:var(--text-muted)}.imgconv-savings{margin-left:6px;background:#22c55e22;color:#22c55e;font-weight:700;padding:1px 6px;border-radius:99px;font-size:.72rem}.imgconv-error-msg{color:var(--danger, #ef4444);margin-left:4px}.imgconv-row-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.imgconv-icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-0);color:var(--text-secondary);cursor:pointer;transition:all var(--fast)}.imgconv-icon-btn:hover{background:var(--surface-2);color:var(--text-primary)}.imgconv-icon-remove:hover{color:var(--danger, #ef4444);border-color:var(--danger, #ef4444)}.imgconv-icon-err{color:var(--danger, #ef4444)}.imgconv-icon-muted{color:var(--text-muted)}.imgconv-action-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.imgconv-clear-btn{background:none;border:none;color:var(--text-muted);font-size:.82rem;cursor:pointer;padding:4px 0;transition:color var(--fast);margin-left:auto}.imgconv-clear-btn:hover{color:var(--danger, #ef4444)}@keyframes imgconv-spin{to{transform:rotate(360deg)}}.imgconv-spin{animation:imgconv-spin .9s linear infinite}@media(max-width:700px){.imgconv-layout{flex-direction:column}.imgconv-settings-panel{flex:none;width:100%}}@keyframes url-short-spin{to{transform:rotate(360deg)}}.url-short-spin{animation:url-short-spin .75s linear infinite}.url-short-create-box{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.85rem;margin-bottom:2rem}[data-theme=dark] .url-short-create-box{background:var(--surface-2)}.url-short-create-label{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0}.url-short-input-row{display:flex;gap:10px;align-items:stretch}.url-short-input{flex:1;min-width:0;padding:10px 14px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-0);color:var(--text-primary);font-size:.9rem;font-family:var(--font);transition:border-color var(--fast),box-shadow var(--fast);outline:none}.url-short-input::placeholder{color:var(--text-muted);opacity:.7}.url-short-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.url-short-input--error{border-color:#ef44448c}.url-short-input--error:focus{box-shadow:0 0 0 3px #ef44441a}.url-short-create-btn{flex-shrink:0;padding:10px 18px}.url-short-alert{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--r-md);font-size:.84rem;font-weight:500;border:1px solid transparent}.url-short-alert--error{background:#ef444414;color:var(--danger, #ef4444);border-color:#ef444433}.url-short-list-alert{margin-bottom:1rem}.url-short-result-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#10b98112;border:1px solid rgba(16,185,129,.22);border-radius:var(--r-md);flex-wrap:wrap}.url-short-result-check{color:var(--success, #10b981);flex-shrink:0}.url-short-result-label{font-size:.82rem;font-weight:600;color:var(--success, #10b981);white-space:nowrap}.url-short-result-link{font-size:.88rem;font-weight:500;color:var(--accent);text-decoration:none;word-break:break-all;flex:1;min-width:0}.url-short-result-link:hover{text-decoration:underline}.url-short-list-section{display:flex;flex-direction:column;gap:.75rem}.url-short-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.url-short-list-title{font-family:var(--font-disp);font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.url-short-refresh-btn{font-size:.78rem;gap:5px;padding:6px 12px}.url-short-state-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:3rem 1rem;color:var(--text-muted);font-size:.9rem;text-align:center}.url-short-state-icon{color:var(--text-muted);opacity:.5}.url-short-state-icon--dim{opacity:.2}.url-short-empty-text{margin:0;line-height:1.6;color:var(--text-muted);font-size:.88rem}.url-short-list{display:flex;flex-direction:column;gap:8px}.url-short-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--fast),box-shadow var(--fast)}.url-short-card:hover{border-color:var(--border-md);box-shadow:var(--sh-sm)}[data-theme=dark] .url-short-card{background:var(--surface-2)}[data-theme=dark] .url-short-card:hover{background:var(--surface-3)}.url-short-card-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.url-short-card-row{display:flex;align-items:center;gap:6px}.url-short-card-icon{color:var(--accent);flex-shrink:0}.url-short-card-link{font-size:.88rem;font-weight:600;color:var(--accent);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.url-short-card-link:hover{text-decoration:underline}.url-short-card-original{display:flex;align-items:center;gap:5px;color:var(--text-muted);font-size:.78rem;min-width:0}.url-short-card-original span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.url-short-card-aside{display:flex;align-items:center;gap:8px;flex-shrink:0}.url-short-badge{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:var(--r-full);background:var(--accent-dim);color:var(--accent);white-space:nowrap}.url-short-meta-date{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.url-short-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--fast);flex-shrink:0;text-decoration:none;padding:0}.url-short-icon-btn:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-md)}.url-short-icon-btn--copied{color:var(--success, #10b981);border-color:#10b9814d;background:#10b9810f}.url-short-del-btn:hover{color:var(--danger, #ef4444);border-color:#ef44444d;background:#ef44440f}@media(max-width:600px){.url-short-input-row{flex-direction:column}.url-short-create-btn{width:100%;justify-content:center}.url-short-card{flex-direction:column;align-items:flex-start}.url-short-card-aside{width:100%;justify-content:flex-end}.url-short-meta-date{display:none}}.docscan-shell{width:100%;max-width:900px;display:flex;flex-direction:column;gap:12px}.docscan-page--capture{gap:.85rem;padding-top:.75rem}.docscan-page--capture .docscan-shell{max-width:960px}.docscan-panel{width:100%;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden}.docscan-shell__error{max-width:none}.docscan-storage{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px 14px;padding:12px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-sm)}.docscan-storage__main{min-width:0;display:flex;align-items:center;gap:10px}.docscan-storage__icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent);background:var(--accent-dim);border-radius:var(--r-md)}.docscan-storage__main div{min-width:0;display:flex;flex-direction:column;gap:3px}.docscan-storage__main strong{color:var(--text-primary);font-size:.84rem;line-height:1.25}.docscan-storage__main span{color:var(--text-muted);font-size:.76rem;line-height:1.35}.docscan-storage__meter{grid-column:1 / -1;height:6px;overflow:hidden;background:var(--surface-2);border-radius:var(--r-full)}.docscan-storage__meter span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:inherit}.docscan-storage__side{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.docscan-storage-trigger{position:relative;z-index:1;flex-shrink:0}.docscan-storage-trigger strong{min-width:34px;padding:3px 7px;border-radius:var(--r-full);color:var(--accent);background:var(--accent-dim);font-size:.74rem;line-height:1}.docscan-header-memory{margin-left:auto}.docscan-storage-trigger--standalone{align-self:flex-end}.docscan-storage-modal{width:min(100%,460px)}.docscan-storage-modal .docscan-storage{box-shadow:none}.docscan-home{display:flex;flex-direction:column;gap:18px;padding:20px}.docscan-home__hero,.docscan-viewbar{display:flex;align-items:center;justify-content:space-between;gap:14px}.docscan-home__brand{display:flex;align-items:center;gap:14px;min-width:0}.docscan-home__brand h2,.docscan-viewbar h2{margin:0;font-family:var(--font-disp);font-size:1.15rem;font-weight:800;color:var(--text-primary);letter-spacing:0;line-height:1.15}.docscan-home__brand p,.docscan-viewbar p{margin:4px 0 0;color:var(--text-muted);font-size:.84rem;line-height:1.45}.docscan-icon-tile{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--r-md);color:var(--text-on-blue);background:linear-gradient(135deg,var(--blue-700),var(--blue-500));box-shadow:var(--sh-blue)}.docscan-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 14px;border-radius:var(--r-md);border:1px solid transparent;font-size:.84rem;font-weight:700;color:var(--text-primary);background:transparent;transition:background var(--fast),border-color var(--fast),color var(--fast),transform var(--fast),box-shadow var(--fast);white-space:nowrap}.docscan-btn:hover:not(:disabled){transform:translateY(-1px)}.docscan-btn:active:not(:disabled){transform:translateY(0)}.docscan-btn:disabled{opacity:.45;cursor:not-allowed}.docscan-btn--primary{color:var(--text-on-blue);background:linear-gradient(135deg,var(--blue-600),var(--blue-500));box-shadow:var(--sh-blue)}.docscan-btn--primary:hover:not(:disabled){filter:brightness(1.05)}.docscan-btn--secondary{color:var(--text-secondary);background:var(--surface-0);border-color:var(--border)}.docscan-btn--secondary:hover:not(:disabled),.docscan-btn--ghost:hover:not(:disabled){color:var(--text-primary);background:var(--surface-2);border-color:var(--border-md)}.docscan-btn--ghost{color:var(--text-muted);border-color:transparent}.docscan-btn--danger{color:var(--danger);background:#ef444414;border-color:#ef444438}.docscan-btn--sm{min-height:34px;padding:0 11px;font-size:.78rem}.docscan-btn--icon{width:36px;height:36px;min-height:36px;padding:0}.docscan-search{display:flex;align-items:center;gap:10px;min-height:44px;padding:0 14px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-muted)}.docscan-search input,.docscan-field input{width:100%;min-width:0;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:.92rem}.docscan-search input::placeholder,.docscan-field input::placeholder{color:var(--text-muted)}.docscan-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:260px;padding:32px 18px;text-align:center;color:var(--text-muted);border:1px dashed var(--border-md);border-radius:var(--r-lg);background:var(--surface-0)}.docscan-empty--compact{min-height:180px}.docscan-empty svg{color:var(--accent);opacity:.5}.docscan-empty h3{margin:0;color:var(--text-primary);font-size:1rem}.docscan-empty p{max-width:340px;margin:0;font-size:.86rem;line-height:1.45}.docscan-loading{display:flex;align-items:center;justify-content:center;gap:9px;min-height:180px;color:var(--text-muted);font-size:.84rem;font-weight:700;border:1px dashed var(--border);border-radius:var(--r-lg);background:var(--surface-0)}.docscan-list-heading{color:var(--text-muted);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.docscan-doc-list,.docscan-page-list,.docscan-preview-pages{display:flex;flex-direction:column;gap:8px}.docscan-doc-card,.docscan-page-card{display:flex;align-items:center;gap:12px;padding:10px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);transition:background var(--fast),border-color var(--fast),box-shadow var(--fast)}.docscan-doc-card:hover,.docscan-page-card:hover{border-color:var(--border-md);box-shadow:var(--sh-sm)}.docscan-doc-card__main{flex:1;min-width:0;display:flex;align-items:center;gap:12px;padding:0;border:none;background:transparent;text-align:left}.docscan-doc-thumb{width:48px;height:62px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm)}.docscan-doc-thumb img{width:100%;height:100%;object-fit:cover}.docscan-doc-info{min-width:0;display:flex;flex-direction:column;gap:5px}.docscan-doc-title{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:.94rem;font-weight:700;line-height:1.25}.docscan-doc-title>:first-child{min-width:0}.docscan-doc-meta{color:var(--text-muted);font-size:.78rem}.docscan-doc-actions,.docscan-page-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.docscan-badge{display:inline-flex;align-items:center;width:fit-content;min-height:21px;padding:2px 8px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:.68rem;font-weight:800;line-height:1;white-space:nowrap}.docscan-badge--success{color:var(--success);background:#10b9811a;border-color:#10b98140}.docscan-badge--warning{color:var(--warning);background:#f59e0b1a;border-color:#f59e0b3d}.docscan-badge--danger{color:var(--danger);background:#ef44441a;border-color:#ef44443d}.docscan-viewbar{min-height:64px;padding:12px 16px;border-bottom:1px solid var(--border)}.docscan-viewbar>div{min-width:0;flex:1;text-align:center}.docscan-viewbar h2{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.docscan-rename-btn{flex-shrink:0}.docscan-viewbar__spacer{width:36px;height:36px}.docscan-viewbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0}.docscan-capture,.docscan-corners,.docscan-filter,.docscan-organizer,.docscan-preview{display:flex;flex-direction:column}.docscan-camera-frame,.docscan-filter-preview,.docscan-canvas-stage{position:relative;min-height:380px;margin:16px;overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface-0)}.docscan-page--capture .docscan-camera-frame{min-height:clamp(420px,58dvh,620px)}.docscan-camera-frame__video,.docscan-filter-preview img{width:100%;height:100%;display:block;object-fit:contain}.docscan-camera-frame__video{position:absolute;inset:0;object-fit:cover;opacity:0;transition:opacity var(--fast)}.docscan-camera-frame__video.is-active{opacity:1}.docscan-camera-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);text-align:center;background:var(--surface-0);z-index:1}.docscan-camera-placeholder--overlay{background:#00000057;color:#fff}.docscan-camera-placeholder small{max-width:280px;color:var(--text-muted);font-size:.76rem;line-height:1.4}.docscan-camera-placeholder--overlay small{color:#ffffffc7}.docscan-action-row{display:flex;align-items:center;justify-content:center;gap:10px;padding:0 16px 16px}.docscan-action-row .docscan-btn{flex:1;max-width:260px}.docscan-divider{display:flex;align-items:center;justify-content:center;gap:12px;padding:0 16px 14px;color:var(--text-muted);font-size:.76rem;font-weight:700}.docscan-divider:before,.docscan-divider:after{content:"";height:1px;flex:1;background:var(--border)}.docscan-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;min-height:142px;margin:0 16px 16px;padding:22px;color:var(--text-secondary);background:var(--surface-0);border:1.5px dashed var(--border-md);border-radius:var(--r-lg);transition:background var(--fast),border-color var(--fast),color var(--fast)}.docscan-dropzone:hover{color:var(--accent);background:var(--accent-dim);border-color:var(--accent)}.docscan-dropzone:disabled{opacity:.55;cursor:not-allowed}.docscan-dropzone span{color:var(--text-primary);font-weight:800}.docscan-dropzone small{color:var(--text-muted);font-size:.76rem}.docscan-alert{display:flex;align-items:center;gap:8px;padding:11px 13px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);color:var(--text-secondary);font-size:.84rem;line-height:1.4}.docscan-alert--danger{color:var(--danger);background:#ef444414;border-color:#ef444438}.docscan-alert--warning{color:var(--warning);background:#f59e0b1a;border-color:#f59e0b3d;margin:16px 16px 0}.docscan-alert--success{color:var(--success);background:#10b9811a;border-color:#10b98140}.docscan-capture>.docscan-alert{margin:0 16px 14px}.docscan-canvas-stage{position:relative;display:flex;align-items:center;justify-content:center;min-height:460px;touch-action:none}.docscan-loupe{display:none;position:absolute;width:120px;height:120px;border-radius:50%;pointer-events:none;z-index:10;box-shadow:0 4px 20px #0000008c,0 0 0 1px #ffffff2e}.docscan-loupe.is-active{display:block}.docscan-corner-canvas{display:block;max-width:100%;max-height:100%;border-radius:var(--r-md);cursor:grab;box-shadow:var(--sh-md);touch-action:none;-webkit-user-select:none;user-select:none}.docscan-corner-canvas:active{cursor:grabbing}.docscan-canvas-placeholder{position:absolute;inset:12px;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-muted);font-size:.86rem;font-weight:700;text-align:center;background:var(--surface-0);border-radius:var(--r-md);pointer-events:none}.docscan-corner-legend{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px 14px;padding:0 16px 16px;color:var(--text-muted);font-size:.76rem;font-weight:700}.docscan-corner-legend span{display:inline-flex;align-items:center;gap:6px}.docscan-corner-legend i{width:10px;height:10px;border-radius:var(--r-full)}.docscan-filter-preview{display:flex;align-items:center;justify-content:center}.docscan-processing{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000057}.docscan-spinner{width:18px;height:18px;display:inline-block;border:2px solid currentColor;border-top-color:transparent;border-radius:var(--r-full);animation:docscan-spin .8s linear infinite}@keyframes docscan-spin{to{transform:rotate(360deg)}}.docscan-compare-btn{position:absolute;left:50%;bottom:14px;transform:translate(-50%);min-height:34px;padding:0 13px;border:1px solid rgba(255,255,255,.22);border-radius:var(--r-full);background:#00000094;color:#fff;font-size:.76rem;font-weight:800;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.docscan-filter-strip{display:flex;flex-direction:row;gap:8px;padding:0 16px 16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.docscan-filter-strip::-webkit-scrollbar{display:none}.docscan-filter-chip{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;width:74px;padding:8px 6px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-muted);scroll-snap-align:start;transition:border-color var(--fast),background var(--fast),box-shadow var(--fast);cursor:pointer}.docscan-filter-chip:hover:not(:disabled){border-color:var(--border-md);background:var(--surface-1)}.docscan-filter-chip.is-active{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 2px var(--border-focus)}.docscan-filter-chip:disabled{opacity:.5;cursor:not-allowed}.docscan-filter-chip__swatch{width:48px;height:48px;border-radius:var(--r-sm);flex-shrink:0;border:1px solid rgba(0,0,0,.12)}.docscan-filter-chip__label{font-size:.66rem;font-weight:800;text-align:center;line-height:1.25;color:var(--text-secondary)}.docscan-filter-chip.is-active .docscan-filter-chip__label{color:var(--accent)}.docscan-filter-chip__check{position:absolute;top:4px;right:4px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);background:var(--accent);color:#fff}.docscan-organizer-workspace{display:grid;grid-template-columns:minmax(230px,290px) minmax(0,1fr);align-items:stretch;gap:14px;padding:16px}.docscan-page-rail{min-width:0;display:flex;flex-direction:column;gap:10px}.docscan-page-rail__header{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--text-muted);font-size:.78rem;font-weight:800}.docscan-page-rail__header strong{min-width:28px;min-height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-full);color:var(--accent);background:var(--accent-dim)}.docscan-page-list{max-height:min(62vh,640px);overflow:auto;padding:0 4px 0 0}.docscan-page-number{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--r-full);background:var(--surface-2);color:var(--text-muted);font-size:.76rem;font-weight:900}.docscan-page-card{padding:0;overflow:hidden}.docscan-page-card.is-selected{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 2px var(--border-focus)}.docscan-page-card__main{width:100%;min-width:0;display:flex;align-items:center;gap:10px;padding:10px;border:none;background:transparent;color:inherit;text-align:left}.docscan-page-card__main:focus-visible{outline:3px solid var(--border-focus);outline-offset:-3px}.docscan-page-card img{width:54px;height:72px;object-fit:cover;flex-shrink:0;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2)}.docscan-page-info{min-width:0;flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:4px}.docscan-page-info strong{color:var(--text-primary);font-size:.9rem}.docscan-page-info span{color:var(--text-muted);font-size:.76rem}.docscan-page-preview-pane{min-width:0;min-height:540px;display:flex;flex-direction:column;overflow:hidden;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md)}.docscan-page-preview-pane__header{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border)}.docscan-page-preview-pane__header>div:first-child{min-width:0;display:flex;flex-direction:column;gap:3px}.docscan-page-preview-pane__header strong{overflow:hidden;color:var(--text-primary);font-size:.92rem;text-overflow:ellipsis;white-space:nowrap}.docscan-page-preview-pane__header span{color:var(--text-muted);font-size:.78rem}.docscan-page-preview-pane__stage{min-height:480px;flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:16px;background:var(--surface-1)}.docscan-page-preview-pane__stage img{width:auto;max-width:100%;max-height:min(70vh,680px);display:block;object-fit:contain;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);box-shadow:var(--sh-sm)}.docscan-action-row--organizer{padding-top:0}.docscan-preview-pages{padding:16px;gap:18px}.docscan-preview-page{display:flex;flex-direction:column;gap:8px}.docscan-preview-page figcaption{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--text-muted);font-size:.8rem;font-weight:800}.docscan-preview-page img{width:100%;display:block;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);box-shadow:var(--sh-sm)}.docscan-modal-backdrop{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:18px;background:#0000007a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.docscan-modal{width:min(100%,440px);display:flex;flex-direction:column;gap:16px;padding:18px;color:var(--text-primary);background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-lg)}.docscan-modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.docscan-modal__header h3{display:flex;align-items:center;gap:8px;margin:0;font-family:var(--font-disp);font-size:1.06rem;letter-spacing:0}.docscan-modal__header button{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--r-md);color:var(--text-muted);background:transparent}.docscan-modal__header button:hover{color:var(--text-primary);background:var(--surface-2)}.docscan-field{display:flex;flex-direction:column;gap:7px}.docscan-field span{color:var(--text-secondary);font-size:.8rem;font-weight:800}.docscan-field input,.docscan-field select{min-height:42px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-md);background-color:var(--surface-1)}.docscan-field input:focus,.docscan-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.docscan-field small,.docscan-modal-note{margin:0;color:var(--text-muted);font-size:.78rem;line-height:1.4}.docscan-segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;padding:5px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1)}.docscan-segmented button{min-height:34px;border:none;border-radius:var(--r-sm);color:var(--text-secondary);background:transparent;font-weight:800}.docscan-segmented button.is-active{color:var(--text-primary);background:var(--surface-0);box-shadow:var(--sh-sm)}.docscan-modal__actions{display:flex;justify-content:flex-end;gap:10px}.docscan-privacy{display:inline-flex;align-items:center;justify-content:center;gap:7px;color:var(--text-muted);font-size:.78rem;font-weight:700}.tools-scanner-art{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;color:#fff}.tools-scanner-art__page{position:relative;width:42%;max-width:118px;aspect-ratio:.74;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#ffffffeb;color:var(--blue-700);box-shadow:0 18px 42px #0000003d}.tools-scanner-art__scan{position:absolute;left:-18%;right:-18%;height:3px;border-radius:var(--r-full);background:#ffffffe6;box-shadow:0 0 18px #ffffffbf}@media(max-width:700px){.docscan-home{padding:16px}.docscan-home__hero{align-items:stretch;flex-direction:column}.docscan-storage{grid-template-columns:1fr}.docscan-storage__side{justify-content:flex-start}.docscan-home__hero .docscan-btn{width:100%}.docscan-home__brand{align-items:flex-start}.docscan-icon-tile{width:46px;height:46px}.docscan-camera-frame,.docscan-filter-preview,.docscan-canvas-stage{min-height:300px;margin:12px}.docscan-page--capture{gap:.75rem;padding:.75rem 1rem 2rem}.docscan-page--capture .docscan-camera-frame{min-height:min(56dvh,460px)}.docscan-canvas-stage{min-height:360px}.docscan-filter-strip{padding:0 12px 12px}.docscan-organizer-workspace{grid-template-columns:1fr;gap:12px;padding:12px}.docscan-page-rail{gap:8px}.docscan-page-rail .docscan-page-list{max-height:none;gap:8px;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:0 0 4px;scroll-snap-type:x mandatory}.docscan-page-card{width:124px;min-width:124px;scroll-snap-align:start}.docscan-page-card__main{min-height:126px;position:relative;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;padding:8px}.docscan-page-card .docscan-page-number{position:absolute;top:8px;left:8px;width:24px;height:24px;font-size:.72rem}.docscan-page-card img{width:62px;height:76px}.docscan-page-card .docscan-page-info{width:100%;flex:0 0 auto;align-items:center;gap:0}.docscan-page-card .docscan-page-info strong{max-width:100%;overflow:hidden;font-size:.78rem;text-align:center;text-overflow:ellipsis;white-space:nowrap}.docscan-page-card .docscan-page-info>span,.docscan-page-card .docscan-page-info .docscan-badge{display:none}.docscan-page-preview-pane{min-height:0}.docscan-page-preview-pane__header{grid-template-columns:minmax(0,1fr) auto;align-items:start}.docscan-page-preview-pane__header .docscan-page-actions{grid-column:1 / -1;justify-content:flex-start}.docscan-page-preview-pane__stage{min-height:430px;padding:12px}.docscan-page-preview-pane__stage img{max-height:62vh}.docscan-action-row{flex-direction:column;padding:0 12px 12px}.docscan-action-row .docscan-btn{width:100%;max-width:none}.docscan-doc-card{align-items:flex-start}.docscan-doc-actions{flex-direction:column}.docscan-viewbar{padding:10px 12px}.docscan-rename-btn{width:36px;padding:0}.docscan-rename-btn span{display:none}.docscan-viewbar-actions{gap:6px}.docscan-viewbar-actions .docscan-btn{width:36px;padding:0;font-size:0}.docscan-modal__actions{flex-direction:column-reverse}.docscan-dropzone{flex-direction:row;min-height:48px;padding:0 16px;gap:10px;border-style:solid;border-width:1px;border-radius:var(--r-md)}.docscan-dropzone small{display:none}}@media(max-width:480px){.docscan-doc-card{display:grid;grid-template-columns:1fr auto}.docscan-doc-card__main{min-width:0}.docscan-doc-title{align-items:flex-start;flex-direction:column;gap:5px}.docscan-page-card{width:112px;min-width:112px}.docscan-page-card__main{min-height:118px;gap:5px;padding:8px 7px}.docscan-page-card img{width:56px;height:70px}.docscan-page-card .docscan-page-info strong{font-size:.74rem}.docscan-page-preview-pane__stage{min-height:360px}}.cfg-page{min-height:100dvh;background:var(--surface-0);display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem 4rem;width:100%;box-sizing:border-box;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.cfg-page::-webkit-scrollbar{display:none}.cfg-page>*{width:100%;max-width:640px;flex-shrink:0}.cfg-nav{display:flex;align-items:center;gap:.75rem;min-height:36px}.cfg-back{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--r-md);border:none;background:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;padding:0;transition:background var(--fast),color var(--fast)}.cfg-back:hover{background:var(--accent-dim);color:var(--accent)}.cfg-title{font-family:var(--font-disp);font-size:1.25rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin:0}.cfg-section{display:flex;flex-direction:column;gap:.5rem}.cfg-section-title{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin:0;padding-left:4px}.cfg-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.cfg-divider{height:1px;background:var(--border);margin:0}.cfg-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;flex-wrap:wrap}.cfg-row--danger .cfg-row-label{color:var(--danger, #ef4444)}.cfg-row-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.cfg-row-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.cfg-row-desc{font-size:.73rem;color:var(--text-muted);line-height:1.4}.cfg-pill-toggle{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full);padding:3px;gap:2px;flex-shrink:0}.cfg-pill-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:var(--r-full);border:none;background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--fast);white-space:nowrap}.cfg-pill-btn:hover{color:var(--text-secondary)}.cfg-pill-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.cfg-toggle{width:44px;height:24px;border-radius:12px;background:var(--border-md, #444);border:none;position:relative;cursor:pointer;transition:background .22s ease;flex-shrink:0}.cfg-toggle.on{background:var(--accent)}.cfg-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000040;transition:transform .22s cubic-bezier(.16,1,.3,1);pointer-events:none}.cfg-toggle.on .cfg-toggle-thumb{transform:translate(20px)}.cfg-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--r-full);font-size:.78rem;font-weight:700;cursor:pointer;transition:all var(--fast);white-space:nowrap;flex-shrink:0}.cfg-btn-outline{border:1.5px solid var(--border-md);background:transparent;color:var(--text-secondary)}.cfg-btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.cfg-btn-ghost{border:none;background:transparent;color:var(--text-muted)}.cfg-btn-ghost:hover{color:var(--text-primary);background:var(--surface-2)}.cfg-btn-danger-outline{border:1.5px solid rgba(239,68,68,.3);background:transparent;color:var(--danger, #ef4444)}.cfg-btn-danger-outline:hover{background:#ef44441a;border-color:var(--danger, #ef4444)}.cfg-btn-danger{border:none;background:var(--danger, #ef4444);color:#fff}.cfg-btn-danger:hover{background:#dc2626}.cfg-btn-primary{border:none;background:var(--accent);color:#fff;padding:8px 20px}.cfg-btn-primary:hover:not(:disabled){filter:brightness(.88)}.cfg-btn-primary:disabled{background:var(--surface-2);color:var(--text-muted);cursor:not-allowed}.cfg-confirm-inline{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.cfg-confirm-text{font-size:.78rem;color:var(--text-muted);font-weight:500}.cfg-report-desc{font-size:.83rem;color:var(--text-secondary);margin:0;padding:.85rem 1rem 0;line-height:1.5}.cfg-report-form{display:flex;flex-direction:column;gap:.6rem;padding:.75rem 1rem 1rem}.cfg-report-textarea{width:100%;padding:10px 12px;background:var(--surface-0);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-size:.875rem;line-height:1.5;resize:vertical;font-family:inherit;box-sizing:border-box;transition:border-color var(--fast),box-shadow var(--fast)}.cfg-report-textarea::placeholder{color:var(--text-muted)}.cfg-report-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.cfg-feedback{font-size:.78rem;font-weight:600;text-align:center;margin:0}.cfg-feedback--ok{color:var(--success, #10b981)}.cfg-feedback--err{color:var(--danger, #ef4444)}.cfg-version{font-size:.72rem;color:var(--text-muted);text-align:center;margin:0;opacity:.55}.cfg-row--col{flex-direction:column;align-items:flex-start;gap:.75rem}.cfg-swatches{display:flex;flex-wrap:wrap;gap:8px}.cfg-swatch{width:32px;height:32px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;flex-shrink:0;outline:none}.cfg-swatch:hover{transform:scale(1.15);box-shadow:0 4px 12px #0003}.cfg-swatch.active{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--surface-1),0 0 0 4px currentColor;transform:scale(1.1)}.cfg-radius-options{display:flex;gap:8px;width:100%}.cfg-radius-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-0);cursor:pointer;transition:all var(--fast)}.cfg-radius-btn:hover{border-color:var(--border-focus);background:var(--accent-dim)}.cfg-radius-btn.active{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}.cfg-radius-preview{width:36px;height:24px;background:var(--accent);display:block;border-radius:var(--r-preview, 6px);opacity:.85;transition:border-radius .2s ease}.cfg-radius-label{font-size:.7rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.cfg-radius-btn.active .cfg-radius-label{color:var(--accent)}.cfg-font-options{display:flex;gap:8px;width:100%}.cfg-font-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-0);cursor:pointer;transition:all var(--fast)}.cfg-font-btn:hover{border-color:var(--border-focus);background:var(--accent-dim)}.cfg-font-btn.active{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}.cfg-font-preview{font-weight:700;color:var(--text-primary);line-height:1}.cfg-font-btn.active .cfg-font-preview{color:var(--accent)}.cfg-font-label{font-size:.68rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.cfg-font-btn.active .cfg-font-label{color:var(--accent)}@media(max-width:480px){.cfg-page{padding:1rem 1rem 3rem}.cfg-row{flex-direction:column;align-items:flex-start;gap:.75rem}.cfg-confirm-inline{width:100%}.cfg-pill-toggle{width:100%;justify-content:stretch}.cfg-pill-btn{flex:1;justify-content:center}}.subject-action-overlay{position:fixed;inset:0;z-index:600;background:#0000006b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;padding:0 0 env(safe-area-inset-bottom,0);animation:sam-fade-in .15s ease}@media(min-width:600px){.subject-action-overlay{align-items:center}}@keyframes sam-fade-in{0%{opacity:0}to{opacity:1}}.subject-action-modal{background:var(--surface-1);border:1px solid var(--border-md);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:480px;max-height:min(92dvh,720px);overflow-y:auto;padding:20px 20px 28px;box-shadow:0 -8px 48px #0000002e;animation:sam-slide-up .22s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;gap:14px}.subject-action-modal--exam{max-width:540px}@media(min-width:600px){.subject-action-modal{border-radius:var(--r-xl);box-shadow:0 20px 64px #00000038}}@keyframes sam-slide-up{0%{transform:translateY(32px);opacity:0}to{transform:translateY(0);opacity:1}}.sam-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.sam-back{width:30px;height:30px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--fast)}.sam-back:hover{background:var(--surface-3);color:var(--text-primary)}.sam-title-wrap{flex:1;min-width:0}.sam-subject{font-size:.98rem;font-weight:700;color:var(--text-primary);line-height:1.3;margin-bottom:3px}.sam-meta{font-size:.74rem;color:var(--text-muted);font-weight:500;display:flex;align-items:center;flex-wrap:wrap}.sam-career-tag{color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.02em}.sam-close{width:30px;height:30px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--fast)}.sam-close:hover{background:var(--danger);border-color:var(--danger);color:#fff}.sam-room-pill{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border-focus);border-radius:var(--r-full);padding:4px 12px;width:fit-content}.sam-actions{display:flex;flex-direction:column;gap:9px}.sam-btn{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--r-md);border:1.5px solid var(--border);font-size:.84rem;font-weight:600;cursor:pointer;transition:all var(--fast);text-align:left;width:100%}.sam-btn-map{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent)}.sam-btn-map:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--sh-blue);transform:translateY(-1px)}.sam-btn-map:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.sam-btn-exam{background:var(--surface-2);border-color:var(--border-md);color:var(--text-secondary)}.sam-btn-exam:hover{background:var(--surface-3);border-color:var(--border-md);color:var(--text-primary)}.sam-btn-exam-active{background:#f59e0b1a;border-color:#f59e0b66;color:#b45309}[data-theme=dark] .sam-btn-exam-active{color:#fcd34d;background:#f59e0b1f;border-color:#f59e0b59}.sam-btn-exam-active:hover{background:#f59e0b2e}.sam-exam-badge{margin-left:auto;font-size:.68rem;background:#f59e0b2e;color:#b45309;padding:2px 7px;border-radius:var(--r-full);font-weight:700;border:1px solid rgba(245,158,11,.3)}[data-theme=dark] .sam-exam-badge{color:#fcd34d;background:#f59e0b26;border-color:#f59e0b40}.sam-exam-summary{display:grid;grid-template-columns:1fr auto;gap:2px 12px;width:100%;padding:12px 14px;border:1.5px solid var(--border-md);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font-family:var(--font);text-align:left;cursor:pointer;transition:all var(--fast)}.sam-exam-summary:hover{border-color:var(--border-focus);background:var(--surface-2)}.sam-exam-summary-label{grid-column:1 / -1;font-size:.68rem;font-weight:800;color:var(--text-muted);text-transform:uppercase}.sam-exam-summary strong{min-width:0;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sam-exam-summary span:last-child{font-size:.76rem;color:var(--text-secondary);white-space:nowrap}.sam-datepicker-wrap{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--surface-0);border:1.5px solid var(--border-md);border-radius:var(--r-md);animation:sam-slide-up .18s cubic-bezier(.16,1,.3,1)}.sam-date-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.sam-date-input{width:100%;padding:9px 12px;background:var(--surface-1);border:1.5px solid var(--border-md);border-radius:var(--r-md);color:var(--text-primary);font-size:.85rem;font-family:var(--font);transition:border-color var(--fast),box-shadow var(--fast)}.sam-date-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.sam-date-actions{display:flex;align-items:center;gap:8px}.sam-save-btn{flex:1;padding:9px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--r-md);font-size:.84rem;font-weight:700;cursor:pointer;transition:all var(--fast);display:flex;align-items:center;justify-content:center;gap:6px}.sam-save-btn:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px);box-shadow:var(--sh-blue)}.sam-save-btn:disabled{opacity:.45;cursor:not-allowed}.sam-save-btn.saved{background:var(--success)}.sam-btn-icon{width:36px;height:36px;border-radius:var(--r-md);border:1.5px solid var(--border-md);background:var(--surface-2);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast);flex-shrink:0}.sam-btn-danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.ecb-wrap{display:flex;align-items:center;gap:10px;padding:8px 16px 6px;border-bottom:1px solid var(--border);background:var(--surface-1);flex-shrink:0;overflow:hidden}.ecb-label{display:flex;align-items:center;gap:5px;font-size:.68rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;flex-shrink:0}.ecb-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;-webkit-overflow-scrolling:touch}.ecb-scroll::-webkit-scrollbar{display:none}.ecb-card{position:relative;display:flex;align-items:stretch;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-0);flex-shrink:0;padding:7px 28px 7px 10px;min-width:130px;max-width:180px;transition:all var(--fast)}.ecb-card:hover{border-color:var(--border-md);box-shadow:var(--sh-sm);transform:translateY(-1px)}.ecb-card-inner{display:flex;flex-direction:column;gap:2px;min-width:0}.ecb-countdown-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em}.ecb-subject{font-size:.75rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ecb-time{font-size:.62rem;color:var(--text-muted);font-weight:500}.ecb-remove-btn{position:absolute;top:4px;right:4px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted);border-radius:4px;cursor:pointer;opacity:0;transition:all var(--fast)}.ecb-card:hover .ecb-remove-btn{opacity:1}.ecb-remove-btn:hover{background:var(--danger);color:#fff;opacity:1}.ecb-card--urgent .ecb-countdown-label{color:var(--danger)}.ecb-card--urgent{border-color:#ef444459;background:#ef44440d}.ecb-card--soon .ecb-countdown-label{color:#d97706}[data-theme=dark] .ecb-card--soon .ecb-countdown-label{color:#fcd34d}.ecb-card--soon{border-color:#f59e0b66;background:#f59e0b0f}.ecb-card--normal .ecb-countdown-label{color:var(--accent)}.ecb-card--past{opacity:.5}.ecb-card--past .ecb-countdown-label{color:var(--text-muted)}.ecb-extra-badge{margin-left:5px;font-size:.58rem;background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-focus);border-radius:var(--r-full);padding:1px 5px;font-weight:800;vertical-align:middle}.sam-btn-hint{margin-left:auto;font-size:.64rem;font-weight:500;color:inherit;opacity:.7;white-space:nowrap}.exam-workspace{display:flex;flex-direction:column;gap:12px}.exam-compose{display:flex;flex-direction:column;gap:12px;padding:14px;background:var(--surface-0);border:1.5px solid var(--border-md);border-radius:var(--r-lg)}.exam-section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--text-primary);font-size:.84rem;font-weight:800}.exam-section-heading small{flex-shrink:0;color:var(--text-muted);font-size:.68rem;font-weight:700}.exam-type-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.exam-type-chip{min-height:38px;padding:8px 10px;border-radius:var(--r-md);border:1.5px solid var(--border-md);background:var(--surface-1);color:var(--text-secondary);font-family:var(--font);font-size:.78rem;font-weight:800;cursor:pointer;transition:all var(--fast)}.exam-type-chip:hover{background:var(--surface-2);color:var(--text-primary)}.exam-type-chip--active{background:var(--accent-dim);color:var(--accent);border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-glow)}.exam-datetime-board{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(190px,.65fr);gap:12px;align-items:stretch}.exam-calendar-card,.exam-time-card{min-width:0;background:var(--surface-1);border:1.5px solid var(--border-md);border-radius:var(--r-lg);padding:12px}.exam-calendar-top,.exam-time-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.exam-calendar-top>div:first-child,.exam-time-head{min-width:0}.exam-calendar-top strong,.exam-time-head strong{display:block;margin-top:3px;color:var(--text-primary);font-size:.88rem;font-weight:800}.exam-calendar-nav{display:inline-flex;gap:6px;flex-shrink:0}.exam-calendar-nav button,.exam-time-column button{display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);cursor:pointer;transition:all var(--fast)}.exam-calendar-nav button{width:30px;height:30px;border-radius:var(--r-sm)}.exam-calendar-nav button:hover,.exam-time-column button:hover{border-color:var(--border-focus);background:var(--accent-dim);color:var(--accent)}.exam-calendar-weekdays,.exam-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.exam-calendar-weekdays{gap:4px;margin-bottom:5px}.exam-calendar-weekdays span{color:var(--text-muted);font-size:.66rem;font-weight:800;text-align:center}.exam-calendar-grid{gap:4px}.exam-calendar-day{aspect-ratio:1;min-width:0;border:1px solid transparent;border-radius:var(--r-sm);background:transparent;color:var(--text-primary);font-family:var(--font);font-size:.76rem;font-weight:700;cursor:pointer;transition:all var(--fast)}.exam-calendar-day:hover{background:var(--surface-2);border-color:var(--border)}.exam-calendar-day--outside{color:var(--text-muted);opacity:.55}.exam-calendar-day--today{border-color:var(--border-focus);color:var(--accent)}.exam-calendar-day--selected{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 18px var(--accent-glow)}.exam-calendar-day--selected:hover{background:var(--accent);color:#fff}.exam-calendar-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.exam-calendar-footer span{min-width:0;color:var(--text-secondary);font-size:.74rem;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exam-calendar-footer--required{color:var(--danger, #ef4444)!important}.exam-validation-hint{display:flex;align-items:center;gap:6px;margin:4px 0 0;color:var(--danger, #ef4444);font-size:.74rem;font-weight:700}.exam-validation-hint svg{flex-shrink:0}.exam-calendar-footer button,.exam-time-presets button{border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);border-radius:var(--r-full);font-family:var(--font);font-size:.7rem;font-weight:800;cursor:pointer;transition:all var(--fast)}.exam-calendar-footer button{padding:5px 10px}.exam-calendar-footer button:hover,.exam-time-presets button:hover,.exam-time-preset--active{border-color:var(--border-focus);background:var(--accent-dim);color:var(--accent)}.exam-time-card{display:flex;flex-direction:column}.exam-time-picker{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:8px;padding:8px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg)}.exam-time-column{display:grid;grid-template-rows:28px 46px auto 28px;align-items:center;justify-items:center;gap:4px;min-width:0}.exam-time-column button{width:30px;height:26px;border-radius:var(--r-sm)}.exam-time-column input{width:100%;min-width:0;border:none;background:var(--surface-2);color:var(--text-primary);border-radius:var(--r-md);font-family:var(--font);font-size:1.16rem;font-weight:900;text-align:center;padding:8px 4px}.exam-time-column input:focus{outline:2px solid var(--border-focus)}.exam-time-column span{color:var(--text-muted);font-size:.62rem;font-weight:800;text-transform:uppercase}.exam-time-separator{color:var(--text-muted);font-size:1.2rem;font-weight:900;padding-bottom:18px}.exam-time-presets{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.exam-time-presets button{padding:5px 9px}.exam-add-actions--main{padding-top:2px}.exam-panel{background:var(--surface-0);border:1.5px solid var(--border-md);border-radius:var(--r-lg);overflow:hidden;animation:sam-slide-up .2s cubic-bezier(.16,1,.3,1)}.exam-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface-1);border-bottom:1px solid var(--border)}.exam-panel-title{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:800;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.exam-panel-delete-all{display:flex;align-items:center;gap:5px;font-size:.68rem;font-weight:700;color:var(--danger);background:none;border:none;cursor:pointer;opacity:.7;padding:3px 6px;border-radius:var(--r-sm);transition:all var(--fast)}.exam-panel-delete-all:hover{opacity:1;background:#ef444414}.exam-panel-empty{font-size:.75rem;color:var(--text-muted);padding:14px 14px 4px;margin:0;text-align:center}.exam-list{display:flex;flex-direction:column}.exam-row{border-bottom:1px solid var(--border)}.exam-row:last-child{border-bottom:none}.exam-row-view{display:flex;align-items:center;padding:10px 14px;cursor:pointer;transition:background var(--fast);gap:10px}.exam-row-view:hover{background:var(--surface-2)}.exam-row-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.exam-row-badge{font-size:.63rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;padding:2px 7px;border-radius:var(--r-full);white-space:nowrap;flex-shrink:0}.exam-row-badge--normal{background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-focus)}.exam-row-badge--soon{background:#f59e0b1a;color:#b45309;border:1px solid rgba(245,158,11,.3)}[data-theme=dark] .exam-row-badge--soon{color:#fcd34d}.exam-row-badge--urgent{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.exam-row-badge--past{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.exam-row-text{display:flex;flex-direction:column;min-width:0}.exam-row-name{font-size:.78rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.exam-row-date{font-size:.66rem;color:var(--text-muted);font-weight:500}.exam-row-delete{width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--fast);flex-shrink:0;opacity:.65}.exam-row-view:hover .exam-row-delete{opacity:1}.exam-row-delete:hover{background:#ef44441f;color:var(--danger);opacity:1}.exam-row-edit{padding:12px 14px;display:flex;flex-direction:column;gap:8px;background:var(--surface-1)}.exam-row-edit-top{display:flex;flex-direction:column;gap:8px}.exam-row-edit-actions{display:flex;gap:8px;justify-content:flex-end}.exam-name-select,.exam-name-custom{padding:8px 10px;background:var(--surface-0);border:1.5px solid var(--border-md);border-radius:var(--r-md);color:var(--text-primary);font-size:.78rem;font-family:var(--font);width:100%;transition:border-color var(--fast)}.exam-name-select:focus,.exam-name-custom:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.exam-row-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-md);font-size:.76rem;font-weight:700;cursor:pointer;border:1.5px solid transparent;transition:all var(--fast);font-family:var(--font)}.exam-row-btn--cancel{background:var(--surface-2);border-color:var(--border);color:var(--text-muted)}.exam-row-btn--cancel:hover{background:var(--surface-3)}.exam-row-btn--save{background:var(--accent);border-color:var(--accent);color:#fff}.exam-row-btn--save:hover:not(:disabled){filter:brightness(.88);transform:translateY(-1px)}.exam-row-btn--save:disabled{opacity:.45;cursor:not-allowed}.exam-add-form{padding:12px 14px;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--border);background:var(--surface-1)}.exam-add-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.exam-field-wrap{display:flex;flex-direction:column;gap:4px}.exam-add-actions{display:flex;gap:8px;justify-content:flex-end}.exam-add-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px;background:none;border:none;border-top:1px dashed var(--border-md);color:var(--accent);font-size:.78rem;font-weight:700;cursor:pointer;font-family:var(--font);transition:all var(--fast)}.exam-add-btn:hover{background:var(--accent-dim)}@media(max-width:520px){.subject-action-modal{padding:18px 16px 24px}.sam-btn{flex-wrap:wrap}.sam-btn-hint{width:100%;margin-left:26px}.sam-exam-summary{grid-template-columns:1fr}.sam-exam-summary span:last-child{white-space:normal}.exam-datetime-board{grid-template-columns:1fr}}@media(max-width:360px){.exam-type-grid{grid-template-columns:1fr}}.sem-overlay{position:fixed;inset:0;z-index:700;background:#050a198c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px;animation:sem-fade .2s ease}@keyframes sem-fade{0%{opacity:0}to{opacity:1}}.sem-card{background:var(--surface-0);border:1px solid var(--border-md);border-radius:var(--r-xl);width:100%;max-width:420px;box-shadow:0 32px 80px #00000047,0 0 0 1px #ffffff0f;overflow:hidden;animation:sem-pop .28s cubic-bezier(.34,1.56,.64,1);position:relative}@keyframes sem-pop{0%{transform:scale(.88) translateY(16px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.sem-hero{position:relative;padding:28px 24px 24px;overflow:hidden}.sem-hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#1d4ed8,#7c3aed 60%,#db2777);opacity:.92;z-index:0}[data-theme=dark] .sem-hero-bg{background:linear-gradient(135deg,#1e3a8a,#5b21b6 60%,#9d174d);opacity:.85}.sem-hero-bg:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.05'/%3E%3C/svg%3E");opacity:.25}.sem-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:8px;padding-right:40px}.sem-badge{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;padding:4px 10px;border-radius:var(--r-full);width:fit-content;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sem-badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.sem-badge--normal{background:#fff3;color:#ffffffe6}.sem-badge--normal .sem-badge-dot{background:#ffffffe6}.sem-badge--soon{background:#fdba7440;color:#fde68a}.sem-badge--soon .sem-badge-dot{background:#fde68a;animation:sem-pulse 1.6s ease infinite}.sem-badge--urgent{background:#fca5a540;color:#fca5a5}.sem-badge--urgent .sem-badge-dot{background:#fca5a5;animation:sem-pulse .9s ease infinite}.sem-badge--past{background:#ffffff1a;color:#ffffff8c}.sem-badge--past .sem-badge-dot{background:#fff6}@keyframes sem-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.sem-subject-name{font-family:var(--font-disp);font-size:1.35rem;font-weight:800;color:#fff;line-height:1.2;letter-spacing:-.02em;text-shadow:0 2px 8px rgba(0,0,0,.2)}.sem-group-pill{display:inline-flex;width:fit-content;font-size:.72rem;font-weight:700;color:#ffffffbf;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);border-radius:var(--r-full);padding:3px 10px}.sem-close-btn{position:absolute;top:16px;right:16px;z-index:2;width:28px;height:28px;border-radius:var(--r-md);border:1px solid rgba(255,255,255,.2);background:#ffffff1f;color:#fffc;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sem-close-btn:hover{background:#ffffff40;color:#fff}.sem-date-row{display:flex;align-items:stretch;gap:0;border-bottom:1px solid var(--border);background:var(--surface-1)}.sem-date-block{display:flex;align-items:center;gap:10px;flex:1;padding:14px 18px}.sem-date-divider{width:1px;background:var(--border);flex-shrink:0}.sem-date-icon{width:18px;height:18px;color:var(--accent);flex-shrink:0}.sem-date-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:2px}.sem-date-value{font-size:.8rem;font-weight:700;color:var(--text-primary);line-height:1.2}.sem-actions{padding:20px;display:flex;flex-direction:column;gap:14px}.sem-share-hint{font-size:.78rem;color:var(--text-muted);line-height:1.55;margin:0}.sem-url-box{background:var(--surface-2);border:1.5px solid var(--border-md);border-radius:var(--r-md);padding:10px 14px;overflow:hidden}.sem-url-text{font-size:.7rem;color:var(--text-muted);font-family:SFMono-Regular,Consolas,Menlo,monospace;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sem-btn-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sem-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 16px;border-radius:var(--r-md);font-size:.82rem;font-weight:700;cursor:pointer;transition:all var(--fast);border:1.5px solid transparent;font-family:var(--font);white-space:nowrap}.sem-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 10px #2563eb40}.sem-btn-primary:hover{filter:brightness(.88);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb59}.sem-btn-success{background:var(--success)!important;border-color:var(--success)!important;box-shadow:0 4px 14px #10b9814d!important;animation:sem-success-bounce .35s cubic-bezier(.34,1.56,.64,1)}@keyframes sem-success-bounce{0%{transform:scale(.92)}to{transform:scale(1)}}.sem-btn-secondary{background:var(--surface-2);color:var(--text-secondary);border-color:var(--border-md)}.sem-btn-secondary:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-focus);transform:translateY(-1px)}.sem-btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border);width:100%}.sem-btn-ghost:hover{background:var(--surface-2);color:var(--text-secondary);border-color:var(--border-md)}.sem-qr-panel{padding:20px;display:flex;flex-direction:column;align-items:center;gap:20px}.sem-qr-frame{position:relative;padding:4px}.sem-qr-inner{background:#fff;padding:16px;border-radius:var(--r-md);color:#000;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px #0000001f}.sem-qr-corner{position:absolute;width:22px;height:22px;border-color:var(--accent);border-style:solid}.sem-qr-corner--tl{top:0;left:0;border-width:3px 0 0 3px;border-radius:4px 0 0}.sem-qr-corner--tr{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 4px 0 0}.sem-qr-corner--bl{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 4px}.sem-qr-corner--br{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 4px}.sw-page{min-height:100dvh;display:flex;flex-direction:column;gap:0;max-width:480px;margin:0 auto;padding-bottom:env(safe-area-inset-bottom,16px);background:var(--surface-0);color:var(--text-primary)}.sw-header{display:flex;align-items:center;gap:12px;padding:20px 18px 12px}.sw-clock{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sw-clock__time{font-size:2.4rem;font-weight:900;letter-spacing:-.04em;line-height:1;color:var(--text-primary);font-family:var(--font-disp)}.sw-clock__day{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.sw-header-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;border-radius:var(--r-full);color:var(--text-muted);background:var(--surface-2);transition:background var(--fast),color var(--fast)}.sw-header-btn:hover{color:var(--accent);background:var(--accent-dim)}.sw-day-strip{display:flex;gap:6px;padding:0 18px 14px;overflow-x:auto;scrollbar-width:none}.sw-day-strip::-webkit-scrollbar{display:none}.sw-day-pill{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:26px;padding:0 10px;border-radius:var(--r-full);font-size:.7rem;font-weight:900;letter-spacing:.04em;color:var(--text-muted);background:var(--surface-2);border:1px solid transparent;transition:background var(--fast),color var(--fast)}.sw-day-pill--active{color:var(--accent);background:var(--accent-dim);border-color:var(--accent)}.sw-progress-wrap{display:flex;align-items:center;gap:8px;padding:0 18px 16px}.sw-prog-label{font-size:.64rem;font-weight:800;color:var(--text-muted);white-space:nowrap;min-width:34px;text-align:center}.sw-progress-track{position:relative;flex:1;height:6px;background:var(--surface-2);border-radius:var(--r-full);overflow:visible}.sw-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#60a5fa);border-radius:var(--r-full);transition:width .6s ease}.sw-progress-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:13px;height:13px;border-radius:var(--r-full);background:#60a5fa;border:2.5px solid var(--surface-0);box-shadow:0 0 10px #60a5faa6;z-index:2;pointer-events:none}.sw-featured{position:relative;display:flex;align-items:center;gap:12px;margin:0 18px 16px;padding:12px 14px 12px 16px;background:var(--surface-1);border:1.5px solid;border-radius:var(--r-lg);overflow:hidden}.sw-featured__stripe{position:absolute;left:0;top:0;bottom:0;width:4px}.sw-featured__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.sw-featured__label{font-size:.62rem;font-weight:900;letter-spacing:.1em;color:var(--accent);text-transform:uppercase}.sw-featured__name{font-size:.98rem;font-weight:800;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sw-featured__meta{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--text-muted);font-weight:700}.sw-featured__room{font-size:.7rem;color:var(--text-muted)}.sw-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:var(--r-full);font-size:.64rem;font-weight:900;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.sw-badge--class{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.25)}.sw-badge--practice{background:#10b98126;color:#34d399;border:1px solid rgba(16,185,129,.25)}.sw-list{flex:1;display:flex;flex-direction:column;padding:0 18px;gap:0}.sw-event{position:relative;display:flex;align-items:center;gap:10px;padding:12px 10px 12px 6px;border-bottom:1px solid var(--border);transition:background var(--fast)}.sw-event:last-child{border-bottom:none}.sw-event--current{background:#60a5fa0d;border-radius:var(--r-md);border-bottom:none;margin-bottom:2px}.sw-event--past{opacity:.38}.sw-now-indicator{position:absolute;left:-4px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:var(--r-full);background:#60a5fa;border:2px solid var(--surface-0);box-shadow:0 0 8px #60a5fab3;z-index:2}.sw-event__stripe{width:3px;min-height:40px;border-radius:var(--r-full);flex-shrink:0;align-self:stretch}.sw-event__time{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:48px;flex-shrink:0;text-align:center}.sw-event__t{font-size:.75rem;font-weight:800;color:var(--text-secondary);line-height:1.2}.sw-event__dur{font-size:.6rem;font-weight:700;color:var(--text-muted)}.sw-event__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sw-event__name{font-size:.87rem;font-weight:800;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sw-event__sub{font-size:.67rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sw-event__right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.sw-event__room{font-size:.64rem;color:var(--text-muted)}.sw-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:240px;color:var(--text-muted);text-align:center}.sw-empty p{margin:0;font-size:.9rem;font-weight:700;color:var(--text-secondary)}.sw-empty-link{font-size:.8rem;font-weight:800;color:var(--accent);text-decoration:none}.sw-footer{padding:18px 18px 28px;text-align:center}.sw-footer-link{font-size:.78rem;font-weight:800;color:var(--accent);text-decoration:none;letter-spacing:.02em;opacity:.8}.sw-footer-link:hover{opacity:1}.cal-page{height:100dvh;min-height:100dvh;width:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.4rem 1.4rem 4rem;background:radial-gradient(circle at top left,rgba(59,130,246,.08),transparent 30rem),var(--surface-0);color:var(--text-primary);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.cal-page>*{width:100%;max-width:1180px;flex-shrink:0}.cal-nav .bib-bc-item a{display:inline-flex;align-items:center;gap:.35rem}.cal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-1);box-shadow:var(--sh-sm)}.cal-header-main{display:flex;align-items:center;gap:.9rem;min-width:0}.cal-header-icon{width:52px;height:52px;border-radius:var(--r-md);display:grid;place-items:center;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border-focus);flex:0 0 auto}.cal-eyebrow{margin:0 0 .22rem;color:var(--accent);font-size:.72rem;line-height:1;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.cal-header h1{margin:0;color:var(--text-primary);font-family:var(--font-disp);font-size:1.45rem;line-height:1.1;letter-spacing:0}.cal-header p:last-child{margin:.36rem 0 0;color:var(--text-muted);font-size:.86rem;line-height:1.45}.cal-career-select{display:grid;gap:.35rem;min-width:250px;color:var(--text-muted);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.cal-career-select select{width:100%;min-height:38px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font:inherit;font-size:.82rem;font-weight:700;letter-spacing:0;text-transform:none;padding:0 .7rem;outline:none}.cal-career-select select:focus{border-color:var(--border-focus)}.cal-auth-gate{min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2.5rem;border:1px dashed var(--border-md);border-radius:var(--r-lg);background:var(--surface-1);text-align:center;color:var(--text-muted)}.cal-auth-gate svg{color:var(--accent)}.cal-auth-gate h2{margin:0;color:var(--text-primary);font-size:1.05rem}.cal-auth-gate p{max-width:430px;margin:0;font-size:.86rem;line-height:1.55}.cal-auth-gate-actions{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:.5rem}.cal-auth-gate-actions .cal-primary-action svg{color:currentColor}.cal-dashboard{display:grid;grid-template-columns:minmax(220px,1fr) auto;align-items:stretch;gap:.9rem}.cal-dashboard-title{display:flex;flex-direction:column;justify-content:center;gap:.2rem;padding:.9rem 1rem;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-1)}.cal-dashboard-title span{color:var(--text-primary);font-size:.96rem;font-weight:800}.cal-dashboard-title small{color:var(--text-muted);font-size:.78rem;font-weight:650}.cal-metrics{display:grid;grid-template-columns:repeat(5,minmax(106px,1fr));gap:.6rem}.cal-metric{min-width:0;display:grid;grid-template-columns:auto 1fr;grid-template-areas:"icon value" "label label";align-items:center;gap:.15rem .5rem;padding:.78rem .82rem;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-1)}.cal-metric svg{grid-area:icon;color:var(--accent)}.cal-metric strong{grid-area:value;color:var(--text-primary);font-size:1.14rem;line-height:1;font-weight:850}.cal-metric span{grid-area:label;color:var(--text-muted);font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.cal-mode-switch{width:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.25rem;margin:.6rem;margin-bottom:0;padding:.25rem;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-0);flex:0 0 auto}.cal-mode-switch+.cal-panel-header{border-top:1px solid var(--border)}.cal-mode-button{min-height:38px;border:0;border-radius:var(--r-full);display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:0 1rem;background:transparent;color:var(--text-muted);font-size:.84rem;font-weight:800;cursor:pointer;transition:background var(--fast),color var(--fast),box-shadow var(--fast)}.cal-mode-button--active{background:var(--accent);color:#fff;box-shadow:0 8px 22px var(--accent-glow)}.cal-layout{display:grid;gap:1rem;align-items:stretch}.cal-layout--teachers{grid-template-columns:minmax(300px,360px) minmax(0,1fr)}.cal-layout--subjects{grid-template-columns:minmax(270px,330px) minmax(250px,300px) minmax(0,1fr)}.cal-panel{min-height:520px;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-1);box-shadow:var(--sh-sm)}.cal-rating-panel{padding:1rem;gap:.9rem}.cal-panel-header{display:grid;gap:.75rem;padding:.95rem;border-bottom:1px solid var(--border);flex:0 0 auto}.cal-panel-header--plain{min-height:77px;align-content:center}.cal-panel-header strong{display:block;color:var(--text-primary);font-size:.88rem;line-height:1.2}.cal-panel-header span{display:block;margin-top:.2rem;color:var(--text-muted);font-size:.72rem;line-height:1.3}.cal-search{min-height:38px;display:flex;align-items:center;gap:.45rem;padding:0 .7rem;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-muted)}.cal-search input{min-width:0;width:100%;border:0;outline:0;background:transparent;color:var(--text-primary);font:inherit;font-size:.82rem}.cal-search input::placeholder{color:var(--text-muted)}.cal-list{display:flex;flex-direction:column;gap:.35rem;padding:.55rem;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.cal-list-row{width:100%;min-height:58px;display:flex;align-items:center;gap:.65rem;border:1px solid transparent;border-radius:var(--r-md);padding:.62rem .7rem;background:transparent;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--fast),border-color var(--fast),box-shadow var(--fast)}.cal-list-row:hover{background:var(--surface-2);border-color:var(--border)}.cal-list-row:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.cal-list-row--active{background:var(--accent-dim);border-color:var(--border-focus);box-shadow:inset 3px 0 0 var(--accent)}.cal-avatar{width:36px;height:36px;border-radius:var(--r-full);display:grid;place-items:center;flex:0 0 auto;border:1px solid var(--border-focus);background:var(--accent-dim);color:var(--accent);font-size:.7rem;font-weight:850}.cal-subject-mark{width:10px;height:34px;border-radius:var(--r-full);flex:0 0 auto;box-shadow:0 0 14px #0000001f}.cal-row-main{min-width:0;flex:1 1 auto;display:grid;gap:.18rem}.cal-row-main strong{min-width:0;color:var(--text-primary);font-size:.8rem;line-height:1.25;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-row-main small{min-width:0;color:var(--text-muted);font-size:.68rem;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-row-badge{min-width:24px;height:24px;border-radius:var(--r-full);display:grid;place-items:center;background:#10b9811f;border:1px solid rgba(16,185,129,.32);color:var(--success);font-size:.7rem;font-weight:850}.cal-success-icon{color:var(--success);flex:0 0 auto}.cal-context-header{display:grid;gap:.22rem;padding:.9rem;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2)}.cal-context-label{color:var(--accent);font-size:.66rem;font-weight:850;letter-spacing:.07em;text-transform:uppercase}.cal-context-header strong{color:var(--text-primary);font-size:1rem;line-height:1.25}.cal-context-header small{color:var(--text-muted);font-size:.76rem;line-height:1.35}.cal-chip-row{display:flex;gap:.45rem;overflow-x:auto;padding-bottom:.1rem;scrollbar-width:none}.cal-chip-row::-webkit-scrollbar{display:none}.cal-chip{min-height:32px;max-width:260px;display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-0);color:var(--text-muted);padding:0 .72rem;font-size:.74rem;font-weight:750;white-space:nowrap;cursor:pointer}.cal-chip span{width:8px;height:8px;border-radius:var(--r-full);flex:0 0 auto}.cal-chip--active{color:var(--accent);border-color:var(--border-focus);background:var(--accent-dim)}.cal-form-card{display:flex;flex-direction:column;gap:.85rem;min-width:0}.cal-form-card--bare{gap:.75rem}.cal-form-heading{display:flex;align-items:center;gap:.7rem;min-width:0}.cal-form-title{min-width:0;flex:1 1 auto;display:grid;gap:.12rem}.cal-form-title span{color:var(--text-primary);font-size:.92rem;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-form-title small{color:var(--text-muted);font-size:.74rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-target-meta{display:flex;flex-wrap:wrap;gap:.45rem}.cal-target-meta span{min-height:26px;display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-0);color:var(--text-muted);padding:0 .65rem;font-size:.7rem;font-weight:750}.cal-score-stack{display:grid;gap:.55rem}.cal-score-field{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.8rem;min-height:70px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);padding:.72rem .8rem}.cal-score-field:focus-within{border-color:var(--border-focus)}.cal-score-meta{min-width:0;display:flex;align-items:center;gap:.62rem}.cal-score-icon{width:34px;height:34px;border-radius:var(--r-md);display:grid;place-items:center;color:var(--accent);background:var(--accent-dim);flex:0 0 auto}.cal-score-meta span:last-child{min-width:0;display:grid;gap:.15rem}.cal-score-meta strong{color:var(--text-primary);font-size:.82rem;line-height:1.2}.cal-score-meta small{color:var(--text-muted);font-size:.68rem;line-height:1.3}.cal-score-control,.cal-score-dots{display:inline-flex;align-items:center;gap:.25rem}.cal-score-button,.cal-score-dot{width:32px;height:32px;border-radius:var(--r-md);display:grid;place-items:center;border:1px solid var(--border);background:var(--surface-0);color:var(--text-muted)}.cal-score-button{cursor:pointer;transition:transform var(--fast),color var(--fast),background var(--fast),border-color var(--fast)}.cal-score-button:hover{transform:translateY(-1px);border-color:var(--border-focus)}.cal-score-button--on,.cal-score-dot--on{color:#fff;background:var(--accent);border-color:var(--accent)}.cal-form-actions{display:flex;justify-content:flex-end;gap:.55rem;flex-wrap:wrap}.cal-primary-action,.cal-secondary-action,.cal-ghost-action{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border-radius:var(--r-full);padding:0 1rem;font-size:.78rem;font-weight:850;cursor:pointer;transition:transform var(--fast),filter var(--fast),background var(--fast),color var(--fast)}.cal-primary-action{border:0;background:var(--accent);color:#fff;box-shadow:0 8px 22px var(--accent-glow)}.cal-primary-action:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.cal-primary-action:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.cal-secondary-action,.cal-ghost-action{border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted)}.cal-secondary-action:hover,.cal-ghost-action:hover{background:var(--surface-3);color:var(--text-secondary)}.cal-secondary-action{align-self:flex-end}.cal-rated-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem}.cal-rated-item{display:grid;justify-items:center;gap:.22rem;padding:.72rem .45rem;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);text-align:center}.cal-rated-item>svg{color:var(--accent)}.cal-rated-item strong{color:var(--text-primary);font-size:1.12rem;line-height:1}.cal-rated-item span{color:var(--text-muted);font-size:.66rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.cal-rated-item .cal-score-dots{gap:.12rem}.cal-rated-item .cal-score-dot{width:22px;height:22px;border-radius:var(--r-sm)}.cal-empty-state{min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;padding:2rem;border:1px dashed var(--border-md);border-radius:var(--r-lg);background:var(--surface-1);color:var(--text-muted);text-align:center}.cal-empty-state--wide{max-width:680px}.cal-empty-state svg{color:var(--accent)}.cal-empty-state strong{color:var(--text-primary);font-size:.95rem}.cal-empty-state span{max-width:390px;font-size:.8rem;line-height:1.45}.sam-btn-rate{background:#f59e0b14;border-color:#f59e0b4d;color:#b45309}.sam-btn-rate:hover{background:#d97706;color:#fff;border-color:#d97706;box-shadow:0 2px 14px #d9770666;transform:translateY(-1px)}[data-theme=dark] .sam-btn-rate{color:#fbbf24;background:#f59e0b1a;border-color:#f59e0b40}[data-theme=dark] .sam-btn-rate:hover{background:#d97706;color:#fff}@media(max-width:1080px){.cal-dashboard{grid-template-columns:1fr}.cal-metrics{grid-template-columns:repeat(5,minmax(0,1fr))}.cal-layout--subjects{grid-template-columns:minmax(240px,300px) minmax(0,1fr)}.cal-layout--subjects .cal-rating-panel{grid-column:1 / -1}}@media(max-width:820px){.cal-page{padding:1rem .85rem 3rem}.cal-header{align-items:flex-start;flex-direction:column}.cal-career-select{width:100%;min-width:0}.cal-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.cal-layout,.cal-layout--teachers,.cal-layout--subjects{grid-template-columns:1fr}.cal-panel{min-height:auto}.cal-list{max-height:360px}}@media(max-width:580px){.cal-header-main{align-items:flex-start}.cal-header-icon{width:44px;height:44px}.cal-header h1{font-size:1.2rem}.cal-header p:last-child{font-size:.8rem}.cal-mode-switch{margin:.6rem;margin-bottom:0}.cal-score-field{grid-template-columns:1fr;align-items:stretch}.cal-score-control{justify-content:space-between}.cal-score-button{width:100%}.cal-rated-grid{grid-template-columns:1fr}}.lp-page{flex:1;min-height:0;height:100dvh;display:flex;flex-direction:column;padding:20px 20px 0;background:var(--surface-0);overflow:hidden;max-width:1200px;margin:0 auto;width:100%;position:relative;border-left:1px solid var(--border);border-right:1px solid var(--border);box-shadow:var(--sh-md)}.lp-day-tabs-wrap{display:flex;background:var(--surface-1);padding:5px;border-radius:var(--r-xl);gap:3px;margin:14px 0;border:1px solid var(--border);overflow-x:auto;scrollbar-width:none}.lp-day-tabs-wrap::-webkit-scrollbar{display:none}.lp-day-tab{flex:1;min-width:44px;display:flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:var(--r-full);border:none;background:transparent;font-size:.78rem;font-weight:700;color:var(--text-muted);cursor:pointer;transition:all var(--fast);white-space:nowrap}.lp-day-tab:hover{color:var(--text-secondary);background:var(--surface-2)}.lp-day-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 10px #00000026}.lp-day-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.lp-day-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0}.lp-day-stats{display:flex;gap:8px;margin-left:auto}.lp-stat{font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:var(--r-full)}.lp-stat--class{background:#64748b1f;color:var(--text-muted)}.lp-stat--routine{background:var(--accent-dim);color:var(--accent)}.lp-legend{display:flex;align-items:center;gap:6px;margin-bottom:10px;font-size:.75rem;color:var(--text-muted)}.lp-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.lp-legend-dot--class{background:#94a3b8}.lp-legend-dot--routine{background:var(--accent)}.lp-legend-text{margin-right:8px}.lp-col-headers{display:flex;padding-left:54px;margin-bottom:4px;gap:2px}.lp-col-header{flex:1;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:4px 8px;background:var(--surface-1);border-radius:var(--r-sm)}.lp-col-header:first-child{border-radius:var(--r-sm) 0 0 var(--r-sm)}.lp-col-header:last-child{border-radius:0 var(--r-sm) var(--r-sm) 0}.lp-timeline-scroll{flex:1;min-height:0;overflow-y:auto;padding-bottom:100px}.lp-timeline{display:flex;gap:0;position:relative}.lp-hours-col{width:50px;flex-shrink:0;position:relative}.lp-hour-row{display:flex;align-items:flex-start;padding-top:2px;border-top:1px solid var(--border)}.lp-hour-label{font-size:.68rem;color:var(--text-muted);font-weight:600;line-height:1;white-space:nowrap}.lp-events-cols{flex:1;display:flex;gap:2px}.lp-col{flex:1;position:relative;min-width:0}.lp-col--classes{flex:0 0 46%}.lp-col--routines{flex:1}.lp-grid-row{border-top:1px solid var(--border);box-sizing:border-box}.lp-grid-row:nth-child(2n){background:#00000003}.lp-block{position:absolute;left:4px;right:4px;border-radius:var(--r-sm);padding:4px 6px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;gap:1px;box-sizing:border-box;min-height:20px}.lp-block--class{background:#64748b1f;border-left:3px solid #94a3b8;cursor:default}.lp-block--routine{cursor:default}.lp-block--routine:hover .lp-block-del{opacity:1}.lp-block-name{font-size:.72rem;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-secondary)}.lp-block--class .lp-block-name{color:var(--text-secondary)}.lp-block-sub{font-size:.65rem;font-weight:500;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-muted)}.lp-block-del{position:absolute;top:4px;right:4px;background:transparent;border:none;cursor:pointer;opacity:0;transition:opacity var(--fast);padding:2px;border-radius:3px;display:flex;align-items:center;justify-content:center}.lp-block-del:hover{background:#00000014}.lp-col-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--text-muted);opacity:.5;pointer-events:none;padding:0 8px;text-align:center}.lp-fab{position:absolute;bottom:28px;right:24px;width:58px;height:58px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px #0003,0 0 0 0 var(--accent-glow);transition:all var(--fast);z-index:50}.lp-fab:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 8px 28px #00000040}.lp-modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:16px;animation:fadeIn .2s ease-out}@media(min-width:640px){.lp-modal-overlay{align-items:center}}.lp-modal{background:var(--surface-0);width:100%;max-width:460px;max-height:90dvh;overflow-y:auto;padding:22px;border-radius:var(--r-xl);box-shadow:var(--sh-lg);border:1px solid var(--border);display:flex;flex-direction:column;gap:16px;animation:slideUp .3s cubic-bezier(.2,.8,.2,1);margin-bottom:12px}@media(min-width:640px){.lp-modal{margin-bottom:0}}.lp-modal-header{display:flex;align-items:center;justify-content:space-between}.lp-modal-title{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:0}.lp-modal-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--r-sm);display:flex;align-items:center;transition:color var(--fast)}.lp-modal-close:hover{color:var(--text-primary)}.lp-form-group{display:flex;flex-direction:column;gap:8px}.lp-label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.lp-input{width:100%;background:var(--surface-1);border:1.5px solid var(--border);color:var(--text-primary);padding:11px 14px;border-radius:var(--r-md);font-size:.9rem;font-family:inherit;outline:none;transition:border-color var(--fast);box-sizing:border-box}.lp-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.lp-emoji-grid{display:flex;flex-wrap:wrap;gap:6px}.lp-emoji-btn{width:40px;height:40px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-1);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--fast)}.lp-emoji-btn:hover{border-color:var(--accent);transform:scale(1.08)}.lp-emoji-btn.active{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 2px var(--accent-glow)}.lp-swatches{display:flex;flex-wrap:wrap;gap:8px}.lp-swatch{width:30px;height:30px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:all var(--fast);outline:none}.lp-swatch:hover{transform:scale(1.12)}.lp-swatch.active{border-color:var(--surface-0);box-shadow:0 0 0 2.5px currentColor,0 2px 8px #0003}.lp-day-pills{display:flex;flex-wrap:wrap;gap:6px}.lp-day-pill{padding:6px 12px;border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface-1);font-size:.78rem;font-weight:700;color:var(--text-muted);cursor:pointer;transition:all var(--fast)}.lp-day-pill:hover{border-color:var(--accent);color:var(--text-secondary)}.lp-day-pill.active{color:#fff}.lp-time-row{display:flex;align-items:center;gap:10px}.lp-select{flex:1;background:var(--surface-1);border:1.5px solid var(--border);color:var(--text-primary);padding:10px 12px;border-radius:var(--r-md);font-size:.88rem;font-family:inherit;outline:none;cursor:pointer;transition:border-color var(--fast);appearance:none;text-align:center}.lp-select:focus{border-color:var(--accent)}.lp-time-sep{color:var(--text-muted);font-weight:700;flex-shrink:0}.lp-error{font-size:.75rem;color:var(--danger, #ef4444);margin:0}.lp-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.lp-week-overview{display:flex;gap:4px;margin:10px 0 4px;padding:8px 10px;background:var(--surface-1);border-radius:var(--r-lg);border:1px solid var(--border)}.lp-week-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 2px 6px;border-radius:var(--r-md);border:1.5px solid transparent;background:transparent;cursor:pointer;transition:all var(--fast);min-width:0;position:relative}.lp-week-col:hover{background:var(--surface-2)}.lp-week-col.active{border-color:var(--accent);background:var(--accent-dim)}.lp-week-col-label{font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.lp-week-col.active .lp-week-col-label{color:var(--accent)}.lp-week-col-track{width:100%;flex:1;min-height:32px;position:relative;background:var(--surface-0);border-radius:3px;border:1px solid var(--border);overflow:hidden}.lp-week-col-block{position:absolute;left:0;right:0;border-radius:2px;opacity:.85}.lp-week-col-count{font-size:.6rem;font-weight:800;color:var(--accent);line-height:1}.lp-ctl-wrap{display:flex;flex-direction:column;gap:3px}.lp-ctl-bar{position:relative;height:26px;background:var(--surface-1);border-radius:var(--r-sm);border:1px solid var(--border);overflow:hidden}.lp-ctl-seg{position:absolute;top:3px;bottom:3px;border-radius:3px;min-width:2px}.lp-ctl-seg--class{background:#ef444466}.lp-ctl-seg--routine{background:#f59e0b73}.lp-ctl-sel{position:absolute;top:4px;bottom:4px;border-radius:3px;min-width:2px;opacity:.85;border:1.5px solid}.lp-ctl-tick-line{position:absolute;top:0;bottom:0;width:1px;background:var(--border);opacity:.6}.lp-ctl-ticks{position:relative;height:12px}.lp-ctl-tick-label{position:absolute;transform:translate(-50%);font-size:.58rem;color:var(--text-muted);font-weight:600}.lp-ctl-legend{display:flex;gap:10px;flex-wrap:wrap}.lp-ctl-leg{font-size:.7rem;color:var(--text-muted)}.lp-cat-pills{display:flex;flex-wrap:wrap;gap:6px}.lp-cat-pill{padding:5px 12px;border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface-1);font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--fast);white-space:nowrap}.lp-cat-pill:hover{border-color:var(--accent)}.lp-cat-pill.active{color:#fff}.lp-label-opt{font-size:.68rem;font-weight:400;text-transform:none;letter-spacing:0;opacity:.65}.lp-time-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.lp-duration-badge{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;font-weight:700;color:var(--accent);background:var(--accent-dim);padding:2px 8px;border-radius:var(--r-full)}.lp-find-slot-btn{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;color:var(--text-muted);background:var(--surface-1);border:1.5px solid var(--border);padding:3px 10px;border-radius:var(--r-full);cursor:pointer;margin-left:auto;transition:all var(--fast)}.lp-find-slot-btn:hover{border-color:var(--accent);color:var(--accent)}.lp-select-wrap{flex:1}.lp-select--class{border-color:#ef444499!important;background:#ef44440f!important}.lp-select--routine{border-color:#f59e0b99!important;background:#f59e0b0f!important}.lp-select-legend{display:flex;gap:12px;flex-wrap:wrap;font-size:.68rem;color:var(--text-muted);margin:2px 0 0}.lp-conflict-warn{display:flex;gap:10px;padding:12px 14px;background:#ef444412;border:1.5px solid rgba(239,68,68,.3);border-radius:var(--r-md);color:var(--text-secondary)}.lp-conflict-warn-icon{color:#ef4444;flex-shrink:0;margin-top:1px}.lp-conflict-warn-body{display:flex;flex-direction:column;gap:4px;min-width:0}.lp-conflict-warn-title{font-size:.8rem;font-weight:700;color:#ef4444}.lp-conflict-warn-detail{font-size:.75rem;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lp-force-check{display:flex;align-items:center;gap:6px;font-size:.76rem;font-weight:600;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;margin-top:4px}.lp-force-check input{cursor:pointer;accent-color:var(--accent)}.lp-reminder-row{display:flex;align-items:center;gap:10px}.lp-reminder-toggle{background:transparent;border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--text-muted);cursor:pointer;padding:4px 6px;display:flex;align-items:center;transition:all var(--fast);margin-left:auto}.lp-reminder-toggle:hover,.lp-reminder-toggle.active{border-color:var(--accent)}.lp-stat--time{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.lp-now-btn{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;color:#ef4444;background:#ef444414;border:1px solid rgba(239,68,68,.3);padding:3px 10px;border-radius:var(--r-full);cursor:pointer;transition:all var(--fast)}.lp-now-btn:hover{background:#ef444426}.lp-quick-row{display:flex;align-items:center;gap:6px;margin-bottom:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.lp-quick-row::-webkit-scrollbar{display:none}.lp-quick-label{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;flex-shrink:0}.lp-quick-chip{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--surface-1);border:1.5px solid var(--border);padding:4px 12px;border-radius:var(--r-full);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all var(--fast)}.lp-quick-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.lp-fab-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:#fff;color:var(--accent);font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--accent);line-height:1}.lp-current-time-line{height:2px;background:#ef4444;z-index:10;pointer-events:none;box-shadow:0 0 8px #ef444480}.lp-current-time-dot{position:absolute;left:-6px;top:-4px;width:10px;height:10px;background:#ef4444;border-radius:50%;box-shadow:0 0 6px #ef444466}.lp-block-reminder{font-size:.6rem;font-weight:600;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:3px}.lp-block-name--routine{display:flex;align-items:center;gap:4px}.lp-icon-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px}@media(max-width:400px){.lp-icon-grid{grid-template-columns:repeat(6,1fr)}}.lp-icon-btn{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-1);color:var(--text-muted);cursor:pointer;transition:all var(--fast);padding:0;min-height:40px}.lp-icon-btn:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.08)}.lp-icon-btn.active{color:#fff;box-shadow:0 2px 10px #0003;transform:scale(1.05)}.lp-nav-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.lp-bell-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--r-md);border:1.5px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--fast)}.lp-bell-btn:hover{border-color:var(--accent);color:var(--accent)}.lp-bell-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.lp-bell-btn.denied{opacity:.4;cursor:not-allowed}.lp-pin-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--r-md);border:1.5px solid var(--border);background:transparent;color:var(--text-muted);font-size:.7rem;font-weight:600;cursor:pointer;transition:all var(--fast);white-space:nowrap}.lp-pin-btn:hover{border-color:var(--accent);color:var(--accent)}.lp-pin-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.lp-tp-wrap{flex:1;position:relative}.lp-tp-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;padding:12px 14px;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;font-size:1rem;font-weight:700;font-family:inherit;font-variant-numeric:tabular-nums;color:var(--text-primary);letter-spacing:.02em;transition:all var(--fast);text-align:center}.lp-tp-btn:hover,.lp-tp-btn:focus-visible{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-dim)}.lp-tp-btn--class{border-color:#ef44448c;background:#ef44440d;color:#ef4444}.lp-tp-btn--routine{border-color:#f59e0b8c;background:#f59e0b0d;color:#d97706}.lp-tp-time{flex:1;text-align:center}.lp-tp-conflict-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.lp-tp-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .18s ease}.lp-tp-chevron--open{transform:rotate(180deg)}.lp-tp-list{position:fixed;background:var(--surface-0);border:1.5px solid var(--border);border-radius:var(--r-md);box-shadow:0 8px 32px #00000038,0 2px 8px #0000001f;max-height:220px;overflow-y:auto;z-index:9999;list-style:none;margin:0;padding:4px;scrollbar-width:thin}.lp-tp-list::-webkit-scrollbar{width:4px}.lp-tp-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.lp-tp-option{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 12px;border-radius:var(--r-sm);cursor:pointer;font-size:.88rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-secondary);transition:background .12s ease;-webkit-user-select:none;user-select:none}.lp-tp-option:hover{background:var(--surface-2)}.lp-tp-option--sel{background:var(--accent-dim);color:var(--accent);font-weight:800}.lp-tp-option--class{background:#ef44440d}.lp-tp-option--routine{background:#f59e0b0d}.lp-tp-option--class:hover{background:#ef44441a}.lp-tp-option--routine:hover{background:#f59e0b1a}.lp-tp-option--class.lp-tp-option--sel{background:#ef44441f;color:#ef4444}.lp-tp-option--routine.lp-tp-option--sel{background:#f59e0b1f;color:#d97706}.lp-tp-opt-time{flex:1}.lp-tp-opt-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.lp-tp-action-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;padding:2px 3px;border-radius:4px;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color var(--fast),background var(--fast)}.lp-tp-action-btn:hover{color:var(--text-primary);background:var(--surface-2)}.lp-tp-btn--manual{padding:6px 10px;gap:6px}.lp-tp-manual-input{flex:1;background:transparent;border:none;outline:none;font-size:1rem;font-weight:700;font-family:inherit;font-variant-numeric:tabular-nums;color:var(--text-primary);text-align:center;min-width:0;cursor:text;-webkit-appearance:none}.lp-tp-manual-input::-webkit-calendar-picker-indicator{display:none}.lp-tp-btn--class .lp-tp-manual-input{color:#ef4444}.lp-tp-btn--routine .lp-tp-manual-input{color:#d97706}.todo-page{flex:1;min-height:0;height:100dvh;display:flex;flex-direction:column;padding:24px;background:var(--surface-0);position:relative;max-width:800px;margin:0 auto;width:100%;overflow:hidden}.todo-horizontal-calendar{display:flex;overflow-x:auto;background:var(--surface-1);padding:10px 12px;border-radius:var(--r-xl);margin:16px 0 20px;border:1px solid var(--border);box-shadow:0 2px 10px #00000008;gap:4px;scrollbar-width:none;-webkit-user-select:none;user-select:none}.todo-horizontal-calendar.dragging{cursor:grabbing}.todo-horizontal-calendar::-webkit-scrollbar{display:none}.todo-calendar-day{display:flex;flex-direction:column;align-items:center;padding:10px 16px;border-radius:var(--r-lg);gap:6px;transition:all var(--fast);position:relative;cursor:pointer;border:1.5px solid transparent;background:transparent;flex-shrink:0}.todo-day-name{font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.todo-day-number{font-size:.95rem;font-weight:700;color:var(--text-secondary)}.todo-calendar-day.selected{background:var(--surface-2);box-shadow:var(--sh-sm);border-color:var(--accent)}.todo-calendar-day.selected .todo-day-name,.todo-calendar-day.selected .todo-day-number{color:var(--text-primary)}.todo-calendar-day.today{background:var(--accent);border-color:var(--accent)}.todo-calendar-day.today .todo-day-name,.todo-calendar-day.today .todo-day-number{color:#fff}.todo-calendar-day.has-pending:after{content:"";position:absolute;top:8px;right:8px;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:1}.todo-calendar-day.today.has-pending:after{background:#fffc}.todo-header{margin-bottom:20px}.todo-header-date{font-size:1.35rem;font-weight:800;color:var(--text-primary);margin:0 0 2px;line-height:1.2}.todo-header-subtitle{font-size:.82rem;color:var(--text-muted);margin:0;font-weight:500}.todo-pill-tabs{display:flex;background:var(--surface-1);padding:5px;border-radius:var(--r-xl);gap:4px;margin-bottom:20px;border:1px solid var(--border)}.todo-pill-tab{flex:1;display:flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:var(--r-full);border:none;background:transparent;font-size:.8rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all var(--fast)}.todo-pill-tab:hover{color:var(--text-secondary);background:var(--surface-2)}.todo-pill-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 10px #00000026}.todo-list-container{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:4px 4px 120px}.todo-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center;gap:16px}.todo-empty-state p{font-size:.95rem;line-height:1.6;margin:0}.todo-item{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--surface-0);border:1.5px solid var(--border);border-radius:var(--r-lg);transition:all var(--normal);box-shadow:0 2px 8px #0000000a;position:relative}.todo-item:before{content:"";position:absolute;left:0;top:20%;height:60%;width:3px;border-radius:0 3px 3px 0;background:var(--accent);opacity:0;transition:opacity var(--fast)}.todo-item:hover{border-color:var(--accent);box-shadow:0 4px 16px #00000014;transform:translateY(-1px)}.todo-item:hover:before{opacity:1}.todo-item.completed{opacity:.55;background:var(--surface-1);box-shadow:none;border-color:var(--border)}.todo-item.completed:before{opacity:0!important}.todo-checkbox{width:24px;height:24px;border-radius:7px;border:2px solid var(--border-focus);cursor:pointer;display:flex;align-items:center;justify-content:center;background:transparent;transition:all var(--fast);color:#fff;flex-shrink:0;padding:0}.todo-checkbox:hover{border-color:var(--accent);background:#6366f10f;transform:scale(1.08)}.todo-checkbox.checked{background:var(--accent);border-color:var(--accent);box-shadow:0 2px 8px #6366f159}.todo-text{flex:1;font-size:.9rem;color:var(--text-primary);font-weight:500;transition:all var(--fast);word-break:break-word;line-height:1.4;min-width:0}.todo-item.completed .todo-text{text-decoration:line-through;color:var(--text-muted)}.todo-delete-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--r-sm);transition:all var(--fast);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0}.todo-item:hover .todo-delete-btn{opacity:1}.todo-delete-btn:hover{color:#ef4444;background:#ef44441a;transform:scale(1.1)}.todo-fab{position:fixed;bottom:30px;right:30px;width:60px;height:60px;border-radius:50%;background:var(--accent);color:#fff;box-shadow:0 4px 20px #2563eb59;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--fast);z-index:100}.todo-fab:hover{transform:scale(1.06) translateY(-3px);box-shadow:0 8px 28px #2563eb73}.todo-modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:20px;animation:fadeIn .2s ease-out}.todo-modal{background:var(--surface-0);width:100%;max-width:500px;padding:24px;border-radius:var(--r-xl);box-shadow:var(--sh-lg);display:flex;flex-direction:column;gap:16px;border:1px solid var(--border);animation:slideUp .3s cubic-bezier(.2,.8,.2,1);margin-bottom:20px}.todo-modal-title{margin:0;font-size:1.3rem;font-weight:800;color:var(--text-primary)}.todo-input{width:100%;background:var(--surface-1);border:1.5px solid var(--border);color:var(--text-primary);padding:14px 16px;border-radius:var(--r-md);font-size:1rem;font-family:inherit;outline:none;transition:border-color var(--fast);box-sizing:border-box}.todo-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11f}.todo-modal-actions{display:flex;justify-content:flex-end;gap:12px}.todo-modal-btn{padding:10px 20px;border-radius:var(--r-xl);border:none;font-size:.95rem;font-weight:700;cursor:pointer;transition:all var(--fast)}.todo-modal-btn.cancel{background:var(--surface-1);color:var(--text-primary)}.todo-modal-btn.cancel:hover{background:var(--surface-2)}.todo-modal-btn.submit{background:var(--accent);color:#fff;box-shadow:0 2px 8px #0000001a}.todo-modal-btn.submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2563eb40}.todo-modal-btn.submit:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}@media(min-width:768px){.todo-modal-overlay{align-items:center}.todo-modal{margin-bottom:0}}.mapa-page{position:fixed;inset:0;overflow:hidden;background:transparent;pointer-events:none;z-index:10}.mapa-page>*{pointer-events:auto}.mapa-canvas-root{position:absolute;inset:0;width:100%;height:100%}.mapa-canvas-root>div{pointer-events:none}.mapa-v2-canvas-root>div{pointer-events:auto}.mapa-topbar{position:absolute;top:0;left:0;right:0;height:56px;display:flex;align-items:center;gap:12px;padding:0 24px;background:#ffffffd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);z-index:200}@media(min-width:768px){.mapa-topbar{height:62px;gap:16px;padding:0 24px}}[data-theme=dark] .mapa-topbar{background:#0b1120cc}.mapa-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);background:transparent;border:1px solid var(--border);color:var(--text-primary);cursor:pointer;transition:background var(--fast),border-color var(--fast);flex-shrink:0}.mapa-back-btn:hover{background:var(--surface-2);border-color:var(--border-md)}.mapa-title{font-family:var(--font-disp);font-size:1rem;font-weight:700;color:var(--text-primary);white-space:nowrap;flex-shrink:0}.mapa-search-wrap{flex:1;max-width:360px;position:relative;margin-left:4px}@media(min-width:768px){.mapa-search-wrap{max-width:480px}}.mapa-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;display:flex}.mapa-search-input{width:100%;height:36px;padding:0 12px 0 34px;border-radius:var(--r-full);border:1px solid var(--border-md);background:var(--surface-1);color:var(--text-primary);font-family:var(--font);font-size:.875rem;outline:none;transition:border-color var(--fast),box-shadow var(--fast);box-sizing:border-box}@media(min-width:768px){.mapa-search-input{height:40px;font-size:.925rem}}.mapa-search-input::placeholder{color:var(--text-muted)}.mapa-search-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.mapa-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface-0);border:1px solid var(--border-md);border-radius:var(--r-md);box-shadow:var(--sh-lg);max-height:55dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;z-index:300;animation:mapaFadeDown .15s ease-out}@keyframes mapaFadeDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mapa-suggestion-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;color:var(--text-primary);font-size:.875rem;transition:background var(--fast);border:none;background:transparent;width:100%;text-align:left}.mapa-suggestion-item:hover,.mapa-suggestion-item.highlighted{background:var(--accent-dim);color:var(--accent)}.mapa-suggestion-icon{font-size:1.1rem;flex-shrink:0;width:24px;text-align:center}.mapa-suggestion-name{font-weight:600;flex:1}.mapa-suggestion-cat{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.mapa-controls-hint{position:absolute;bottom:20px;left:16px;background:#ffffffbf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 14px;z-index:200;font-size:.78rem;color:var(--text-muted);line-height:1.7;pointer-events:none}[data-theme=dark] .mapa-controls-hint{background:#0b1120bf}.mapa-controls-hint kbd{display:inline-block;background:var(--surface-2);border:1px solid var(--border-md);border-radius:4px;padding:1px 5px;font-size:.72rem;font-family:var(--font);color:var(--text-primary);margin-right:3px}.mapa-zoom-btns{position:absolute;bottom:20px;right:16px;display:flex;flex-direction:column;gap:3px;z-index:200;transition:bottom .25s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 10px rgba(0,0,0,.18))}.mapa-zoom-btn{width:40px;height:40px;border-radius:11px;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,.09);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,transform .12s ease,box-shadow .15s ease;box-shadow:0 1px 3px #0000001a;flex-shrink:0}[data-theme=dark] .mapa-zoom-btn{background:#161c2deb;border-color:#ffffff14;box-shadow:0 1px 4px #00000059}.mapa-zoom-btn:hover:not(:disabled){background:var(--surface-2);transform:scale(1.08);box-shadow:0 3px 10px #00000026}.mapa-zoom-btn:active:not(:disabled){transform:scale(.95)}.mapa-zoom-sep{height:1px;background:var(--border);margin:3px 4px;opacity:.6}@media(min-width:768px){.mapa-zoom-btns{bottom:28px;right:22px;gap:4px}.mapa-zoom-btn{width:42px;height:42px}}.mapa-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:var(--surface-0);z-index:100;transition:opacity .5s ease,visibility .5s ease}.mapa-loading.hidden{opacity:0;visibility:hidden;pointer-events:none}.mapa-loading-spinner{width:56px;height:56px;border-radius:50%;border:4px solid var(--border);border-top-color:var(--accent);animation:mapaSpinner .8s linear infinite}@keyframes mapaSpinner{to{transform:rotate(360deg)}}.mapa-loading-title{font-family:var(--font-disp);font-size:1.125rem;font-weight:700;color:var(--text-primary)}.mapa-loading-sub{font-size:.875rem;color:var(--text-muted);margin-top:-12px}.mapa-progress-bar-wrap{width:200px;height:4px;background:var(--surface-3);border-radius:var(--r-full);overflow:hidden}.mapa-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--blue-400));border-radius:var(--r-full);transition:width .3s ease}.mapa-label{background:#ffffffeb;border:1px solid rgba(37,99,235,.18);border-radius:20px;padding:4px 10px;font-family:var(--font);font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;box-shadow:0 2px 8px #0000001f;transition:opacity .2s;pointer-events:none;-webkit-user-select:none;user-select:none;will-change:transform}.mapa-v2-marker{pointer-events:auto;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.mapa-v2-marker:hover{transform:scale(1.08);box-shadow:0 4px 14px #0003;z-index:1}.mapa-v2-marker--selected{background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important;box-shadow:0 0 0 3px #6366f159,0 4px 14px #00000038!important;transform:scale(1.1);z-index:2}[data-theme=dark] .mapa-label{background:#101828e0;border-color:#60a5fa33;color:#e8f0fe}.mapa-error{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:var(--surface-0);z-index:150;padding:24px;text-align:center}.mapa-error-icon{font-size:3rem}.mapa-error-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.mapa-error-msg{font-size:.9rem;color:var(--text-muted);max-width:400px}@media(max-width:480px){.mapa-title{display:none}.mapa-search-wrap{max-width:100%}.mapa-controls-hint{display:none}}.mapboxgl-ctrl-attrib.mapboxgl-compact{min-height:unset!important;padding:2px 4px!important;border-radius:6px!important;opacity:.55;transition:opacity .2s ease}.mapboxgl-ctrl-attrib.mapboxgl-compact:hover{opacity:1}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner{font-size:.6rem!important}.mapboxgl-ctrl-attrib-button{width:18px!important;height:18px!important}.me-page{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--surface-0);overflow:hidden;font-family:var(--font)}.me-topbar{height:52px;flex-shrink:0;display:flex;align-items:center;gap:12px;padding:0 16px;background:var(--surface-0);border-bottom:1px solid var(--border);z-index:50}.me-back-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer;transition:background var(--fast);flex-shrink:0}.me-back-btn:hover{background:var(--surface-2)}.me-topbar-title{font-weight:700;font-size:.95rem;color:var(--text-primary);font-family:var(--font-disp);display:flex;align-items:center;gap:8px}.me-topbar-badge{font-size:.7rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:2px 8px;border-radius:var(--r-full);letter-spacing:.04em;text-transform:uppercase}.me-topbar-spacer{flex:1}.me-mode-btn{display:flex;align-items:center;gap:6px;height:34px;padding:0 14px;border-radius:var(--r-full);font-size:.82rem;font-weight:700;cursor:pointer;border:1.5px solid var(--border-md);background:var(--surface-1);color:var(--text-secondary);transition:all var(--fast)}.me-mode-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.me-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.me-mode-btn.active:hover{background:var(--blue-600);color:#fff}.me-body{flex:1;display:flex;overflow:hidden;min-height:0}.me-canvas-wrap{flex:1;position:relative;overflow:hidden;min-width:0}.me-canvas-root{position:absolute;inset:0}.me-canvas-root>div{pointer-events:none}.me-canvas-wrap.add-mode .me-canvas-root canvas{cursor:crosshair}.me-canvas-toast{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#000000b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:.82rem;font-weight:600;padding:7px 16px;border-radius:var(--r-full);white-space:nowrap;pointer-events:none;animation:meToastIn .25s ease-out;z-index:20}@keyframes meToastIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.me-canvas-loading{position:absolute;inset:0;background:var(--surface-0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:30;transition:opacity .5s,visibility .5s}.me-canvas-loading.hidden{opacity:0;visibility:hidden;pointer-events:none}.me-canvas-spinner{width:44px;height:44px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:meSpin .8s linear infinite}@keyframes meSpin{to{transform:rotate(360deg)}}.me-canvas-loading-text{font-size:.9rem;color:var(--text-muted);font-weight:600}.me-temp-marker{background:#6366f1e6;color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--r-full);white-space:nowrap;pointer-events:none;animation:maPulse 1.2s ease-in-out infinite}@keyframes maPulse{0%,to{box-shadow:0 0 #6366f180}50%{box-shadow:0 0 0 8px #6366f100}}.me-label{display:inline-flex;position:absolute;align-items:center;background:#ffffffe0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(37,99,235,.18);border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;box-shadow:0 2px 8px #0000001f;will-change:transform;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s,box-shadow .15s}.me-label:hover{background:#fff;box-shadow:0 4px 14px #2563eb2e}.me-label.selected{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 14px var(--accent-glow)}[data-theme=dark] .me-label{background:#101828e0;border-color:#60a5fa33;color:#e8f0fe}[data-theme=dark] .me-label:hover{background:#1e2d42f2}.me-panel{width:340px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface-0);overflow:hidden}.me-panel-header{padding:16px 20px 0;flex-shrink:0}.me-panel-title{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.me-form{margin:0 20px;padding:16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;gap:10px;animation:meSlideIn .2s ease-out}@keyframes meSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.me-form-title{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:2px}.me-form-row{display:flex;gap:8px}.me-form-emoji-btn{width:42px;height:42px;border-radius:var(--r-md);border:1px solid var(--border-md);background:var(--surface-0);font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color var(--fast)}.me-form-emoji-btn:hover{border-color:var(--accent)}.me-input{flex:1;height:42px;padding:0 12px;border-radius:var(--r-md);border:1px solid var(--border-md);background:var(--surface-0);color:var(--text-primary);font-family:var(--font);font-size:.875rem;outline:none;transition:border-color var(--fast),box-shadow var(--fast)}.me-input::placeholder{color:var(--text-muted)}.me-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.me-select{height:38px;padding:0 10px;border-radius:var(--r-md);border:1px solid var(--border-md);background:var(--surface-0);color:var(--text-primary);font-family:var(--font);font-size:.82rem;outline:none;cursor:pointer;width:100%}.me-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.me-form-coords{font-size:.72rem;color:var(--text-muted);font-family:Courier New,monospace;background:var(--surface-2);padding:6px 10px;border-radius:var(--r-sm);border:1px solid var(--border)}.me-form-actions{display:flex;gap:8px}.me-btn-confirm{flex:1;height:36px;border-radius:var(--r-md);border:none;background:var(--accent);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;transition:background var(--fast),transform var(--fast)}.me-btn-confirm:hover{background:var(--blue-600);transform:translateY(-1px)}.me-btn-cancel{height:36px;padding:0 14px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:background var(--fast)}.me-btn-cancel:hover{background:var(--surface-3)}.me-emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;background:var(--surface-0);border:1px solid var(--border-md);border-radius:var(--r-md);padding:8px;margin-top:-4px}.me-emoji-opt{width:34px;height:34px;border-radius:var(--r-sm);border:none;background:transparent;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--fast)}.me-emoji-opt:hover{background:var(--surface-2)}.me-emoji-opt.active{background:var(--accent-dim)}.me-list-wrap{flex:1;overflow-y:auto;padding:0 20px 12px;margin-top:12px}.me-list-wrap::-webkit-scrollbar{width:4px}.me-list-wrap::-webkit-scrollbar-track{background:transparent}.me-list-wrap::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:var(--r-full)}.me-empty-state{text-align:center;padding:32px 16px;color:var(--text-muted)}.me-empty-icon{font-size:2.5rem;margin-bottom:8px}.me-empty-text{font-size:.85rem;line-height:1.5}.me-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:6px;cursor:pointer;transition:all var(--fast);animation:meSlideIn .2s ease-out}.me-list-item:hover{border-color:var(--border-md);background:var(--surface-2)}.me-list-item.selected{border-color:var(--accent);background:var(--accent-dim)}.me-list-emoji{font-size:1.2rem;flex-shrink:0;width:28px;text-align:center}.me-list-info{flex:1;min-width:0}.me-list-name{font-size:.875rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.me-list-cat{font-size:.72rem;color:var(--text-muted);margin-top:2px}.me-list-coords{font-size:.68rem;color:var(--text-muted);font-family:monospace;margin-top:2px}.me-list-actions{display:flex;gap:4px;flex-shrink:0}.me-list-btn{width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-0);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--fast);font-size:.75rem}.me-list-btn:hover{border-color:var(--border-md);color:var(--text-primary)}.me-list-btn.danger:hover{border-color:var(--danger);color:var(--danger);background:#ef444414}.me-panel-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0}.me-count-chip{font-size:.78rem;color:var(--text-muted);font-weight:600;text-align:center}.me-export-btn{width:100%;height:40px;border-radius:var(--r-md);border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:.875rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity var(--fast),transform var(--fast);box-shadow:0 4px 14px #6366f159}.me-export-btn:hover{opacity:.92;transform:translateY(-1px)}.me-export-btn:active{transform:translateY(0)}.me-copy-btn{width:100%;height:36px;border-radius:var(--r-md);border:1.5px solid var(--border-md);background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--fast)}.me-copy-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.me-copy-btn.copied{border-color:var(--success);color:var(--success);background:#10b98114}.me-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:meFadeIn .15s ease-out}@keyframes meFadeIn{0%{opacity:0}to{opacity:1}}.me-modal{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-lg);width:100%;max-width:680px;max-height:80vh;display:flex;flex-direction:column;animation:meModalIn .2s cubic-bezier(.175,.885,.32,1.275)}@keyframes meModalIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.me-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.me-modal-title{font-family:var(--font-disp);font-size:1rem;font-weight:700;color:var(--text-primary)}.me-modal-close{width:28px;height:28px;border-radius:var(--r-md);border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background var(--fast)}.me-modal-close:hover{background:var(--surface-2)}.me-modal-body{flex:1;overflow-y:auto;padding:20px 24px}.me-code-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;font-family:Courier New,monospace;font-size:.78rem;color:var(--text-primary);white-space:pre;overflow-x:auto;line-height:1.7}.me-modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}@media(max-width:900px){.me-body{flex-direction:column}.me-panel{width:100%;height:40%;border-left:none;border-top:1px solid var(--border)}.me-canvas-wrap{flex:1}}@media(max-width:600px){.me-panel{height:45%}.me-form{margin:0 12px}.me-list-wrap{padding:0 12px 12px}.me-panel-footer{padding:10px 12px}}.me2-textarea{width:100%;padding:12px 14px;border-radius:var(--r-lg);border:1.5px solid var(--border-md);background:var(--surface-1);color:var(--text-primary);font-family:var(--font);font-size:.9rem;line-height:1.55;resize:vertical;min-height:76px;outline:none;transition:border-color var(--fast),box-shadow var(--fast);box-sizing:border-box}.me2-textarea::placeholder{color:var(--text-muted)}.me2-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.me2-temp-marker{background:#6366f1eb;color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:var(--r-full);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;box-shadow:0 2px 10px #6366f173;animation:me2Pulse 1.4s ease-in-out infinite}@keyframes me2Pulse{0%,to{box-shadow:0 0 #6366f180}50%{box-shadow:0 0 0 10px #6366f100}}.me2-list-desc{font-size:.72rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;font-style:italic}.me-v2-canvas-root>div{pointer-events:auto}.me-v2-canvas-root{position:absolute;inset:0;width:100%!important;height:100%!important}.me-v2-canvas-root .mapboxgl-map,.me-v2-canvas-root .mapboxgl-canvas-container,.me-v2-canvas-root .mapboxgl-canvas{width:100%!important;height:100%!important}.aulas-import-overlay{padding:18px;align-items:center}.aulas-import-modal{width:min(780px,calc(100vw - 36px));max-width:780px;max-height:calc(100vh - 36px);max-height:min(760px,calc(100dvh - 36px));display:flex;flex-direction:column;overflow:hidden}.aulas-import-modal .me-modal-header{flex-shrink:0}.aulas-import-modal .me-modal-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.aulas-modal-config{display:flex;align-items:flex-end;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;background:var(--surface-1)}.aulas-config-group{display:flex;flex-direction:column;gap:5px;min-width:0}.aulas-config-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}.aulas-category-select{width:auto;min-width:130px}.aulas-search-group{flex:1 1 220px}.aulas-search-wrap{position:relative;min-width:0}.aulas-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;display:flex}.aulas-bulk-actions{display:flex;gap:6px}.aulas-emoji-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:20;min-width:240px}.aulas-modal-body{flex:1 1 auto;overflow-y:auto;padding:16px 24px;min-height:0;overscroll-behavior:contain}.aulas-modal-body::-webkit-scrollbar{width:4px}.aulas-modal-body::-webkit-scrollbar-track{background:transparent}.aulas-modal-body::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:var(--r-full)}.aulas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}.aulas-room-item{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface-0);cursor:pointer;font-size:.8rem;font-weight:600;color:var(--text-secondary);transition:all .12s ease;-webkit-user-select:none;user-select:none;min-width:0}.aulas-room-item:hover:not(.placed){border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-1px)}.aulas-room-item.selected{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.aulas-room-item.placed{opacity:.45;cursor:default;pointer-events:none}.aulas-room-check{width:14px;flex-shrink:0;text-align:center;font-size:.7rem;font-weight:800}.aulas-room-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.aulas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;height:200px;color:var(--text-muted);font-size:.875rem}.aulas-empty{text-align:center;padding:48px 20px;color:var(--text-muted);font-size:.875rem}.aulas-sel-btn{height:36px!important;padding:0 12px!important;font-size:.78rem!important;white-space:nowrap}.aulas-footer-info{display:flex;align-items:center;flex:1 1 auto;flex-wrap:wrap;font-size:.82rem;color:var(--text-secondary);font-weight:600;gap:4px;min-width:0;line-height:1.25}.aulas-badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:22px;padding:0 7px;border-radius:var(--r-full);background:var(--accent);color:#fff;font-size:.75rem;font-weight:800}.aulas-modal-footer{justify-content:space-between;align-items:center;flex-shrink:0;min-width:0}.aulas-footer-muted{color:var(--text-muted)}.aulas-footer-muted--spaced{margin-left:6px}.aulas-footer-actions{display:flex;gap:10px;flex:0 0 auto;min-width:0}.aulas-confirm-btn{width:auto;min-width:150px;height:38px;padding:0 18px;white-space:nowrap}.aulas-confirm-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.aulas-confirm-btn:disabled:hover{transform:none}@media(max-width:560px){.aulas-import-overlay{padding:max(10px,env(safe-area-inset-top)) 10px max(10px,env(safe-area-inset-bottom))}.aulas-import-modal{width:min(100%,calc(100vw - 20px));max-height:calc(100vh - 20px);max-height:calc(100dvh - 20px);border-radius:var(--r-lg)}.aulas-import-modal .me-modal-header{padding:14px 16px 12px}.aulas-modal-config{display:grid;grid-template-columns:104px minmax(0,1fr);gap:10px 12px;padding:12px 16px}.aulas-modal-config>.aulas-config-group:first-child{min-width:0}.aulas-modal-config>.aulas-config-group:first-child .aulas-config-label{white-space:normal;overflow-wrap:anywhere;line-height:1.08}.aulas-category-select{width:100%;min-width:0}.aulas-search-group,.aulas-bulk-group{grid-column:1 / -1}.aulas-bulk-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.aulas-sel-btn{width:100%;min-width:0}.aulas-modal-body{padding:14px 16px}.aulas-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}.aulas-room-item{padding:7px 8px}.aulas-modal-footer{flex-direction:column;align-items:stretch;gap:10px;padding:12px 16px 14px}.aulas-footer-info{justify-content:center;text-align:center}.aulas-footer-actions{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:8px;width:100%}.aulas-footer-actions .me-btn-cancel,.aulas-confirm-btn{width:100%;min-width:0}.aulas-confirm-btn{height:42px;padding:0 10px;white-space:normal;line-height:1.1}}@media(max-width:360px){.aulas-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.aulas-batch-toast{position:absolute;top:12px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;font-size:.85rem;font-weight:700;padding:10px 20px;border-radius:var(--r-full);white-space:nowrap;pointer-events:none;box-shadow:0 4px 20px var(--accent-glow);z-index:50;animation:me2ToastIn .25s ease-out;display:flex;align-items:center;gap:8px}@keyframes me2ToastIn{0%{opacity:0;transform:translate(-50%) translateY(-8px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.aulas-batch-toast-cancel{pointer-events:auto;background:#ffffff40;border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:var(--r-full);padding:2px 10px;font-size:.75rem;font-weight:700;cursor:pointer;transition:background .15s}.aulas-batch-toast-cancel:hover{background:#fff6}.me-import-aulas-btn{width:100%;height:38px;border-radius:var(--r-md);border:1.5px dashed var(--border-md);background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:all var(--fast);margin-bottom:2px}.me-import-aulas-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);border-style:solid}.mapa-v2-btn-3d{font-size:.7rem!important;font-weight:800;letter-spacing:.04em}.mapa-v2-btn-3d.active{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;box-shadow:0 4px 14px var(--accent-glow)!important}.mapa-v2-marker--selected{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;box-shadow:0 4px 14px var(--accent-glow)!important;z-index:10}.mapa-v2-marker{animation:mapaV2MarkerIn .2s ease-out}@keyframes mapaV2MarkerIn{0%{opacity:0;transform:translateY(4px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.me-hud{position:absolute;bottom:36px;left:12px;background:#0b1120d1;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:8px 12px;z-index:100;pointer-events:none;-webkit-user-select:none;user-select:none;min-width:130px}.me-hud-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;line-height:1.9}.me-hud-label{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff6}.me-hud-val{font-size:.78rem;font-weight:600;font-variant-numeric:tabular-nums;color:#e2e8f0}.me-hud-coord{font-size:.72rem;color:#93c5fd}.me-hud-divider{height:1px;background:#ffffff1a;margin:4px 0}.me2-shell{position:fixed;inset:0;overflow:hidden;font-family:var(--font);background:var(--surface-0)}.me2-map-layer{position:absolute;inset:0;z-index:0}.me2-loading{position:absolute;inset:0;background:var(--surface-0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:30;color:var(--text-muted);font-size:.9rem;font-weight:600;transition:opacity .4s,visibility .4s}.me2-loading--hidden{opacity:0;visibility:hidden;pointer-events:none}.me2-spinner{width:40px;height:40px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:me2spin .75s linear infinite}@keyframes me2spin{to{transform:rotate(360deg)}}.me2-canvas-toast{position:absolute;top:72px;left:50%;transform:translate(-50%);background:#000000bf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-size:.82rem;font-weight:600;padding:8px 18px;border-radius:var(--r-full);white-space:nowrap;pointer-events:none;z-index:20;animation:me2toastIn .22s ease-out}@keyframes me2toastIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.me2-canvas-toast--move{background:#10b981d1}.me2-canvas-toast--dragging{background:#3b82f6e0;animation:me2toastIn .18s ease-out}.me-label--dragging{opacity:.85;filter:drop-shadow(0 4px 12px rgba(59,130,246,.5));z-index:999!important}.me-label--official{border-color:#f59e0ba6!important;background:#fffbebeb!important}.me-label--official.selected{background:#f59e0b!important;border-color:#d97706!important;color:#fff!important;box-shadow:0 4px 14px #f59e0b73!important}[data-theme=dark] .me-label--official{border-color:#f59e0b80!important;background:#291b05eb!important;color:#fde68a!important}[data-theme=dark] .me-label--official.selected{background:#b45309!important;border-color:#92400e!important;color:#fff!important}.me-label--multi{animation:me2MultiPulse 1.6s ease-in-out infinite}@keyframes me2MultiPulse{0%,to{box-shadow:0 0 #6366f173}50%{box-shadow:0 0 0 7px #6366f100}}.me2-multiselect-bar{position:absolute;top:72px;left:50%;transform:translate(-50%);background:#6366f1eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;font-size:.82rem;font-weight:600;padding:8px 16px 8px 18px;border-radius:var(--r-full);display:flex;align-items:center;gap:10px;z-index:20;pointer-events:auto;white-space:nowrap;max-width:calc(100vw - 40px);animation:me2toastIn .22s ease-out}.me2-multiselect-hint{opacity:.8;font-weight:500;overflow:hidden;text-overflow:ellipsis}.me2-multiselect-clear{background:#ffffff38;border:none;color:#fff;cursor:pointer;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1;padding:0;flex-shrink:0;transition:background .15s}.me2-multiselect-clear:hover{background:#ffffff61}.me2-drawer-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 4px 5px;margin-bottom:5px;border-bottom:1px solid var(--border)}.me2-drawer-section-title{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted)}.me2-drawer-section-count{font-size:.7rem;font-weight:700;color:var(--text-muted);background:var(--surface-2);padding:1px 8px;border-radius:var(--r-full)}.me2-list-item--official{border-left:3px solid rgba(245,158,11,.6)}.me2-list-item--official.selected{border-left-color:#f59e0b}.me2-topbar{position:absolute;top:12px;left:12px;right:12px;z-index:200;height:48px;display:flex;align-items:center;gap:10px;background:var(--surface-0);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--r-xl);padding:0 8px 0 12px;box-shadow:0 4px 20px #00000024}.me2-topbar-back{width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer;transition:background var(--fast)}.me2-topbar-back:hover{background:var(--surface-2)}.me2-topbar-title{flex:1;display:flex;align-items:center;gap:8px;font-weight:700;font-size:.9rem;color:var(--text-primary);font-family:var(--font-disp);white-space:nowrap;overflow:hidden;min-width:0}.me2-topbar-badge{font-size:.62rem;font-weight:800;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:2px 7px;border-radius:var(--r-full);letter-spacing:.06em;text-transform:uppercase;flex-shrink:0}.me2-topbar-badge--move{background:linear-gradient(135deg,#10b981,#059669)}.me2-topbar-right{display:flex;align-items:center;flex-shrink:0}.me2-fab{position:absolute;bottom:calc(80px + env(safe-area-inset-bottom,0px));right:16px;z-index:150;display:flex;align-items:center;gap:8px;height:52px;padding:0 20px;border-radius:var(--r-full);border:none;background:var(--accent);color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;box-shadow:0 6px 24px var(--accent-glow, rgba(99, 102, 241, .4));transition:transform .2s cubic-bezier(.175,.885,.32,1.275),background var(--fast),box-shadow var(--fast);white-space:nowrap}.me2-fab:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--accent-glow, rgba(99, 102, 241, .5))}.me2-fab:active{transform:translateY(0)}.me2-fab--active{background:var(--surface-2);color:var(--text-secondary);border:1.5px solid var(--border-md);box-shadow:0 4px 12px #0000001f}.me2-fab--active:hover{background:var(--surface-3);color:var(--text-primary)}.me2-sheet-handle-wrap{display:flex;justify-content:center;padding:10px 0 4px;flex-shrink:0;width:100%;border:0;background:transparent;cursor:pointer;touch-action:none}.me2-sheet-handle{width:36px;height:4px;background:var(--border-md);border-radius:var(--r-full);flex-shrink:0;transition:width var(--fast),background var(--fast)}.me2-sheet-handle-wrap:hover .me2-sheet-handle,.me2-drawer-tab:hover .me2-sheet-handle{width:44px;background:var(--border-focus)}.me2-form-sheet{position:absolute;bottom:0;left:0;right:0;z-index:300;background:var(--surface-0);border-top:1px solid var(--border);border-radius:var(--r-xl) var(--r-xl) 0 0;box-shadow:0 -8px 40px #0000002e;transform:translateY(100%);transition:transform .32s cubic-bezier(.32,.72,0,1);max-height:92dvh;display:flex;flex-direction:column;overflow:hidden}.me2-form-sheet--open{transform:translateY(0)}.me2-form-sheet--open.me2-form-sheet--collapsed{transform:translateY(calc(100% - 34px - env(safe-area-inset-bottom,0px)))}.me2-form-sheet--collapsed{box-shadow:0 -4px 18px #00000024}.me2-form-sheet--collapsed .me2-form-inner{pointer-events:none}.me2-form-inner{flex:1;overflow-y:auto;padding:0 18px calc(20px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:14px}.me2-form-inner::-webkit-scrollbar{display:none}.me2-form-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}.me2-form-title{font-size:1.05rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp)}.me2-form-coords{font-size:.68rem;color:var(--text-muted);font-family:monospace;background:var(--surface-2);padding:3px 8px;border-radius:var(--r-sm)}.me2-form-row{display:flex;gap:8px;align-items:center}.me2-emoji-btn{width:56px;height:56px;flex-shrink:0;border-radius:var(--r-lg);border:1.5px solid var(--border-md);background:var(--surface-1);font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1px;transition:border-color var(--fast),background var(--fast)}.me2-emoji-btn:hover{border-color:var(--accent);background:var(--accent-dim)}.me2-emoji-btn svg{opacity:.4}.me2-input{flex:1;height:56px;padding:0 16px;border-radius:var(--r-lg);border:1.5px solid var(--border-md);background:var(--surface-1);color:var(--text-primary);font-family:var(--font);font-size:1rem;outline:none;transition:border-color var(--fast),box-shadow var(--fast)}.me2-input::placeholder{color:var(--text-muted)}.me2-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.me2-emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--r-md);padding:10px;animation:me2slideDown .18s ease-out}@keyframes me2slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.me2-emoji-opt{aspect-ratio:1;border-radius:var(--r-sm);border:none;background:transparent;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--fast);padding:0}.me2-emoji-opt:hover{background:var(--surface-2)}.me2-emoji-opt.active{background:var(--accent-dim)}.me2-field-label{font-size:.7rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:-8px}.me2-cat-scroll{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px;flex-shrink:0}.me2-cat-scroll::-webkit-scrollbar{display:none}.me2-cat-chip{flex-shrink:0;height:38px;padding:0 16px;border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface-1);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--fast)}.me2-cat-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.me2-cat-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px var(--accent-glow, rgba(99, 102, 241, .3))}.me2-form-actions{display:flex;gap:10px;margin-top:6px}.me2-btn-cancel{height:52px;padding:0 20px;border-radius:var(--r-full);border:1.5px solid var(--border-md);background:var(--surface-2);color:var(--text-secondary);font-size:.92rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:background var(--fast)}.me2-btn-cancel:hover{background:var(--surface-3);color:var(--text-primary)}.me2-btn-confirm{flex:1;height:52px;border-radius:var(--r-full);border:none;background:var(--accent);color:#fff;font-size:1rem;font-weight:700;letter-spacing:.01em;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow, rgba(99, 102, 241, .35));transition:background var(--fast),transform var(--fast),box-shadow var(--fast)}.me2-btn-confirm:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow, rgba(99, 102, 241, .45))}.me2-btn-confirm:active{transform:translateY(0)}.me2-btn-confirm:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.me2-drawer{position:absolute;bottom:0;left:0;right:0;z-index:100;background:var(--surface-0);border-top:1px solid var(--border);border-radius:var(--r-xl) var(--r-xl) 0 0;box-shadow:0 -4px 24px #0000001f;display:flex;flex-direction:column;overflow:hidden;transform:translateY(calc(100% - 64px));max-height:82dvh;transition:transform .32s cubic-bezier(.32,.72,0,1),opacity .2s}.me2-drawer--open{transform:translateY(0)}.me2-drawer--hidden{transform:translateY(110%);opacity:0;pointer-events:none;visibility:hidden}.me2-drawer-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px;padding:0 16px 12px;background:transparent;border:none;cursor:pointer;text-align:left;width:100%;touch-action:none}.me2-drawer-tab-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.me2-drawer-count{font-size:.82rem;font-weight:700;color:var(--text-secondary);white-space:nowrap}.me2-drawer-count-muted{color:var(--text-muted);font-weight:600}.me2-save-dot{font-size:.75rem;font-weight:500}.me2-save-dot--saving{color:var(--text-muted)}.me2-save-dot--ok{color:#22c55e}.me2-drawer-tab-actions{display:flex;gap:6px;flex-shrink:0}.me2-pill-btn{display:inline-flex;align-items:center;gap:5px;height:32px;padding:0 12px;border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.76rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all var(--fast)}.me2-pill-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.me2-pill-btn:disabled{opacity:.35;cursor:not-allowed}.me2-pill-btn--accent{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 3px 12px var(--accent-glow, rgba(99, 102, 241, .35))}.me2-pill-btn--accent:hover{background:var(--blue-600, #2563eb);border-color:var(--blue-600, #2563eb);color:#fff}.me2-pill-btn--ok{background:#16a34a;border-color:#16a34a;color:#fff;box-shadow:0 3px 12px #16a34a4d}.me2-drawer-body{flex:1;overflow-y:auto;padding:0 12px 16px;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.me2-drawer-body::-webkit-scrollbar{width:3px}.me2-drawer-body::-webkit-scrollbar-track{background:transparent}.me2-drawer-body::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:var(--r-full)}.me2-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 16px;text-align:center}.me2-empty-icon{font-size:2rem}.me2-empty-text{font-size:.85rem;color:var(--text-muted);line-height:1.5}.me2-list-item{display:flex;align-items:center;gap:10px;padding:13px 12px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:7px;cursor:pointer;transition:all var(--fast);animation:me2slideDown .18s ease-out}.me2-list-item:hover{border-color:var(--border-md);background:var(--surface-2)}.me2-list-item.selected{border-color:var(--accent);background:var(--accent-dim)}.me2-list-emoji{font-size:1.3rem;flex-shrink:0;width:30px;text-align:center}.me2-list-info{flex:1;min-width:0}.me2-list-name{font-size:.875rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.me2-list-meta{font-size:.72rem;color:var(--text-muted);margin-top:2px}.me2-list-desc{font-size:.7rem;color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.me2-list-actions{display:flex;gap:4px;flex-shrink:0}.me2-item-btn{width:36px;height:36px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-0);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--fast)}.me2-item-btn:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-md)}.me2-item-btn--danger:hover{background:#ef444414;color:#ef4444;border-color:#ef4444}.me2-json-row{display:flex;gap:8px;margin-top:8px;padding-top:12px;border-top:1px solid var(--border)}.me2-json-btn{flex:1;height:38px;display:flex;align-items:center;justify-content:center;gap:6px;border-radius:var(--r-md);border:1.5px solid var(--border-md);background:var(--surface-1);color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--fast)}.me2-json-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.me2-json-btn.copied{border-color:#22c55e;color:#22c55e;background:#22c55e14}.me2-loc-btn{position:absolute;bottom:calc(148px + env(safe-area-inset-bottom,0px));right:16px;z-index:150;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border-md);background:var(--surface-0);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px #00000026;transition:background var(--fast),color var(--fast),border-color var(--fast),transform .2s}.me2-loc-btn:hover{background:var(--surface-2);color:var(--text-primary);transform:scale(1.06)}.me2-loc-btn:disabled{cursor:not-allowed}.me2-loc-btn--ok{color:#3b82f6;border-color:#3b82f6;background:#3b82f614}.me2-loc-btn--err{color:#ef4444;border-color:#ef4444;background:#ef444414}.me2-loc-spin{animation:me2spin .9s linear infinite}.me2-loc-dot{width:16px;height:16px;border-radius:50%;background:#3b82f6;border:2.5px solid #fff;box-shadow:0 0 #3b82f680;animation:me2locPulse 2s ease-out infinite;pointer-events:none}@keyframes me2locPulse{0%{box-shadow:0 0 #3b82f680}70%{box-shadow:0 0 0 12px #3b82f600}to{box-shadow:0 0 #3b82f600}}.me2-topbar-save{display:none;font-size:.78rem;font-weight:600;white-space:nowrap;flex-shrink:0;padding:4px 10px;border-radius:var(--r-full)}.me2-desktop-add-btn{display:none!important}.me2-topbar-hamburger{position:relative;width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer;transition:background var(--fast)}.me2-topbar-hamburger:hover{background:var(--surface-2)}.me2-topbar-hamburger--open{background:var(--surface-2);border-color:var(--border-md)}.me2-hamburger-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--accent);color:#fff;font-size:.58rem;font-weight:800;display:flex;align-items:center;justify-content:center;pointer-events:none;line-height:1}.me2-drawer-backdrop{position:absolute;inset:0;z-index:95;background:#00000085;animation:me2fadeIn .2s ease-out}@keyframes me2fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:899px){.me-hud{bottom:auto;top:72px;left:12px}.me2-drawer:not(.me2-drawer--open) .me2-drawer-tab-actions{display:none}.me2-drawer--open .me2-drawer-tab-row{flex-direction:column;align-items:stretch;gap:10px}.me2-drawer--open .me2-drawer-tab-actions{display:flex;gap:8px;width:100%}.me2-drawer--open .me2-pill-btn{flex:1;justify-content:center;height:40px;font-size:.8rem;border-radius:var(--r-md)}.me2-drawer:not(.me2-drawer--open) .me2-drawer-count{font-size:.88rem;font-weight:700;color:var(--text-primary)}.me2-drawer-tab{gap:6px;padding:0 16px 10px}.me2-list-emoji{font-size:1.5rem;width:34px}.me2-input:focus,.me2-textarea:focus{box-shadow:0 0 0 3.5px var(--accent-dim)}}@media(min-width:900px){.me2-topbar-hamburger,.me2-drawer-backdrop{display:none}.me2-topbar{top:0;left:0;right:0;border-radius:0;border-top:none;border-left:none;border-right:none;height:52px;padding:0 16px 0 12px}.me2-topbar-save{display:inline-flex;align-items:center;gap:5px}.me2-topbar-save--idle{display:none}.me2-topbar-save--saving{color:var(--text-muted);background:var(--surface-2)}.me2-topbar-save--saved{color:#16a34a;background:#16a34a14}.me2-topbar-save--error{color:#dc2626;background:#dc262614}.me2-map-layer{right:380px;top:52px}.me2-fab{display:none}.me2-loc-btn{bottom:52px;right:396px}.me2-form-sheet{position:absolute;inset:52px 0 0 auto;width:380px;border-radius:0;border-top:none;border-left:1px solid var(--border);box-shadow:none;transform:none!important;max-height:none;display:none}.me2-form-sheet--open{display:flex}.me2-sheet-handle-wrap{display:none}.me2-form-inner{padding:20px 20px 28px;gap:14px}.me2-input{height:50px}.me2-emoji-btn{width:50px;height:50px}.me2-emoji-grid{grid-template-columns:repeat(8,1fr)}.me2-btn-confirm{height:46px;font-size:.95rem}.me2-btn-cancel{height:46px}.me2-drawer{position:absolute;inset:52px 0 0 auto;width:380px;border-radius:0;border-top:none;border-left:1px solid var(--border);max-height:none;box-shadow:none;transform:none!important;opacity:1!important;pointer-events:auto!important;display:flex;flex-direction:column}.me2-drawer--open{max-height:none}.me2-drawer--hidden{display:none}.me2-drawer-tab{cursor:default;pointer-events:none;padding:16px 20px 14px;gap:10px;background:var(--surface-1);border-bottom:1px solid var(--border);flex-shrink:0}.me2-sheet-handle{display:none}.me2-drawer-tab-row{flex-direction:column;align-items:stretch;gap:10px}.me2-drawer-count{font-size:.92rem;font-weight:800;color:var(--text-primary)}.me2-drawer-tab-actions{pointer-events:auto;display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.me2-desktop-add-btn{display:inline-flex!important;grid-column:1 / -1;height:42px;background:var(--accent);border-color:var(--accent);color:#fff;justify-content:center;font-size:.88rem;font-weight:700;border-radius:var(--r-md);box-shadow:0 3px 14px var(--accent-glow, rgba(99, 102, 241, .35))}.me2-desktop-add-btn:hover{background:#4f46e5;border-color:#4f46e5;color:#fff;transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow, rgba(99, 102, 241, .45))}.me2-desktop-add-btn--active{background:var(--surface-3)!important;border-color:var(--border-md)!important;color:var(--text-secondary)!important;box-shadow:none!important}.me2-desktop-add-btn--active:hover{background:var(--surface-3)!important;color:var(--text-primary)!important;transform:none!important;box-shadow:none!important}.me2-pill-btn{justify-content:center;height:36px}.me2-drawer-body{flex:1;padding:12px 16px 20px}.me2-list-item{padding:11px 12px}.me2-list-name{font-size:.9rem}.me2-list-desc{max-width:200px}}:root{--topbar-h: 56px;--chips-h: 42px;--overlay-top: calc(var(--topbar-h) + var(--chips-h) + 8px);--bottom-safe: 80px}@media(min-width:768px){:root{--topbar-h: 62px;--chips-h: 46px;--overlay-top: calc(var(--topbar-h) + var(--chips-h) + 10px);--bottom-safe: 90px}}.mv2-chips-row{position:absolute;top:var(--topbar-h);left:0;right:0;height:var(--chips-h);z-index:15;display:flex;align-items:center;gap:6px;padding:0 14px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch;background:#ffffffd1;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-bottom:1px solid rgba(0,0,0,.06);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 12px,black calc(100% - 12px),transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 12px,black calc(100% - 12px),transparent 100%);pointer-events:auto}.mv2-chips-row::-webkit-scrollbar{display:none}[data-theme=dark] .mv2-chips-row{background:#0b1120a6;border-bottom-color:#ffffff0f}.mv2-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:99px;border:1px solid var(--border, #e2e8f0);background:var(--surface-0, #fff);color:var(--text-primary);font-size:.75rem;font-weight:600;white-space:nowrap;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;flex-shrink:0;box-shadow:0 1px 4px #00000012;font-family:var(--font);height:30px}.mv2-chip:hover{background:var(--surface-1, #f8fafc);transform:translateY(-1px)}.mv2-chip.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 10px var(--accent-glow, rgba(99,102,241,.35))}.mv2-chip-count{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 4px;border-radius:99px;background:#0000001a;font-size:.65rem;font-weight:800;line-height:1}.mv2-chip.active .mv2-chip-count{background:#ffffff47;color:#fff}[data-theme=dark] .mv2-chip{background:var(--surface-1, rgba(20,30,48,.9));border-color:#6482b438;color:#dce8f8}[data-theme=dark] .mv2-chip.active{background:var(--accent);color:#fff}@media(min-width:768px){.mv2-chip{font-size:.8rem;padding:5px 14px;height:32px}.mv2-chip-count{min-width:18px;height:18px}}.mv2-popup{position:absolute;z-index:30;background:var(--surface-0, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;box-shadow:0 8px 32px #00000029;padding:16px;pointer-events:auto;bottom:calc(var(--bottom-safe) + 12px);left:50%;transform:translate(-50%);width:min(340px,calc(100vw - 28px));animation:popupInMobile .2s cubic-bezier(.34,1.56,.64,1);will-change:transform}@keyframes popupInMobile{0%{opacity:0;transform:translate(-50%) translateY(14px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@media(min-width:768px){.mv2-popup{left:auto;right:76px;bottom:auto;top:var(--overlay-top);transform:none;width:340px;animation:popupInDesktop .2s cubic-bezier(.34,1.56,.64,1)}@keyframes popupInDesktop{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}}.mv2-popup-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.mv2-popup-emoji{font-size:1.6rem;line-height:1;flex-shrink:0;margin-top:2px}.mv2-popup-title-wrap{flex:1;min-width:0}.mv2-popup-name{display:block;font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2;word-break:break-word}.mv2-popup-cat{display:inline-block;margin-top:3px;font-size:.7rem;font-weight:600;color:var(--text-muted);background:var(--surface-2, #f1f5f9);padding:1px 8px;border-radius:99px}.mv2-popup-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--surface-2, #f1f5f9);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.mv2-popup-close:hover{background:var(--surface-3, #e2e8f0)}.mv2-popup-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin:0 0 8px}.mv2-popup-coords{font-size:.68rem;color:var(--text-muted);font-family:Courier New,monospace;margin-bottom:12px;opacity:.75}.mv2-popup-actions{display:flex;gap:8px;align-items:center}.mv2-popup-btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:10px;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;font-family:var(--font);white-space:nowrap}.mv2-popup-btn:hover{transform:translateY(-1px)}.mv2-popup-btn.primary{flex:1;justify-content:center;padding:10px 14px;background:var(--accent);color:#fff;box-shadow:0 2px 10px var(--accent-glow, rgba(99,102,241,.35))}.mv2-popup-btn.primary:hover{background:var(--accent-hover, #4f46e5)}.mv2-popup-btn.icon{width:38px;height:38px;justify-content:center;padding:0;background:var(--surface-2, #f1f5f9);color:var(--text-muted);border-radius:10px;font-size:1rem}.mv2-popup-btn.icon:hover{background:var(--surface-3, #e2e8f0);color:var(--text-primary)}.mv2-popup-btn.fav-active{color:#f59e0b;background:#f59e0b1f}.mv2-compass-btn{display:flex;align-items:center;justify-content:center;transition:opacity .2s}.mv2-compass-btn.north{opacity:.5}.mv2-compass-btn:not(.north){opacity:1}.mv2-current-class-btn{position:absolute;top:var(--overlay-top);left:50%;transform:translate(-50%);z-index:18;display:flex;align-items:center;gap:10px;padding:9px 16px 9px 12px;background:#fffffff5;border:1px solid rgba(34,197,94,.25);border-radius:99px;box-shadow:0 4px 16px #0000001f;cursor:pointer;font-family:var(--font);color:var(--text-primary);white-space:nowrap;pointer-events:auto;transition:transform .15s,box-shadow .15s;animation:classBtn .25s ease-out}@keyframes classBtn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mv2-current-class-btn:hover{transform:translate(-50%) translateY(-2px);box-shadow:0 6px 20px #00000026}.mv2-cc-pulse{display:block;width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0;box-shadow:0 0 #22c55eb3;animation:ccPulse 2s ease-out infinite}@keyframes ccPulse{0%{box-shadow:0 0 #22c55eb3}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}.mv2-cc-label{display:flex;flex-direction:column;gap:1px;line-height:1.15}.mv2-cc-now{font-size:.65rem;font-weight:600;color:#22c55e;text-transform:uppercase;letter-spacing:.04em}.mv2-cc-room{font-size:.88rem;font-weight:800;color:var(--text-primary)}[data-theme=dark] .mv2-current-class-btn{background:#101828eb;border-color:#22c55e4d}.mv2-history-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 4px;font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.mv2-history-clear{border:none;background:none;color:var(--accent);font-size:.7rem;font-weight:600;cursor:pointer;padding:2px 4px;font-family:var(--font)}.mv2-history-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 14px;border:none;background:none;text-align:left;cursor:pointer;font-family:var(--font);font-size:.83rem;color:var(--text-primary);transition:background .1s}.mv2-history-item:hover{background:var(--surface-1, #f8fafc)}.mv2-history-icon{color:var(--text-muted);font-size:.75rem;flex-shrink:0}.mv2-route-panel{position:absolute;bottom:var(--bottom-safe);left:50%;transform:translate(-50%);z-index:20;background:var(--surface-0, #fff);border:1px solid var(--border, #e2e8f0);border-radius:14px;box-shadow:0 4px 20px #00000024;padding:12px 48px 12px 16px;min-width:260px;max-width:calc(100vw - 40px);display:flex;flex-direction:column;gap:6px;pointer-events:auto;animation:routePanelIn .22s ease-out}@keyframes routePanelIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mv2-route-dest{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text-primary);font-weight:600;flex-wrap:wrap}.mv2-route-origin{color:#4285f4}.mv2-route-dest-name{color:var(--text-primary);background:#4285f41a;padding:1px 7px;border-radius:99px}.mv2-route-stats{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-muted)}.mv2-route-sep{opacity:.4}.mv2-route-stat{font-weight:500}.mv2-route-close{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:50%;border:none;background:var(--surface-2, #f1f5f9);color:var(--text-muted);font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.mv2-route-close:hover{background:var(--surface-3, #e2e8f0)}.mv2-route-loading-bar{height:2px;border-radius:2px;background:linear-gradient(90deg,#4285f4,#34a853);animation:routeLoadBar 1.2s ease-in-out infinite alternate}@keyframes routeLoadBar{0%{opacity:.4;width:30%}to{opacity:1;width:100%}}.mv2-route-nudge{position:absolute;bottom:var(--bottom-safe);left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:7px;background:var(--surface-0, #fff);border:1px solid var(--border, #e2e8f0);border-radius:99px;padding:9px 18px;font-size:.78rem;color:var(--text-muted);box-shadow:0 2px 12px #0000001a;white-space:nowrap;pointer-events:none;animation:routePanelIn .2s ease-out}.mv2-route-nudge strong{color:var(--text-primary)}.mv2-share-toast{position:absolute;bottom:calc(var(--bottom-safe) + 60px);left:50%;transform:translate(-50%);z-index:350;display:flex;align-items:center;gap:8px;background:#1a2236;color:#fff;border-radius:14px;padding:11px 20px 11px 14px;font-size:.82rem;font-weight:600;white-space:nowrap;pointer-events:none;box-shadow:0 8px 24px #00000047,0 2px 8px #0000002e;border:1px solid rgba(255,255,255,.08);letter-spacing:.01em;animation:toastIn .25s cubic-bezier(.34,1.56,.64,1),toastOut .3s ease-in 2.1s forwards}.mv2-share-toast-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#22c55e;flex-shrink:0}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px) scale(.92)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translate(-50%) translateY(-6px)}}.mv2-loc-dot{width:18px;height:18px;border-radius:50%;background:#4285f4;border:2.5px solid #fff;box-shadow:0 2px 8px #4285f48c;position:relative;z-index:1}.mv2-loc-dot:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.5);width:40px;height:40px;border-radius:50%;background:#4285f438;animation:locPulse 2.2s ease-out 4;pointer-events:none}@keyframes locPulse{0%{transform:translate(-50%,-50%) scale(.4);opacity:1}to{transform:translate(-50%,-50%) scale(1.6);opacity:0}}.mv2-loc-btn{display:flex;align-items:center;justify-content:center;min-width:32px}.mv2-loc-btn.active{color:#4285f4!important;border-color:#4285f4!important;background:#4285f41a!important}.mv2-loc-btn.error{color:#ef4444!important;border-color:#ef4444!important;background:#ef444414!important}.mv2-loc-btn:disabled{opacity:.7;cursor:default}.mv2-loc-spin{display:block;width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:locSpin .75s linear infinite}@keyframes locSpin{to{transform:rotate(360deg)}}.me-label-stack-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:800;margin-left:5px;vertical-align:middle;line-height:1;pointer-events:none}.me-label.selected .me-label-stack-badge{background:#ffffffe6;color:var(--accent)}.mv2-unified-sheet{position:absolute;z-index:30;background:var(--surface-0, #fff);border:1px solid var(--border, #e2e8f0);border-radius:18px;box-shadow:0 8px 32px #00000029;padding:16px;pointer-events:auto;right:76px;top:var(--overlay-top);width:340px;animation:popupInDesktop .22s cubic-bezier(.34,1.56,.64,1)}.mv2-sheet-handle{display:none}.mv2-sheet-poi-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.mv2-sheet-divider{height:1px;background:var(--border, #e2e8f0);margin:10px 0}.mv2-sheet-route-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.mv2-sheet-route-path{display:flex;flex-direction:column;align-items:center;gap:3px;flex-shrink:0;padding:2px 0}.mv2-sheet-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.mv2-sheet-dot--origin{background:#4285f4;box-shadow:0 0 0 2px #4285f440}.mv2-sheet-dot--dest{background:#ea4335;box-shadow:0 0 0 2px #ea433538}.mv2-sheet-line{width:2px;height:18px;background:repeating-linear-gradient(to bottom,#cbd5e1 0px,#cbd5e1 4px,transparent 4px,transparent 8px)}.mv2-sheet-route-labels{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.mv2-sheet-route-from{font-size:.78rem;font-weight:600;color:#4285f4}.mv2-sheet-route-to{font-size:.78rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mv2-sheet-route-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0;font-size:.74rem;color:var(--text-muted);font-weight:600}.mv2-sheet-stat{white-space:nowrap}.mv2-sheet-sep{display:none}@media(max-width:767px){.mapa-zoom-btns{right:12px;bottom:80px;gap:3px}.mapa-zoom-btn{width:32px;height:32px;font-size:1rem}.mapa-center-btn{font-size:.68rem}.mapa-page:has(.mv2-popup) .mapa-zoom-btns{bottom:250px}.mapa-page:has(.mv2-route-panel) .mapa-zoom-btns{bottom:176px}.mv2-popup{bottom:0!important;left:0!important;right:0!important;transform:none!important;width:100%!important;border-radius:20px 20px 0 0;padding:0 16px calc(20px + env(safe-area-inset-bottom,0px));box-shadow:0 -4px 28px #00000026;animation:mobileSheetIn .28s cubic-bezier(.32,.72,0,1);z-index:260}@keyframes mobileSheetIn{0%{transform:translateY(100%);opacity:.8}to{transform:translateY(0);opacity:1}}.mv2-popup:before{content:"";display:block;width:40px;height:4px;background:var(--border-md, #cbd5e1);border-radius:2px;margin:12px auto 10px}.mv2-popup-coords{display:none}.mv2-popup-desc{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;font-size:.78rem;margin-bottom:6px}.mv2-popup-btn.primary{padding:9px 12px;font-size:.78rem}.mv2-popup-btn.icon{width:34px;height:34px}.mv2-route-panel{bottom:0;left:0;right:0;transform:none;max-width:100%;border-radius:20px 20px 0 0;padding:0 16px calc(16px + env(safe-area-inset-bottom,0px));box-shadow:0 -4px 20px #0000001f;z-index:260}.mv2-route-panel:before{content:"";display:block;width:40px;height:4px;background:var(--border-md, #cbd5e1);border-radius:2px;margin:12px auto 10px}.mv2-route-panel{padding-top:0}.mv2-route-nudge{bottom:80px;font-size:.72rem;padding:7px 14px;max-width:calc(100vw - 68px);left:16px;transform:none;white-space:normal;text-align:left}.mv2-share-toast{bottom:210px}.mv2-current-class-btn{padding:7px 12px 7px 10px;gap:8px}.mv2-cc-room{font-size:.82rem}.mv2-cc-now{font-size:.62rem}.mv2-chips-row{background:var(--surface-0, #fff);border-bottom:1px solid var(--border, #e2e8f0);-webkit-backdrop-filter:none;backdrop-filter:none}[data-theme=dark] .mv2-chips-row{background:var(--surface-1, #0d1729)}.mv2-unified-sheet{position:fixed;inset:auto 0 0;width:100%;border-radius:20px 20px 0 0;padding:0 16px calc(20px + env(safe-area-inset-bottom,0px));box-shadow:0 -4px 28px #00000029;animation:mobileSheetIn .28s cubic-bezier(.32,.72,0,1);z-index:260}.mapa-page:has(.mv2-unified-sheet) .mapa-zoom-btns{bottom:280px}.mv2-sheet-handle{display:block;width:40px;height:4px;background:var(--border-md, #cbd5e1);border-radius:2px;margin:12px auto 14px}.mv2-sheet-poi-row{margin-bottom:8px}.mv2-sheet-route-row{background:var(--surface-1, #f8fafc);border-radius:12px;padding:10px 12px;margin-bottom:10px;gap:8px}[data-theme=dark] .mv2-sheet-route-row{background:#ffffff0f}.mv2-sheet-route-stats{flex-direction:row;align-items:center;gap:6px}.mv2-sheet-sep{display:inline;color:var(--border-md)}.mv2-unified-sheet .mv2-popup-btn.primary{padding:10px 14px}.mv2-unified-sheet .mv2-popup-btn.icon{width:40px;height:40px}}.unete-page{height:100%;overflow-y:auto;overflow-x:hidden;background:var(--surface-0);position:relative;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.unete-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.unete-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.22;animation:unete-float 9s ease-in-out infinite}[data-theme=dark] .unete-orb{opacity:.15}.unete-orb-1{width:560px;height:560px;background:radial-gradient(circle,#3b82f6,#6366f1);top:-180px;left:-140px;animation-delay:0s}.unete-orb-2{width:360px;height:360px;background:radial-gradient(circle,#06b6d4,#3b82f6);bottom:10%;right:-80px;animation-delay:-3.5s}.unete-orb-3{width:260px;height:260px;background:radial-gradient(circle,#8b5cf6,#6366f1);top:40%;left:60%;animation-delay:-6s}.unete-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;opacity:.5;-webkit-mask-image:radial-gradient(ellipse 80% 50% at 50% 0%,black 30%,transparent 100%);mask-image:radial-gradient(ellipse 80% 50% at 50% 0%,black 30%,transparent 100%)}@keyframes unete-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-22px) scale(1.04)}}.unete-hero{position:relative;z-index:1;display:grid;align-items:center;grid-template-columns:1fr;gap:40px;padding:28px 40px 24px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--accent-dim) 0%,transparent 100%)}.unete-hero-left{min-width:0}.unete-badge{display:inline-flex;align-items:center;gap:7px;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border-md);padding:4px 11px;border-radius:var(--r-full);margin-bottom:10px;white-space:nowrap}.unete-badge-dot{width:6px;height:6px;background:var(--success);border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px #10b98133;animation:unete-pulse 2s ease-in-out infinite}@keyframes unete-pulse{0%,to{box-shadow:0 0 0 3px #10b98133}50%{box-shadow:0 0 0 7px #10b9810f}}.unete-title{font-family:var(--font-disp);font-size:clamp(1.5rem,2.2vw,2rem);font-weight:800;line-height:1.2;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.025em}.unete-title-gradient{background:linear-gradient(130deg,#3b82f6,#6366f1 55%,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.unete-subtitle{font-size:.83rem;line-height:1.6;color:var(--text-secondary);margin:0}.unete-perks{display:grid;grid-template-columns:1fr 1fr;gap:10px;min-width:0}.unete-perk{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);min-width:0;transition:transform var(--fast),border-color var(--fast),box-shadow var(--fast)}.unete-perk:hover{transform:translateY(-2px);border-color:var(--border-md);box-shadow:var(--sh-sm)}.unete-perk-icon{font-size:1.15rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:var(--r-sm);flex-shrink:0}.unete-perk-title{font-size:.8rem;font-weight:600;color:var(--text-primary);margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unete-perk-sub{font-size:.7rem;color:var(--text-muted);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.unete-form-section{position:relative;z-index:1;padding:24px 40px 40px}.unete-form-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-lg);overflow:hidden;transition:box-shadow var(--normal),border-color var(--normal)}.unete-form-card:hover{border-color:var(--border-md);box-shadow:var(--sh-lg),var(--sh-glow)}.unete-form-topbar{display:flex;align-items:center;gap:10px;padding:13px 20px;background:linear-gradient(135deg,var(--accent-dim),transparent);border-bottom:1px solid var(--border)}.unete-form-topbar-icon{color:var(--accent);flex-shrink:0}.unete-form-topbar-title{font-size:.87rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.25}.unete-form-topbar-sub{font-size:.76rem;color:var(--text-muted)}.unete-form-open-link{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;padding:0 13px;border:1px solid var(--border-md);border-radius:var(--r-full);background:var(--surface-1);color:var(--accent);font-size:.78rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:background var(--fast),border-color var(--fast),transform var(--fast),box-shadow var(--fast)}.unete-form-open-link:hover{background:var(--accent-dim);border-color:var(--border-focus);box-shadow:var(--sh-sm);transform:translateY(-1px)}.unete-form-open-link:focus-visible{outline:2px solid var(--border-focus);outline-offset:3px}.unete-form-access{padding:11px 20px;border-bottom:1px solid var(--border);background:var(--surface-0);color:var(--text-secondary);font-size:.78rem;line-height:1.5}.unete-iframe-wrap{background:var(--surface-0)}.unete-iframe{display:block;width:100%;height:100dvh;border:none}[data-theme=dark] .unete-iframe{opacity:.93}@media(max-width:880px){.unete-hero{grid-template-columns:1fr;padding:20px 24px 18px;gap:20px}.unete-perks{grid-template-columns:1fr 1fr}.unete-form-section{padding:16px 24px 28px}.unete-form-topbar{flex-wrap:wrap}}@media(max-width:560px){.unete-hero{padding:16px 18px 14px}.unete-perks{grid-template-columns:1fr;gap:8px}.unete-form-section{padding:12px 16px 24px}.unete-form-topbar-sub{display:none}.unete-form-open-link{width:100%;margin-left:0}.unete-form-access{padding:10px 16px}}.courses-page{display:flex;flex-direction:column;height:100dvh;background:var(--surface-1)}.courses-page__body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px}.courses-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.courses-header__left{display:flex;flex-direction:column;gap:2px}.courses-header__title{font-size:1.4rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0}.courses-header__sub{font-size:.82rem;color:var(--text-muted);margin:0}.courses-header__actions{display:flex;align-items:center;gap:10px}.courses-create-btn{display:flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-full);background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:.84rem;font-weight:700;font-family:var(--font);transition:background var(--fast),transform var(--fast),box-shadow var(--fast);box-shadow:var(--sh-blue)}.courses-create-btn:hover{background:var(--blue-700);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb4d}.courses-role-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--r-full);font-size:.72rem;font-weight:700;letter-spacing:.04em}.courses-role-badge--teacher{background:#7c3aed1f;color:#7c3aed}.courses-role-badge--admin{background:#dc26261a;color:#dc2626}.courses-role-badge--student{background:var(--accent-dim);color:var(--accent)}.courses-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.courses-search{display:flex;align-items:center;gap:9px;padding:0 14px;height:38px;flex:1;min-width:200px;max-width:380px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-full);transition:border-color var(--fast),box-shadow var(--fast)}.courses-search:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.courses-search__input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.84rem;color:var(--text-primary);outline:none}.courses-search__input::placeholder{color:var(--text-muted)}.courses-filter-select{height:38px;padding:0 34px 0 14px;border:1px solid var(--border);border-radius:var(--r-full);background-color:var(--surface-0);color:var(--text-secondary);font-family:var(--font);font-size:.82rem;cursor:pointer;outline:none;transition:border-color var(--fast)}.courses-filter-select:focus{border-color:var(--border-focus)}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.courses-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;text-align:center}.courses-empty__icon{font-size:3rem}.courses-empty__title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.courses-empty__sub{font-size:.82rem;color:var(--text-muted);margin:0}.course-card{display:flex;flex-direction:column;border-radius:var(--r-lg);background:var(--surface-0);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform var(--normal),box-shadow var(--normal),border-color var(--fast);box-shadow:var(--sh-sm)}.course-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--border-md)}.course-card__cover{height:80px;position:relative;flex-shrink:0}.course-card__cover-bg{position:absolute;inset:0}.course-card__status-badge{position:absolute;top:10px;right:10px;padding:3px 9px;border-radius:var(--r-full);font-size:.6rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.course-card__status-badge--active{background:#10b98133;color:#059669;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.course-card__status-badge--draft{background:#f59e0b33;color:#d97706;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.course-card__status-badge--archived{background:#64748b33;color:#64748b;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.course-card__body{padding:16px;flex:1;display:flex;flex-direction:column;gap:8px}.course-card__subject{font-size:.65rem;font-weight:700;color:var(--accent);letter-spacing:.05em;text-transform:uppercase;margin:0}.course-card__title{font-size:.95rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0;line-height:1.3}.course-card__desc{font-size:.75rem;color:var(--text-secondary);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-card__footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}.course-card__teacher{display:flex;align-items:center;gap:7px}.course-card__teacher-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--accent);flex-shrink:0}.course-card__teacher-name{font-size:.72rem;color:var(--text-secondary);font-weight:600}.course-card__meta{display:flex;align-items:center;gap:8px}.course-card__meta-item{display:flex;align-items:center;gap:4px;font-size:.68rem;color:var(--text-muted)}.course-detail{display:flex;flex-direction:column;height:100dvh;background:var(--surface-1)}.course-detail__body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px;max-width:1100px;margin:0 auto;width:100%}.course-detail__back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:6px 0;font-size:.82rem;font-weight:600;color:var(--accent);font-family:var(--font);transition:gap var(--fast)}.course-detail__back:hover{gap:10px}.course-hero{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md)}.course-hero__cover{height:120px;position:relative;display:flex;align-items:flex-end;padding:20px 24px}.course-hero__cover-bg{position:absolute;inset:0}.course-hero__cover-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 60%)}.course-hero__badges{position:relative;display:flex;gap:8px;flex-wrap:wrap}.course-hero__body{background:var(--surface-0);padding:20px 24px;border-top:0}.course-hero__title{font-size:1.5rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0 0 4px}.course-hero__desc{font-size:.85rem;color:var(--text-secondary);margin:0 0 16px;line-height:1.6}.course-hero__meta-row{display:flex;gap:20px;flex-wrap:wrap}.course-hero__meta-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-muted)}.course-hero__meta-item strong{color:var(--text-secondary);font-weight:600}.course-detail__columns{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}.course-sessions{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm)}.course-panel__title{font-size:1rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0 0 16px;display:flex;align-items:center;gap:8px}.course-sessions__list{display:flex;flex-direction:column;gap:10px}.course-sessions__empty{text-align:center;color:var(--text-muted);font-size:.82rem;padding:24px}.session-card{display:flex;align-items:center;gap:14px;padding:14px;border-radius:var(--r-md);background:var(--surface-1);border:1px solid var(--border);transition:border-color var(--fast),box-shadow var(--fast)}.session-card:hover{border-color:var(--border-md);box-shadow:var(--sh-sm)}.session-card__platform{width:42px;height:42px;border-radius:var(--r-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.3rem}.session-card__platform--meet{background:#34a8531f}.session-card__platform--zoom{background:#2d8cff1f}.session-card__platform--teams{background:#6264a71f}.session-card__platform--other{background:var(--surface-3)}.session-card__info{flex:1;min-width:0}.session-card__title{font-size:.84rem;font-weight:700;color:var(--text-primary);margin:0 0 3px}.session-card__schedule{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.session-card__day{font-size:.72rem;font-weight:700;color:var(--accent)}.session-card__time{font-size:.72rem;color:var(--text-muted);display:flex;align-items:center;gap:3px}.session-card__platform-label{font-size:.68rem;color:var(--text-muted)}.session-card__join-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r-full);background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:.75rem;font-weight:700;font-family:var(--font);text-decoration:none;transition:background var(--fast),transform var(--fast)}.session-card__join-btn:hover{background:var(--blue-700);transform:scale(1.03)}.course-tasks{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm)}.course-tasks__list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.course-tasks__empty{text-align:center;color:var(--text-muted);font-size:.82rem;padding:20px}.task-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--r-md);background:var(--surface-1);border:1px solid var(--border);transition:border-color var(--fast),opacity var(--fast)}.task-item--done{opacity:.55}.task-item:hover{border-color:var(--border-md)}.task-item__checkbox{width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:2px;border:2px solid var(--border-md);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--fast),background var(--fast)}.task-item__checkbox:hover{border-color:var(--accent)}.task-item__checkbox--checked{border-color:var(--accent);background:var(--accent)}.task-item__check-icon{color:#fff}.task-item__body{flex:1;min-width:0}.task-item__title{font-size:.84rem;font-weight:700;color:var(--text-primary);margin:0 0 3px}.task-item--done .task-item__title{text-decoration:line-through;color:var(--text-muted)}.task-item__desc{font-size:.74rem;color:var(--text-secondary);margin:0 0 5px;line-height:1.4}.task-item__due{font-size:.68rem;font-weight:600;padding:2px 8px;border-radius:var(--r-full);display:inline-flex;align-items:center;gap:4px}.task-item__due--ok{background:#10b9811a;color:#059669}.task-item__due--soon{background:#f59e0b1f;color:#d97706}.task-item__due--overdue{background:#dc26261a;color:#dc2626}.task-item__delete-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:var(--r-sm);transition:color var(--fast),background var(--fast);flex-shrink:0}.task-item__delete-btn:hover{color:var(--danger);background:#dc262614}.add-task-form{background:var(--surface-1);border:1.5px dashed var(--border-focus);border-radius:var(--r-md);padding:14px;display:flex;flex-direction:column;gap:10px}.add-task-form__label{font-size:.7rem;font-weight:700;color:var(--text-secondary);display:block;margin-bottom:3px}.add-task-form__input{width:100%;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;font-size:.8rem;color:var(--text-primary);font-family:var(--font);outline:none;transition:border-color var(--fast);box-sizing:border-box}.add-task-form__input:focus{border-color:var(--accent)}.add-task-form__actions{display:flex;justify-content:flex-end;gap:8px}.add-task-form__btn{padding:7px 14px;border-radius:var(--r-sm);border:none;cursor:pointer;font-size:.78rem;font-weight:700;font-family:var(--font);transition:background var(--fast)}.add-task-form__btn--cancel{background:transparent;color:var(--text-secondary)}.add-task-form__btn--cancel:hover{background:var(--surface-2)}.add-task-form__btn--submit{background:var(--accent);color:#fff}.add-task-form__btn--submit:hover{background:var(--blue-700)}.add-task-trigger-btn{display:flex;align-items:center;gap:6px;background:var(--accent-dim);border:1px dashed var(--border-focus);border-radius:var(--r-md);padding:9px 14px;width:100%;cursor:pointer;color:var(--accent);font-size:.8rem;font-weight:700;font-family:var(--font);transition:background var(--fast)}.add-task-trigger-btn:hover{background:#2563eb24}.create-course{display:flex;flex-direction:column;height:100dvh;background:var(--surface-1)}.create-course__body{flex:1;overflow-y:auto;padding:24px}.create-course__inner{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.create-course__card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-sm)}.create-course__step-title{font-size:1.1rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0 0 4px}.create-course__step-sub{font-size:.8rem;color:var(--text-muted);margin:0 0 20px}.create-course__field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.create-course__label{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.create-course__input,.create-course__select,.create-course__textarea{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;font-size:.84rem;color:var(--text-primary);font-family:var(--font);outline:none;transition:border-color var(--fast),box-shadow var(--fast)}.create-course__input:focus,.create-course__select:focus,.create-course__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.create-course__textarea{resize:vertical;min-height:90px}.create-course__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.create-course__color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:32px;height:32px;border-radius:var(--r-sm);cursor:pointer;border:2px solid transparent;transition:transform var(--fast),border-color var(--fast)}.color-swatch:hover{transform:scale(1.15)}.color-swatch--active{border-color:var(--text-primary);transform:scale(1.15)}.session-form-item{display:flex;flex-direction:column;gap:10px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-bottom:10px;position:relative}.session-form-item__remove{position:absolute;top:10px;right:10px;background:none;border:none;cursor:pointer;color:var(--text-muted);transition:color var(--fast)}.session-form-item__remove:hover{color:var(--danger)}.session-form-item__grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.create-course__steps{display:flex;align-items:center;gap:0;margin-bottom:8px}.create-course__step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;border:2px solid var(--border-md);background:var(--surface-1);color:var(--text-muted)}.create-course__step-dot--active{background:var(--accent);border-color:var(--accent);color:#fff}.create-course__step-dot--done{background:var(--success);border-color:var(--success);color:#fff}.create-course__step-line{flex:1;height:2px;background:var(--border)}.create-course__step-line--done{background:var(--success)}.create-course__submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--r-full);font-size:.9rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:background var(--fast),transform var(--fast),box-shadow var(--fast);box-shadow:var(--sh-blue);width:100%}.create-course__submit-btn:hover{background:var(--blue-700);transform:translateY(-1px)}.add-session-btn{display:flex;align-items:center;gap:7px;background:var(--accent-dim);border:1px dashed var(--border-focus);border-radius:var(--r-md);padding:10px 14px;width:100%;cursor:pointer;color:var(--accent);font-size:.82rem;font-weight:700;font-family:var(--font);margin-top:4px;transition:background var(--fast)}.add-session-btn:hover{background:#2563eb24}@media(max-width:900px){.course-detail__columns{grid-template-columns:1fr}}@media(max-width:640px){.courses-page__body{padding:16px}.courses-grid,.create-course__row{grid-template-columns:1fr}.session-form-item__grid{grid-template-columns:1fr 1fr}}.admin-console{flex:1;overflow-y:auto;padding:22px 24px 32px;display:flex;flex-direction:column;gap:18px;background:var(--surface-1)}.admin-console>*{flex-shrink:0}.admin-console__section{display:flex;flex-direction:column;gap:16px}.admin-console__header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 22px;box-shadow:var(--sh-sm)}.admin-console__heading{display:flex;flex-direction:column;gap:4px;min-width:0}.admin-console__role-badge{display:inline-flex;align-items:center;gap:6px;width:fit-content;padding:3px 10px;border-radius:var(--r-full);background:#dc26261a;color:#dc2626;font-size:.66rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.admin-console__role-dot{width:6px;height:6px;border-radius:50%;background:#dc2626}.admin-console__title{font-size:1.45rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:2px 0 0;line-height:1.1}.admin-console__sub{font-size:.82rem;color:var(--text-muted);margin:0}.admin-console__actions{display:flex;gap:8px;flex-wrap:wrap}.admin-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:var(--r-md);font-family:var(--font);font-size:.8rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:background var(--fast),border-color var(--fast),color var(--fast),transform var(--fast);white-space:nowrap}.admin-btn:active{transform:translateY(1px)}.admin-btn--primary{background:var(--accent);color:#fff;box-shadow:var(--sh-blue)}.admin-btn--primary:hover{filter:brightness(1.05)}.admin-btn--ghost{background:var(--surface-0);color:var(--text-secondary);border-color:var(--border-md);box-shadow:var(--sh-sm)}.admin-btn--ghost:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-focus)}.admin-console__nav{display:flex;gap:4px;background:var(--surface-2);border:1px solid var(--border-md);border-radius:var(--r-full);padding:5px;width:fit-content;max-width:100%;overflow-x:auto;box-shadow:var(--sh-sm);position:relative;z-index:1}.admin-seg{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:var(--r-full);border:none;cursor:pointer;font-family:var(--font);font-size:.82rem;font-weight:600;color:var(--text-secondary);background:transparent;transition:background var(--fast),color var(--fast);white-space:nowrap}.admin-seg:hover{background:var(--surface-0);color:var(--text-primary)}.admin-seg--active{background:var(--accent);color:#fff;font-weight:700;box-shadow:var(--sh-blue)}.admin-seg__count{font-size:.68rem;font-weight:800;line-height:1;padding:2px 6px;border-radius:var(--r-full);background:var(--surface-3);color:var(--text-muted)}.admin-seg--active .admin-seg__count{background:#ffffff40;color:#fff}.admin-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(184px,1fr));gap:12px}.admin-stat-card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:15px 16px;display:flex;align-items:center;gap:13px;box-shadow:var(--sh-sm);transition:transform var(--fast),box-shadow var(--fast),border-color var(--fast);position:relative;overflow:hidden}.admin-stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--border-md)}.admin-stat-card:before{content:"";position:absolute;top:0;left:0;bottom:0;width:3px}.admin-stat-card--blue:before{background:var(--accent)}.admin-stat-card--purple:before{background:#7c3aed}.admin-stat-card--green:before{background:#10b981}.admin-stat-card--orange:before{background:#f59e0b}.admin-stat-card--red:before{background:#ef4444}.admin-stat-card__icon{width:42px;height:42px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-card__icon--blue{background:var(--accent-dim);color:var(--accent)}.admin-stat-card__icon--purple{background:#7c3aed1f;color:#7c3aed}.admin-stat-card__icon--green{background:#10b9811f;color:#059669}.admin-stat-card__icon--orange{background:#f59e0b1f;color:#d97706}.admin-stat-card__icon--red{background:#ef44441f;color:#dc2626}.admin-stat-card__body{min-width:0}.admin-stat-card__value{font-size:1.7rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);line-height:1}.admin-stat-card__label{font-size:.78rem;color:var(--text-secondary);font-weight:600;margin-top:3px}.admin-stat-card__sub{font-size:.68rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.admin-panel{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--sh-sm)}.admin-panel__title{font-size:.9rem;font-weight:800;color:var(--text-primary);font-family:var(--font-disp);margin:0 0 16px}.admin-panel__empty{font-size:.8rem;color:var(--text-muted);margin:8px 0}.admin-bars{display:flex;flex-direction:column;gap:11px}.admin-bar-row{display:flex;align-items:center;gap:12px}.admin-bar-row__name{font-size:.74rem;font-weight:700;color:var(--text-secondary);width:46px;flex-shrink:0}.admin-bar-row__name--wide{width:64px}.admin-bar-row__track{flex:1;height:8px;background:var(--surface-3);border-radius:var(--r-full);overflow:hidden}.admin-bar-row__fill{height:100%;border-radius:var(--r-full);transition:width .6s cubic-bezier(.34,1.56,.64,1);min-width:4px}.admin-bar-row__count{font-size:.72rem;font-weight:800;color:var(--text-muted);width:28px;text-align:right;flex-shrink:0}.admin-split{margin-top:18px;padding-top:16px;border-top:1px dashed var(--border)}.admin-split__head{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--text-secondary);font-weight:600;margin-bottom:8px}.admin-split__head strong{font-family:var(--font-disp);font-size:.95rem;color:var(--text-primary)}.admin-split__bar{height:9px;background:var(--surface-3);border-radius:var(--r-full);overflow:hidden}.admin-split__seg--active{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:var(--r-full);transition:width .6s cubic-bezier(.34,1.56,.64,1)}.admin-split__legend{display:flex;gap:16px;margin-top:10px}.admin-split__legend span{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;color:var(--text-muted);font-weight:600}.admin-dot{width:8px;height:8px;border-radius:50%}.admin-dot--green{background:#10b981}.admin-dot--grey{background:var(--border-md)}.admin-shortcuts{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.admin-shortcut{display:flex;align-items:center;gap:12px;text-align:left;padding:13px 14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-1);cursor:pointer;transition:border-color var(--fast),box-shadow var(--fast),transform var(--fast)}.admin-shortcut:hover{border-color:var(--border-focus);box-shadow:var(--sh-sm);transform:translateY(-1px)}.admin-shortcut__icon{width:38px;height:38px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-shortcut__icon--blue{background:var(--accent-dim);color:var(--accent)}.admin-shortcut__icon--orange{background:#f59e0b1f;color:#d97706}.admin-shortcut__icon--red{background:#ef44441f;color:#dc2626}.admin-shortcut__icon--purple{background:#7c3aed1f;color:#7c3aed}.admin-shortcut__text{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.admin-shortcut__label{font-size:.82rem;font-weight:700;color:var(--text-primary)}.admin-shortcut__desc{font-size:.7rem;color:var(--text-muted)}.admin-shortcut>svg:last-child{color:var(--text-muted);flex-shrink:0}.admin-shortcut:hover>svg:last-child{color:var(--accent)}.admin-table-wrap{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}.admin-table-toolbar{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);flex-wrap:wrap}.admin-table-search{display:flex;align-items:center;gap:8px;padding:0 12px;height:36px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-full);flex:1;min-width:200px;max-width:340px;color:var(--text-muted);transition:border-color var(--fast)}.admin-table-search:focus-within{border-color:var(--border-focus)}.admin-table-search__input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.82rem;color:var(--text-primary);outline:none}.admin-table-search__input::placeholder{color:var(--text-muted)}.admin-filter{height:36px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface-1);color:var(--text-secondary);font-family:var(--font);font-size:.8rem;cursor:pointer;outline:none}.admin-filter:focus{border-color:var(--border-focus)}.admin-table-count{margin-left:auto;font-size:.75rem;color:var(--text-muted);font-weight:600;white-space:nowrap}.admin-table{width:100%;border-collapse:collapse}.admin-table th{padding:10px 16px;text-align:left;font-size:.64rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-1);border-bottom:1px solid var(--border)}.admin-table td{padding:11px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr{transition:background var(--fast)}.admin-table tbody tr:hover{background:var(--surface-1)}.admin-user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;flex-shrink:0}.admin-user-name-cell{display:flex;align-items:center;gap:10px}.admin-user-name{font-size:.82rem;font-weight:700;color:var(--text-primary)}.admin-user-email{font-size:.68rem;color:var(--text-muted)}.admin-faculty-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-sm);font-size:.68rem;font-weight:700}.admin-faculty-badge--FCyT{background:#2563eb1a;color:#1d4ed8}.admin-faculty-badge--FACH{background:#f59e0b1a;color:#b45309}.admin-faculty-badge--FHum{background:#7c3aed1a;color:#7c3aed}.admin-faculty-badge--FCP{background:#10b9811a;color:#059669}.admin-faculty-badge--FD{background:#ef44441a;color:#dc2626}.admin-faculty-badge--null{background:var(--surface-3);color:var(--text-muted)}.admin-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px}.admin-status-dot--active{background:#10b981}.admin-status-dot--inactive{background:var(--border-md)}.admin-role-select{padding:4px 10px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-1);color:var(--text-primary);font-family:var(--font);font-size:.78rem;cursor:pointer;outline:none;transition:border-color var(--fast)}.admin-role-select:focus{border-color:var(--accent)}.admin-courses-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.admin-courses-head__stats{display:flex;gap:8px;flex-wrap:wrap}.admin-pill{display:inline-flex;align-items:center;padding:4px 11px;border-radius:var(--r-full);font-size:.72rem;font-weight:700}.admin-pill--green{background:#10b9811f;color:#059669}.admin-pill--grey{background:var(--surface-3);color:var(--text-secondary)}.admin-pill--muted{background:var(--surface-2);color:var(--text-muted)}.admin-courses-grid{display:flex;flex-direction:column;gap:10px}.admin-course-row{display:flex;align-items:center;gap:14px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--r-md);padding:13px 16px;transition:border-color var(--fast),box-shadow var(--fast)}.admin-course-row:hover{border-color:var(--border-md);box-shadow:var(--sh-sm)}.admin-course-row__cover{width:44px;height:44px;border-radius:var(--r-sm);flex-shrink:0}.admin-course-row__info{flex:1;min-width:0}.admin-course-row__title{font-size:.88rem;font-weight:700;color:var(--text-primary);margin:0 0 3px}.admin-course-row__meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.admin-course-row__meta-item{font-size:.7rem;color:var(--text-muted)}.admin-course-row__actions{display:flex;gap:6px;flex-shrink:0}.admin-action-btn{padding:6px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:transparent;cursor:pointer;font-size:.72rem;font-weight:700;font-family:var(--font);color:var(--text-secondary);transition:background var(--fast),color var(--fast),border-color var(--fast)}.admin-action-btn:hover{background:var(--surface-2);color:var(--text-primary)}.admin-action-btn--danger{color:var(--danger);border-color:var(--danger)}.admin-action-btn--danger:hover{background:#ef44441a}.admin-empty{display:flex;flex-direction:column;align-items:center;padding:44px 24px;gap:10px;text-align:center}.admin-empty__icon{font-size:2.4rem}.admin-empty__text{font-size:.85rem;color:var(--text-muted);margin:0}@media(max-width:1023px){.admin-overview-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-console{padding:16px}.admin-console__header{align-items:flex-start}.admin-kpi-grid{grid-template-columns:1fr 1fr}.admin-table th:nth-child(3),.admin-table td:nth-child(3),.admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}}@media(max-width:480px){.admin-kpi-grid{grid-template-columns:1fr}.admin-console__nav{width:100%}}.mobile-menu-btn{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all var(--fast)}.mobile-menu-btn:hover{background:var(--accent-dim);border-color:var(--border-md);color:var(--accent)}.mobile-close-btn{display:none}.desktop-uncollapse-btn{display:inline-flex}.main-fab{display:flex;position:fixed;bottom:24px;right:20px;z-index:200;background:var(--accent);color:#fff;border:none;border-radius:var(--r-full);padding:14px 20px;font-size:.85rem;font-weight:700;font-family:var(--font);cursor:pointer;align-items:center;gap:8px;box-shadow:0 4px 20px var(--accent-glow),0 2px 8px #00000026;transition:all var(--fast);letter-spacing:.01em}.main-fab:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow),0 4px 12px #0003}.main-fab:active{transform:scale(.96)}.ai-fab{display:flex;position:fixed;bottom:84px;right:20px;z-index:200;background:var(--surface-0);border:2px solid var(--accent);border-radius:50%;width:48px;height:48px;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow);transition:all var(--fast)}.ai-fab:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.ai-fab:active{transform:scale(.96)}.hide-on-desktop{display:none}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000073;z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn var(--fast) ease}@media(max-width:900px){:root{--sidebar-w: 300px}.grid-body{overflow:visible}}@media(max-width:640px){body{overflow:auto}#root{height:auto;min-height:100dvh}.app-layout{flex-direction:column;height:auto;min-height:100dvh;overflow:visible}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(300px,88vw);height:100dvh;z-index:300;transform:translate(-110%);transition:transform var(--normal) cubic-bezier(.4,0,.2,1);box-shadow:4px 0 32px #0000002e;display:flex}.sidebar.sidebar--open{transform:translate(0)}.sidebar-backdrop{display:block}.mobile-close-btn{display:flex!important;position:fixed;bottom:24px;left:min(300px,88vw);z-index:310;width:44px;height:44px;border-radius:var(--r-full);background:var(--accent);color:#fff;border:none;box-shadow:0 4px 16px #2563eb73;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--fast)}.mobile-close-btn:active{transform:scale(.9)}.mobile-menu-btn{display:flex}.desktop-uncollapse-btn,.sidebar-collapse-btn{display:none!important}.selected-panel,.toast-wrap{display:none}.main-fab.hide-on-desktop{display:flex;bottom:80px!important}.main-fab.hide-on-mobile,.ai-fab.hide-on-mobile,.hide-on-mobile-global,.ai-fab.hide-on-desktop{display:none!important}.main{flex:unset;width:100%;min-height:100dvh;display:flex;flex-direction:column;overflow:visible}.top-bar{position:sticky;top:0;z-index:100;background:var(--surface-0);padding:0 12px;gap:8px}.career-name{font-size:.88rem}.semester-badge{display:none}.stats-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;gap:10px;padding:0 12px;font-size:.7rem}.stat-sep{display:none}.grid-wrap{flex:none;height:auto;overflow:visible}.grid-outer-scroll{overflow-x:auto!important;overflow-y:visible;-webkit-overflow-scrolling:touch;min-height:auto;height:auto;position:relative}.grid-inner{height:auto!important;min-height:var(--grid-inner-h, 600px)}.hour-col{background:var(--surface-1);box-shadow:2px 0 6px #00000014}.grid-body{overflow:visible;height:auto}.list-view{padding:12px}.list-event{padding:8px 10px;gap:8px}.list-event-time{min-width:76px;font-size:.7rem}.list-event-name{font-size:.8rem}.home-view{padding:20px 12px 96px}.home-theme-toggle{top:10px;right:10px}.home-hero{margin-bottom:24px}.home-hero h1,.home-app-title{font-size:1.8rem}.home-app-subtitle{font-size:1rem;margin-bottom:1rem}.home-hero p{font-size:.9rem}.home-hero-actions{gap:8px;margin-top:16px}.home-hero-btn-secondary{font-size:.8rem;padding:7px 13px}.home-install-btn{font-size:.88rem;padding:9px 16px;margin-bottom:16px}.home-logo-img{width:64px;height:64px}.home-careers-grid{grid-template-columns:1fr}.home-semester-group{margin-bottom:20px}.list-view{padding-bottom:88px}.view-toggle{padding:2px}.view-btn{padding:5px 8px;font-size:0}.view-btn svg{display:block}.event-block{border-left-width:5px;border-radius:var(--r-sm)}.empty-state{padding-bottom:96px}.level-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none;gap:3px;padding:6px 10px}.level-tabs::-webkit-scrollbar{display:none}.level-tab{flex-shrink:0;padding:2px 8px;font-size:.7rem}.event-title{font-size:.72rem!important;-webkit-line-clamp:3;line-clamp:3}.event-meta{font-size:.64rem!important}.cgb-item-name{font-size:.68rem!important;-webkit-line-clamp:4;line-clamp:4}.cgb-item-meta{font-size:.6rem!important}.cgb-header{font-size:.6rem!important;padding:3px 5px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}@keyframes animUp{0%{opacity:0;transform:translateY(15px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.anim-up{animation:animUp .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.slide-in-right{animation:slideInRight .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.pop-in{animation:popIn .25s cubic-bezier(.16,1,.3,1) forwards}.event-block{transition:box-shadow .2s cubic-bezier(.16,1,.3,1),filter .2s cubic-bezier(.16,1,.3,1)!important}.event-block:hover{filter:brightness(1.03)}.event-block,.conflict-group-block{animation:popIn .3s cubic-bezier(.16,1,.3,1) forwards}
