@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);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;max-width:1600px;margin:0 auto;width:100%;position:relative;background:var(--surface-0);box-shadow:var(--sh-lg);border-left:1px solid var(--border);border-right:1px solid var(--border)}.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:14px 16px;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{padding:8px 12px;border-bottom:1px solid var(--border);display:flex;gap:4px;flex-wrap:wrap;flex-shrink:0;background:var(--surface-1)}.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;z-index:1100;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}}.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}.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,.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:transform var(--fast),box-shadow var(--fast),z-index 0s;border-left-width:3px;border-left-style:solid;z-index:1}.event-block:hover{transform:scale(1.02) translateZ(0);z-index:10!important}.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;z-index:8}.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:40px 24px;background:var(--surface-0);position:relative}.home-theme-toggle{position:fixed;top:12px;right:12px;color:var(--text-secondary);z-index:100}.home-hero{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}.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}.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-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}.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:column;height:100vh;background:var(--surface-0);overflow:hidden}.aulas-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:32px 20px 40px;gap:24px}.aulas-hero{width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;animation:animUp .35s cubic-bezier(.16,1,.3,1) forwards;z-index:1}.aulas-hero-icon{width:64px;height:64px;border-radius:var(--r-lg);background:var(--accent-dim);border:1px solid var(--border-focus);display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:8px}.aulas-hero h2{font-family:var(--font-disp);font-size:1.6rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin:0}.aulas-hero p{font-size:.9rem;color:var(--text-muted);margin:0 0 12px;max-width:420px}.aulas-search-wrap{position:relative;width:100%}.aulas-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.aulas-search-input{width:100%;padding:14px 14px 14px 44px;border-radius:var(--r-full);border:1.5px solid var(--border-md);background:var(--surface-1);color:var(--text-primary);font-size:1rem;font-family:var(--font);transition:border-color var(--fast),box-shadow var(--fast);box-shadow:var(--sh-sm);box-sizing:border-box}.aulas-search-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.aulas-search-input::placeholder{color:var(--text-muted)}.aulas-show-all-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:var(--r-full);background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:#fff;font-size:.9rem;font-weight:600;border:none;cursor:pointer;box-shadow:var(--sh-blue);transition:filter var(--fast),transform var(--fast);margin-top:4px}.aulas-show-all-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.aulas-show-all-btn:active{transform:scale(.97)}.aulas-rooms-section{width:100%;max-width:860px;animation:animUp .3s cubic-bezier(.16,1,.3,1) forwards}.aulas-rooms-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}.aulas-rooms-title:after{content:"";flex:1;height:1px;background:var(--border)}.aulas-rooms-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start}.aulas-room-chip{padding:6px 14px;border-radius:var(--r-full);background:var(--surface-1);border:1px solid var(--border);font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--fast);font-family:var(--font)}.aulas-room-chip:hover{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent);transform:translateY(-1px)}.aulas-room-chip:active{transform:scale(.96)}.aulas-results{width:100%;background:var(--surface-1);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column;flex:1;min-height:600px;animation:animUp .3s cubic-bezier(.16,1,.3,1) forwards}.aulas-results-header{padding:14px 18px;background:var(--surface-2);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.aulas-results-title{font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}.aulas-results-title-query{color:var(--accent)}.aulas-results-hint{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.aulas-legend-item{display:inline-flex;align-items:center;gap:5px}.aulas-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.aulas-results-body{flex:1;overflow:auto;position:relative}.aulas-empty{padding:56px 24px;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:12px}.aulas-empty svg{opacity:.25;color:var(--accent)}.aulas-empty p{font-size:.9rem;max-width:280px}.aulas-loading{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 24px;color:var(--text-muted);font-size:.9rem}.btn-aulas-hero{background:var(--surface-1);color:var(--text-secondary);border:1px solid var(--border);padding:8px 16px;border-radius:var(--r-full);font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:all var(--fast);letter-spacing:-.01em}.btn-aulas-hero:hover{background:var(--surface-2);border-color:var(--border-focus);color:var(--text-primary)}.btn-aulas-hero:active{transform:scale(.97)}.aulas-topbar-title{font-weight:700;font-size:1rem;color:var(--text-primary);letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.aulas-mode-switch{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full);padding:4px;gap:2px;width:fit-content;box-shadow:var(--sh-sm);animation:animUp .3s cubic-bezier(.16,1,.3,1) forwards}.aulas-mode-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:var(--r-full);border:none;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--fast);white-space:nowrap}.aulas-mode-btn:hover:not(.active){color:var(--text-secondary);background:var(--surface-3)}.aulas-mode-btn.active{background:linear-gradient(135deg,var(--blue-700),var(--blue-500));color:#fff;box-shadow:var(--sh-blue)}.aulas-teacher-chip{display:inline-flex;align-items:center;gap:5px}.aulas-teacher-chip:hover{background:#7c3aed14;border-color:#7c3aed66;color:#7c3aed}.aulas-quickchips-wrap{width:100%;display:flex;align-items:center;gap:10px;margin-top:6px;animation:animUp .3s cubic-bezier(.16,1,.3,1) forwards;overflow-x:clip;overflow-y:visible}.aulas-quickchips-label{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);white-space:nowrap;flex-shrink:0;opacity:.7}.aulas-quickchips-scroll{display:flex;gap:6px;overflow-x:auto;overflow-y:visible;padding-top:4px;padding-bottom:6px;scrollbar-width:none;-ms-overflow-style:none;flex:1;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-mask-image:linear-gradient(to right,transparent 0px,black 6px,black calc(100% - 24px),transparent 100%);mask-image:linear-gradient(to right,transparent 0px,black 6px,black calc(100% - 24px),transparent 100%)}.aulas-quickchips-scroll::-webkit-scrollbar{display:none}.aulas-quickchip{flex-shrink:0;padding:5px 12px;border-radius:var(--r-full);background:var(--surface-2);border:1px solid var(--border);font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--fast);font-family:var(--font);white-space:nowrap}.aulas-quickchip:hover{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent);transform:translateY(-1px)}.aulas-quickchip:active{transform:scale(.95)}.aulas-quickchip.active{background:linear-gradient(135deg,var(--blue-700),var(--blue-500));border-color:var(--blue-500);color:#fff;box-shadow:var(--sh-blue)}.aulas-quickchips-teachers .aulas-quickchips-label{color:#7c3aedb3}.aulas-quickchip-teacher:hover{background:#7c3aed14;border-color:#7c3aed66;color:#7c3aed}.aulas-quickchip-teacher.active{background:linear-gradient(135deg,#5b21b6,#7c3aed);border-color:#7c3aed;color:#fff;box-shadow:0 2px 12px #7c3aed59}.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:.5rem;min-height:36px}.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:.5rem}.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}.bib-promo-card:hover{transform:translateY(-4px);box-shadow:0 10px 36px #0000002e}.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-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))}@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}}@media(max-width:420px){.bib-hero-title{font-size:1.5rem}.bib-hero-icon-wrap{font-size:2.5rem}}.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)}.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-container{display:flex;flex-wrap:wrap;gap:32px;margin-top:24px}.qr-section{flex:1;min-width:300px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px}.qr-textarea{width:100%;min-height:100px;padding:16px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-0);color:var(--text-primary);font-size:1rem;resize:vertical;margin-bottom:16px;font-family:inherit;box-sizing:border-box}.qr-preview{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px;background:#fff;border-radius:var(--r-md);margin-top:16px}#qr-reader{width:100%;border-radius:var(--r-md);overflow:hidden;border:none!important}#qr-reader-results{margin-top:16px;padding:16px;background:var(--surface-0);border-left:4px solid #b224ef;border-radius:var(--r-md);word-break:break-all}.qr-scan-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}@media(max-width:768px){.qr-scan-layout{grid-template-columns:1fr}}.qr-panel{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:14px}.qr-panel-header{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.95rem;color:var(--text-primary);padding-bottom:12px;border-bottom:1px solid var(--border)}.qr-panel-badge{margin-left:auto;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:var(--r-full);background:linear-gradient(135deg,#b224ef22,#7579ff22);color:#7579ff;border:1px solid #7579ff44}.qr-cam-select-wrap{width:100%}.qr-cam-select{width:100%;padding:10px 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)}.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:.85rem;text-align:center;padding:16px}.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,#7579ff,#b224ef,#7579ff,transparent);box-shadow:0 0 8px #7579ff;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 #7579ff}.qr-viewfinder-corners:before{top:10%;left:10%;border-right:none;border-bottom:none;border-radius:4px 0 0}.qr-viewfinder-corners:after{bottom:10%;right:10%;border-left:none;border-top:none;border-radius:0 0 4px}.qr-cam-controls{display:flex;gap:10px}.qr-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--r-md);padding:10px 14px;font-size:.85rem;color:#ef4444}.qr-result-box{background:#7579ff12;border:1px solid rgba(117,121,255,.3);border-radius:var(--r-md);padding:14px 16px;display:flex;flex-direction:column;gap:8px;animation:fadeIn .3s ease-out}.qr-result-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#7579ff}.qr-result-text{font-size:.9rem;color:var(--text-primary);word-break:break-all;line-height:1.5}.qr-result-text a{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:20px;text-align:center;cursor:pointer;transition:all var(--fast);background:var(--surface-0);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:160px;position:relative;overflow:hidden}.qr-dropzone:hover,.qr-drop-active{border-color:var(--accent);background:var(--accent-dim)}.qr-drop-preview{max-width:100%;max-height:220px;object-fit:contain;border-radius:var(--r-sm)}.qr-loading{flex-direction:row;align-items:center;gap:12px}.qr-spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:#7579ff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.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}}.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;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}@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-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}.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-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-panel{background:var(--surface-0);border:1.5px solid var(--border-md);border-radius:var(--r-md);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:0}.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)}.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}.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}.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}.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}.main-fab.hide-on-mobile,.ai-fab.hide-on-mobile,.hide-on-mobile-global{display:none!important}.ai-fab.hide-on-desktop{display:flex}.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:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s cubic-bezier(.16,1,.3,1)!important}.event-block:hover{transform:translateY(-2px) scale(1.02);z-index:20!important}.event-block,.conflict-group-block{animation:popIn .3s cubic-bezier(.16,1,.3,1) forwards}
