:root{--primary-rgb: 99, 102, 241;--primary-light-rgb: 129, 140, 248;--primary-dark-rgb: 79, 70, 229;--color-primary: rgb(var(--primary-rgb));--color-primary-light: rgb(var(--primary-light-rgb));--color-primary-dark: rgb(var(--primary-dark-rgb));--color-primary-subtle: rgba(var(--primary-rgb), .08);--color-primary-muted: rgba(var(--primary-rgb), .15);--color-accent: #F43F5E;--color-destructive: #EF4444;--color-destructive-dark: #DC2626;--color-destructive-subtle: rgba(239, 68, 68, .08);--color-success: #22C55E;--color-success-subtle: rgba(34, 197, 94, .1);--color-background: #F8FAFC;--color-surface: #FFFFFF;--color-surface-elevated: #F1F5F9;--color-surface-hover: #E2E8F0;--color-text-primary: #0F172A;--color-text-secondary: #64748B;--color-text-tertiary: #94A3B8;--color-text-inverted: #FFFFFF;--color-border: #E2E8F0;--color-border-subtle: #F1F5F9;--color-overlay: rgba(15, 23, 42, .5);--gradient-primary: linear-gradient(135deg, rgb(var(--primary-rgb)), rgb(var(--primary-light-rgb)));--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--space-9: 48px;--space-10: 64px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-card: 0 2px 8px rgba(0, 0, 0, .06), 0 0 1px rgba(0, 0, 0, .08);--shadow-elevated: 0 8px 24px rgba(0, 0, 0, .1), 0 2px 8px rgba(0, 0, 0, .06);--shadow-float: 0 16px 48px rgba(0, 0, 0, .12), 0 4px 12px rgba(0, 0, 0, .08);--shadow-primary: 0 4px 14px rgba(var(--primary-rgb), .35);--shadow-primary-hover: 0 6px 20px rgba(var(--primary-rgb), .45);--shadow-today: 0 2px 6px rgba(var(--primary-rgb), .3);--shadow-glow: 0 0 20px rgba(var(--primary-rgb), .15);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", sans-serif;--font-mono: "SF Mono", "Fira Code", "JetBrains Mono", monospace;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s}[data-theme=light]{--color-background: #F8FAFC;--color-surface: #FFFFFF;--color-surface-elevated: #F1F5F9;--color-surface-hover: #E2E8F0;--color-text-primary: #0F172A;--color-text-secondary: #64748B;--color-text-tertiary: #94A3B8;--color-border: #E2E8F0;--color-border-subtle: #F1F5F9;--shadow-card: 0 2px 8px rgba(0, 0, 0, .06), 0 0 1px rgba(0, 0, 0, .08);--shadow-elevated: 0 8px 24px rgba(0, 0, 0, .1), 0 2px 8px rgba(0, 0, 0, .06)}[data-theme=dark]{--primary-rgb: 129, 140, 248;--primary-light-rgb: 165, 180, 252;--primary-dark-rgb: 99, 102, 241;--color-background: #0F172A;--color-surface: #1E293B;--color-surface-elevated: #334155;--color-surface-hover: #475569;--color-text-primary: #F1F5F9;--color-text-secondary: #94A3B8;--color-text-tertiary: #64748B;--color-border: #334155;--color-border-subtle: #1E293B;--color-destructive-subtle: rgba(239, 68, 68, .15);--color-success-subtle: rgba(34, 197, 94, .15);--color-overlay: rgba(0, 0, 0, .7);--shadow-card: 0 2px 8px rgba(0, 0, 0, .25), 0 0 1px rgba(0, 0, 0, .3);--shadow-elevated: 0 8px 24px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .25);--shadow-float: 0 16px 48px rgba(0, 0, 0, .4), 0 4px 12px rgba(0, 0, 0, .3)}[data-accent=ocean]{--primary-rgb: 10, 132, 255;--primary-light-rgb: 61, 160, 255;--primary-dark-rgb: 0, 102, 204}[data-theme=dark][data-accent=ocean]{--primary-rgb: 61, 160, 255;--primary-light-rgb: 107, 184, 255;--primary-dark-rgb: 10, 132, 255}[data-accent=teal]{--primary-rgb: 90, 200, 250;--primary-light-rgb: 125, 213, 251;--primary-dark-rgb: 46, 170, 229}[data-theme=dark][data-accent=teal]{--primary-rgb: 125, 213, 251;--primary-light-rgb: 160, 224, 252;--primary-dark-rgb: 90, 200, 250}[data-accent=emerald]{--primary-rgb: 48, 209, 88;--primary-light-rgb: 90, 219, 123;--primary-dark-rgb: 36, 168, 68}[data-theme=dark][data-accent=emerald]{--primary-rgb: 90, 219, 123;--primary-light-rgb: 132, 229, 157;--primary-dark-rgb: 48, 209, 88}[data-accent=mint]{--primary-rgb: 0, 199, 190;--primary-light-rgb: 51, 212, 205;--primary-dark-rgb: 0, 158, 151}[data-theme=dark][data-accent=mint]{--primary-rgb: 51, 212, 205;--primary-light-rgb: 102, 225, 220;--primary-dark-rgb: 0, 199, 190}[data-accent=sunset]{--primary-rgb: 255, 159, 10;--primary-light-rgb: 255, 179, 64;--primary-dark-rgb: 204, 127, 8}[data-theme=dark][data-accent=sunset]{--primary-rgb: 255, 179, 64;--primary-light-rgb: 255, 199, 102;--primary-dark-rgb: 255, 159, 10}[data-accent=coral]{--primary-rgb: 255, 107, 107;--primary-light-rgb: 255, 143, 143;--primary-dark-rgb: 229, 69, 69}[data-theme=dark][data-accent=coral]{--primary-rgb: 255, 143, 143;--primary-light-rgb: 255, 179, 179;--primary-dark-rgb: 255, 107, 107}[data-accent=rose]{--primary-rgb: 255, 45, 85;--primary-light-rgb: 255, 92, 122;--primary-dark-rgb: 212, 35, 71}[data-theme=dark][data-accent=rose]{--primary-rgb: 255, 92, 122;--primary-light-rgb: 255, 139, 158;--primary-dark-rgb: 255, 45, 85}[data-accent=berry]{--primary-rgb: 175, 82, 222;--primary-light-rgb: 194, 120, 230;--primary-dark-rgb: 138, 63, 181}[data-theme=dark][data-accent=berry]{--primary-rgb: 194, 120, 230;--primary-light-rgb: 212, 157, 238;--primary-dark-rgb: 175, 82, 222}[data-accent=amber]{--primary-rgb: 255, 149, 0;--primary-light-rgb: 255, 176, 64;--primary-dark-rgb: 204, 119, 0}[data-theme=dark][data-accent=amber]{--primary-rgb: 255, 176, 64;--primary-light-rgb: 255, 203, 128;--primary-dark-rgb: 255, 149, 0}[data-accent=lavender]{--primary-rgb: 189, 180, 254;--primary-light-rgb: 208, 201, 254;--primary-dark-rgb: 155, 142, 252}[data-theme=dark][data-accent=lavender]{--primary-rgb: 208, 201, 254;--primary-light-rgb: 227, 223, 254;--primary-dark-rgb: 189, 180, 254}[data-accent=slate]{--primary-rgb: 142, 142, 147;--primary-light-rgb: 174, 174, 178;--primary-dark-rgb: 99, 99, 102}[data-theme=dark][data-accent=slate]{--primary-rgb: 174, 174, 178;--primary-light-rgb: 200, 200, 204;--primary-dark-rgb: 142, 142, 147}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);background-color:var(--color-background);color:var(--color-text-primary);line-height:1.6;min-height:100dvh}#root{min-height:100dvh;display:flex}a{color:var(--color-primary);text-decoration:none;transition:color var(--duration-fast) ease}a:hover{color:var(--color-primary-dark);text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}.card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-6);transition:box-shadow var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out)}.card:hover{box-shadow:var(--shadow-card)}.card-elevated{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);padding:var(--space-6)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px var(--space-5);border-radius:var(--radius-sm);font-weight:600;font-size:.875rem;letter-spacing:-.01em;transition:background-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),opacity var(--duration-fast) var(--ease-out);line-height:1.4;white-space:nowrap}.btn:hover{text-decoration:none}.btn-primary{background:var(--gradient-primary);color:var(--color-text-inverted);box-shadow:var(--shadow-primary)}.btn-primary:hover{box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-primary)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-destructive{background:var(--color-destructive);color:var(--color-text-inverted)}.btn-destructive:hover{background:var(--color-destructive-dark);transform:translateY(-1px)}.btn-destructive:active{transform:translateY(0)}.btn-outline{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary-subtle)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{color:var(--color-text-primary);background:var(--color-surface-elevated)}.input-field{width:100%;padding:10px var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.9375rem;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle),var(--shadow-glow)}.input-field::placeholder{color:var(--color-text-tertiary)}.label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-1);letter-spacing:.01em}.error-text{color:var(--color-destructive);font-size:.8125rem;font-weight:500;margin-top:var(--space-2)}.success-text{color:var(--color-success);font-size:.8125rem;font-weight:500;margin-top:var(--space-2)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.spinner-dark{border-color:var(--color-primary-subtle);border-top-color:var(--color-primary)}.toggle{position:relative;width:44px;height:24px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-track{position:absolute;inset:0;background:var(--color-border);border-radius:12px;cursor:pointer;transition:background var(--duration-normal) var(--ease-out)}.toggle input:checked+.toggle-track{background:var(--color-primary);box-shadow:0 0 8px var(--color-primary-muted)}.toggle-track:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform var(--duration-normal) var(--ease-spring);box-shadow:0 1px 3px #00000026}.toggle input:checked+.toggle-track:after{transform:translate(20px)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-text-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.select-field{width:100%;padding:10px var(--space-4);background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.9375rem;font-family:inherit;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5l3 3 3-3' stroke='%2394A3B8' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}.select-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle),var(--shadow-glow)}.textarea-field{width:100%;padding:10px var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.9375rem;font-family:inherit;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease;resize:vertical;min-height:80px;line-height:1.6}.textarea-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle),var(--shadow-glow)}.textarea-field::placeholder{color:var(--color-text-tertiary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-sm{padding:6px var(--space-4);font-size:.8125rem;width:fit-content}.event-modal-overlay{position:fixed;inset:0;background:var(--color-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-4);animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.event-modal{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-float);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modal-in .3s var(--ease-out)}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.event-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--color-border)}.event-modal-title{font-size:1.0625rem;font-weight:600;letter-spacing:-.01em}.event-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-tertiary);transition:all var(--duration-fast) var(--ease-out)}.event-modal-close:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.event-modal-body{padding:var(--space-5);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-4)}.event-modal-field{display:flex;flex-direction:column;gap:var(--space-1)}.event-modal-title-input{font-size:1.0625rem;font-weight:500;padding:10px var(--space-4)}.event-modal-row{display:flex;gap:var(--space-3)}.em-toggles-row{display:flex;gap:var(--space-4)}.em-toggle-item{display:flex;align-items:center;justify-content:space-between;flex:1;padding:var(--space-2) 0}.em-toggle-label{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.event-modal-colors{display:flex;gap:var(--space-2)}.event-modal-color-btn{width:30px;height:30px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring),border-color var(--duration-fast) var(--ease-spring);position:relative}.event-modal-color-btn:hover{transform:scale(1.15)}.event-modal-color-btn.selected{border-color:var(--color-text-primary);transform:scale(1.15);box-shadow:0 0 0 2px var(--color-surface),0 0 0 4px var(--color-text-primary)}.em-datetime-row{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.em-datetime-icon{color:var(--color-text-tertiary);flex-shrink:0}.em-pill-wrapper{position:relative}.em-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:var(--color-text-primary);background:var(--color-surface-elevated);border:1px solid var(--color-border-subtle);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.em-pill:hover{background:var(--color-surface-hover, var(--color-surface-elevated));border-color:var(--color-border)}.em-pill.active{background:rgba(var(--primary-rgb),.1);border-color:rgb(var(--primary-rgb));color:rgb(var(--primary-rgb))}.em-pill-dur{font-size:.6875rem;color:var(--color-text-tertiary);font-weight:400}.em-pill.active .em-pill-dur{color:rgb(var(--primary-rgb));opacity:.7}.em-dash{color:var(--color-text-tertiary);font-size:.875rem;flex-shrink:0}.em-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-float);z-index:50;animation:em-drop-in .15s var(--ease-out)}@keyframes em-drop-in{0%{opacity:0;transform:translateY(-4px)}}.em-time-dropdown{max-height:240px;overflow-y:auto;scrollbar-width:thin;width:190px;padding:var(--space-1) 0}.em-date-dropdown{padding:var(--space-2);width:auto}.em-date-input{padding:6px 10px;font-size:.8125rem;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-surface-elevated);color:var(--color-text-primary);outline:none;color-scheme:dark}.em-date-input:focus{border-color:rgb(var(--primary-rgb))}.em-dropdown-item{display:block;width:100%;text-align:left;padding:7px 14px;font-size:.8125rem;font-weight:400;color:var(--color-text-primary);background:transparent;border:none;cursor:pointer;transition:background var(--duration-fast) ease;white-space:nowrap}.em-dropdown-item:hover{background:var(--color-surface-elevated)}.em-dropdown-item.active{background:rgba(var(--primary-rgb),.1);color:rgb(var(--primary-rgb));font-weight:600}.em-dropdown-divider{height:1px;background:var(--color-border-subtle);margin:var(--space-1) 0}.em-category-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.em-category-btn{display:inline-flex;align-items:center;gap:6px;padding:6px var(--space-3);border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-surface-elevated);border:1.5px solid var(--color-border);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.em-category-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.em-category-btn.active{background:var(--gradient-primary);color:var(--color-text-inverted);border-color:transparent;box-shadow:var(--shadow-primary)}.em-category-btn.active .em-category-dot{border:1.5px solid rgba(255,255,255,.5)}.em-category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.event-modal-priorities{display:flex;gap:var(--space-2);flex-wrap:wrap}.event-modal-priority-btn{padding:6px var(--space-3);border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-surface-elevated);border:1.5px solid var(--color-border);transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.event-modal-priority-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.event-modal-priority-btn.active{background:var(--gradient-primary);color:var(--color-text-inverted);border-color:transparent;box-shadow:var(--shadow-primary)}.event-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);gap:var(--space-3)}.event-modal-footer-right{display:flex;gap:var(--space-2);margin-left:auto}.em-day-picker{display:flex;gap:var(--space-2)}.em-day-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.em-day-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.em-day-btn.active{background:var(--gradient-primary);color:var(--color-text-inverted);border-color:transparent;box-shadow:var(--shadow-primary)}.em-repeat-end{display:flex;flex-direction:column;gap:var(--space-2)}.em-repeat-option{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;font-weight:500;color:var(--color-text-primary);cursor:pointer}.em-repeat-option input[type=radio]{accent-color:rgb(var(--primary-rgb));width:16px;height:16px;cursor:pointer}.em-repeat-count-input{width:64px!important;padding:4px 8px!important;font-size:.8125rem!important;text-align:center}.em-repeat-until-input{width:auto!important;padding:4px 8px!important;font-size:.8125rem!important}.em-repeat-preview{font-size:.75rem;color:rgb(var(--primary-rgb));font-weight:500;margin-top:var(--space-1)}@media(max-width:540px){.event-modal{max-width:100%;max-height:100vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.event-modal-overlay{padding:0;align-items:flex-end}.event-modal-row{flex-direction:column}}.guided-tour{position:fixed;inset:0;z-index:10000;pointer-events:none}.guided-tour-overlay{position:fixed;inset:0;background:#000000a6;z-index:10001;pointer-events:auto;transition:clip-path .35s var(--ease-out, cubic-bezier(.16, 1, .3, 1))}.guided-tour-spotlight{position:fixed;z-index:10002;border-radius:var(--radius-md, 12px);box-shadow:0 0 0 3px rgba(var(--primary-rgb, 99, 102, 241),.5),0 0 24px rgba(var(--primary-rgb, 99, 102, 241),.25);pointer-events:none;transition:all .35s var(--ease-out, cubic-bezier(.16, 1, .3, 1))}.guided-tour-tooltip{position:fixed;z-index:10003;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius-lg, 16px);padding:24px;width:340px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-float, 0 16px 48px rgba(0, 0, 0, .12));pointer-events:auto;opacity:0;transform:translateY(8px);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out)}.guided-tour-tooltip.visible{opacity:1;transform:translateY(0)}.guided-tour-tooltip.is-modal{width:420px;text-align:center}.guided-tour-tooltip:before{content:"";position:absolute;width:12px;height:12px;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);transform:rotate(45deg);display:none}.guided-tour-tooltip.arrow-top:before{display:block;top:-7px;left:50%;margin-left:-6px;border-right:none;border-bottom:none}.guided-tour-tooltip.arrow-bottom:before{display:block;bottom:-7px;left:50%;margin-left:-6px;border-left:none;border-top:none}.guided-tour-tooltip.arrow-left:before{display:block;left:-7px;top:50%;margin-top:-6px;border-right:none;border-top:none}.guided-tour-tooltip.arrow-right:before{display:block;right:-7px;top:50%;margin-top:-6px;border-left:none;border-bottom:none}.guided-tour-tooltip.is-modal:before{display:none}.guided-tour-counter{font-size:12px;font-weight:600;color:var(--color-text-tertiary, #94a3b8);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.guided-tour-title{font-size:18px;font-weight:700;color:var(--color-text-primary, #0f172a);margin:0 0 8px;line-height:1.3}.guided-tour-body{font-size:14px;line-height:1.6;color:var(--color-text-secondary, #64748b);margin:0 0 16px}.guided-tour-dots{display:flex;gap:6px;justify-content:center;margin-bottom:16px}.guided-tour-dot{width:7px;height:7px;border-radius:50%;background:var(--color-border, #e2e8f0);transition:all .25s ease}.guided-tour-dot.active{background:var(--color-primary, rgb(99, 102, 241));transform:scale(1.3)}.guided-tour-dot.done{background:var(--color-primary-light, rgb(129, 140, 248))}.guided-tour-actions{display:flex;align-items:center;justify-content:space-between;gap:8px}.guided-tour-actions-right{display:flex;gap:8px}.guided-tour-skip{background:none;border:none;color:var(--color-text-tertiary, #94a3b8);font-size:13px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm, 8px);transition:color .2s ease,background .2s ease}.guided-tour-skip:hover{color:var(--color-text-secondary, #64748b);background:var(--color-surface-elevated, #f1f5f9)}.guided-tour-back{background:var(--color-surface-elevated, #f1f5f9);border:1px solid var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a);font-size:14px;font-weight:500;padding:8px 16px;border-radius:var(--radius-sm, 8px);cursor:pointer;transition:all .2s ease}.guided-tour-back:hover{background:var(--color-surface-hover, #e2e8f0)}.guided-tour-next{background:var(--color-primary, rgb(99, 102, 241));border:none;color:#fff;font-size:14px;font-weight:600;padding:8px 20px;border-radius:var(--radius-sm, 8px);cursor:pointer;box-shadow:var(--shadow-primary, 0 4px 14px rgba(99, 102, 241, .35));transition:all .2s ease}.guided-tour-next:hover{background:var(--color-primary-dark, rgb(79, 70, 229));box-shadow:var(--shadow-primary-hover, 0 6px 20px rgba(99, 102, 241, .45));transform:translateY(-1px)}.guided-tour-next:active{transform:translateY(0)}@media(max-width:768px){.guided-tour-tooltip{width:calc(100vw - 32px)!important;left:16px!important;max-width:none}.guided-tour-tooltip.is-modal{width:calc(100vw - 32px)!important}.guided-tour-dots{gap:4px}.guided-tour-dot{width:6px;height:6px}}.survey-bg{position:fixed;inset:0;z-index:10000;background:linear-gradient(-45deg,#0f0c29,#302b63,#24243e,#0f172a);background-size:400% 400%;animation:gradientShift 28s ease infinite;overflow:hidden;display:flex;align-items:center;justify-content:center}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.survey-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.3;pointer-events:none;will-change:transform}.survey-orb--1{width:300px;height:300px;background:#6366f199;top:-5%;left:-5%;animation:orbDrift1 28s ease-in-out infinite}.survey-orb--2{width:200px;height:200px;background:#8b5cf680;top:60%;right:-3%;animation:orbDrift2 32s ease-in-out infinite}.survey-orb--3{width:250px;height:250px;background:#06b6d466;bottom:-8%;left:30%;animation:orbDrift3 30s ease-in-out infinite}.survey-orb--4{width:150px;height:150px;background:#ec489959;top:20%;right:20%;animation:orbDrift4 25s ease-in-out infinite}.survey-orb--5{width:180px;height:180px;background:#3b82f666;top:40%;left:10%;animation:orbDrift5 33s ease-in-out infinite}.survey-orb--6{width:120px;height:120px;background:#a855f773;bottom:20%;right:10%;animation:orbDrift6 27s ease-in-out infinite}.survey-orb--7{width:220px;height:220px;background:#22d3ee4d;top:10%;left:50%;animation:orbDrift7 35s ease-in-out infinite}@keyframes orbDrift1{0%,to{transform:translateZ(0) scale(1)}33%{transform:translate3d(80px,60px,0) scale(1.1)}66%{transform:translate3d(-40px,90px,0) scale(.95)}}@keyframes orbDrift2{0%,to{transform:translateZ(0) scale(1)}33%{transform:translate3d(-70px,-50px,0) scale(1.05)}66%{transform:translate3d(50px,-80px,0) scale(.9)}}@keyframes orbDrift3{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(60px,-70px,0) scale(1.15)}}@keyframes orbDrift4{0%,to{transform:translateZ(0)}25%{transform:translate3d(-50px,40px,0)}75%{transform:translate3d(40px,-30px,0)}}@keyframes orbDrift5{0%,to{transform:translateZ(0) scale(1)}40%{transform:translate3d(70px,-40px,0) scale(1.1)}80%{transform:translate3d(-30px,50px,0) scale(.95)}}@keyframes orbDrift6{0%,to{transform:translateZ(0)}50%{transform:translate3d(-60px,-50px,0)}}@keyframes orbDrift7{0%,to{transform:translateZ(0) scale(1)}33%{transform:translate3d(-50px,60px,0) scale(.9)}66%{transform:translate3d(40px,-40px,0) scale(1.1)}}.survey-bg.survey-exit .survey-orb{transition:opacity 1s ease,filter 1s ease;filter:blur(80px);opacity:0}.survey-content{position:relative;z-index:1;max-width:900px;width:100%;padding:2rem;text-align:center;color:#fff}.survey-screen{animation:screenEnter .8s cubic-bezier(.16,1,.3,1) forwards}.survey-screen.survey-screen--exiting{animation:screenExit .6s cubic-bezier(.7,0,.84,0) forwards}@keyframes screenEnter{0%{opacity:0;transform:translate(60px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes screenExit{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(-60px) scale(.97)}}.survey-bg{opacity:1;transition:opacity 1s cubic-bezier(.16,1,.3,1)}.survey-bg.survey-exit{opacity:0}.survey-bg.survey-exit .survey-content{animation:surveyExit 1.2s cubic-bezier(.16,1,.3,1) forwards}@keyframes surveyExit{0%{opacity:1;transform:scale(1);filter:brightness(1)}40%{opacity:.7;transform:scale(1.02);filter:brightness(1.15)}to{opacity:0;transform:scale(1.05);filter:brightness(1.3)}}.survey-bg.survey-exit:after{content:"";position:absolute;inset:0;background:#fff0;animation:flashOut 1.2s ease forwards;z-index:10}@keyframes flashOut{0%{background:#fff0}30%{background:#ffffff14}to{background:#fff0}}.survey-title{font-size:3rem;font-weight:800;line-height:1.15;margin-bottom:1rem;background:linear-gradient(135deg,#fff 30%,rgba(var(--primary-light-rgb, 129, 140, 248),1));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:fadeSlideUp .8s ease forwards}.survey-subtitle{font-size:1.25rem;font-weight:400;color:#ffffffa6;margin-bottom:2.5rem;animation:fadeSlideUp .8s .2s ease both}.survey-question{font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:2rem;animation:fadeSlideUp .6s ease forwards}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.survey-word{display:inline-block;opacity:0;animation:fadeSlideUp .85s ease forwards}.survey-cards{display:flex;gap:1.25rem;justify-content:center;margin-bottom:2.5rem;animation:fadeSlideUp .6s .15s ease both}.survey-card{flex:1;max-width:260px;padding:2rem 1.5rem;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;cursor:pointer;transition:all .35s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;text-align:center}.survey-card:before{content:"";position:absolute;inset:0;border-radius:20px;opacity:0;background:linear-gradient(135deg,rgba(var(--primary-rgb, 99, 102, 241),.08),rgba(var(--primary-light-rgb, 129, 140, 248),.04));transition:opacity .35s ease}.survey-card:hover{border-color:rgba(var(--primary-rgb, 99, 102, 241),.5);box-shadow:0 0 30px rgba(var(--primary-rgb, 99, 102, 241),.2);transform:translateY(-4px)}.survey-card:hover:before{opacity:1}.survey-card.selected{border-color:rgb(var(--primary-rgb, 99, 102, 241));box-shadow:0 0 40px rgba(var(--primary-rgb, 99, 102, 241),.3);transform:translateY(-4px)}.survey-card.selected:before{opacity:1}.survey-card__icon{font-size:2.8rem;margin-bottom:.75rem;display:block;transition:transform .3s ease}.survey-card:hover .survey-card__icon{animation:iconBounce .5s ease}@keyframes iconBounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-3px)}}.survey-card__title{font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:.5rem}.survey-card__desc{font-size:.85rem;color:#ffffff8c;line-height:1.5}.survey-card__check{position:absolute;top:12px;right:12px;width:24px;height:24px;border-radius:50%;background:rgb(var(--primary-rgb, 99, 102, 241));display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all .3s cubic-bezier(.16,1,.3,1);color:#fff;font-size:14px}.survey-card.selected .survey-card__check{opacity:1;transform:scale(1)}.survey-prefs{margin-bottom:2.5rem}.survey-pref-group{margin-bottom:2rem;animation:fadeSlideUp .5s ease both}.survey-pref-group:nth-child(2){animation-delay:.15s}.survey-pref-label{font-size:1rem;font-weight:600;color:#fffc;margin-bottom:.75rem}.survey-pills{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.survey-pill{padding:.6rem 1.25rem;border-radius:100px;border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:#ffffffbf;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .35s cubic-bezier(.16,1,.3,1);-webkit-user-select:none;user-select:none}.survey-pill:hover{background:#ffffff1a;border-color:#ffffff40;color:#fff}.survey-pill.selected{background:rgba(var(--primary-rgb, 99, 102, 241),.3);border-color:rgb(var(--primary-rgb, 99, 102, 241));color:#fff}.survey-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 2.5rem;border:none;border-radius:14px;font-size:1.05rem;font-weight:600;cursor:pointer;color:#fff;background:linear-gradient(135deg,rgb(var(--primary-rgb, 99, 102, 241)),rgb(var(--primary-light-rgb, 129, 140, 248)));box-shadow:0 4px 20px rgba(var(--primary-rgb, 99, 102, 241),.35);transition:all .3s cubic-bezier(.16,1,.3,1);animation:fadeSlideUp .5s .3s ease both;position:relative;overflow:hidden}.survey-btn:after{content:"";position:absolute;inset:0;border-radius:14px;background:linear-gradient(135deg,#ffffff26,#fff0);opacity:0;transition:opacity .3s ease}.survey-btn:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 6px 30px rgba(var(--primary-rgb, 99, 102, 241),.5)}.survey-btn:hover:after{opacity:1}.survey-btn:active{transform:translateY(0) scale(.98)}.survey-btn--pulse{animation:fadeSlideUp .8s .3s ease both,btnPulse 2.5s 1s ease-in-out infinite}@keyframes btnPulse{0%,to{box-shadow:0 4px 20px rgba(var(--primary-rgb, 99, 102, 241),.35)}50%{box-shadow:0 4px 30px rgba(var(--primary-rgb, 99, 102, 241),.5)}}.survey-btn--hidden{opacity:0;pointer-events:none;transform:translateY(10px)}.survey-btn--visible{animation:fadeSlideUp .4s ease forwards}@media(max-width:700px){.survey-title{font-size:2rem}.survey-subtitle{font-size:1rem}.survey-question{font-size:1.25rem}.survey-cards{flex-direction:column;align-items:center}.survey-card{max-width:100%;width:100%}.survey-content{padding:1.5rem 1rem}.survey-pills{gap:.5rem}.survey-pill{padding:.5rem 1rem;font-size:.8rem}}.toast-container{position:fixed;top:72px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:380px;pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-3);padding:12px 16px;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-float);pointer-events:auto;cursor:pointer;animation:toast-in .3s var(--ease-out)}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}}.toast-success{border-left:3px solid #22C55E}.toast-error{border-left:3px solid #EF4444}.toast-info{border-left:3px solid rgb(var(--primary-rgb))}.toast-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}.toast-success .toast-icon{background:#22c55e26;color:#22c55e}.toast-error .toast-icon{background:#ef444426;color:#ef4444}.toast-info .toast-icon{background:rgba(var(--primary-rgb),.15);color:rgb(var(--primary-rgb))}.toast-message{flex:1;font-size:.8125rem;font-weight:500;color:var(--color-text-primary);line-height:1.4}.toast-close{flex-shrink:0;width:20px;height:20px;border-radius:var(--radius-xs);border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.toast-close:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}@media(max-width:480px){.toast-container{right:8px;left:8px;max-width:none}}.layout{display:flex;flex-direction:column;width:100%;height:100dvh;overflow:hidden}.layout-body{display:flex;flex:1;min-height:0;overflow:hidden}.layout-topbar{display:flex;align-items:center;justify-content:space-between;height:60px;min-height:60px;padding:0 var(--space-5);background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.layout-topbar-left,.layout-topbar-right{display:flex;align-items:center;gap:var(--space-3)}.layout-topbar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out);flex-shrink:0}.layout-topbar-btn:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.layout-hamburger-btn{width:38px;height:38px}.layout-logo{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.layout-logo-svg{flex-shrink:0}.layout-logo-text{font-size:1.25rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:var(--font-display);letter-spacing:-.03em}.layout-topbar-nav{display:flex;align-items:center;gap:var(--space-2);margin-left:var(--space-4)}.layout-today-btn{padding:6px var(--space-4);font-size:.8125rem;font-weight:600;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);transition:border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out)}.layout-today-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-subtle)}.layout-arrow-btn{width:32px;height:32px}.layout-topbar-date{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;margin-left:var(--space-2);letter-spacing:-.02em}.layout-ai-btn{display:flex;align-items:center;gap:var(--space-2);padding:6px var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--color-primary);background:var(--color-primary-subtle);transition:background-color var(--duration-fast) var(--ease-out)}.layout-ai-btn:hover{background:var(--color-primary-muted)}.layout-signin-btn{padding:6px var(--space-4);font-size:.8125rem}.layout-view-toggle{display:flex;background:var(--color-surface-elevated);border-radius:var(--radius-sm);padding:2px;gap:2px}.layout-view-btn{padding:6px var(--space-4);font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);transition:all var(--duration-fast) var(--ease-out);border-radius:var(--radius-xs)}.layout-view-btn:hover{color:var(--color-text-primary)}.layout-view-btn.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-xs)}.layout-avatar-btn{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);color:var(--color-text-inverted);font-weight:600;font-size:.8125rem;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-xs)}.layout-avatar-btn:hover{box-shadow:var(--shadow-primary-hover);transform:scale(1.05)}.layout-user-menu-wrapper{position:relative}.layout-user-menu-backdrop{position:fixed;inset:0;z-index:40}.layout-user-menu{position:absolute;top:calc(100% + var(--space-2));right:0;width:280px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-float);z-index:50;overflow:hidden;animation:dropdown-in .2s var(--ease-out)}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.layout-user-menu-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4)}.layout-user-menu-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-primary);color:var(--color-text-inverted);font-weight:600;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.layout-user-menu-name{font-weight:600;font-size:.9375rem;color:var(--color-text-primary)}.layout-user-menu-email{font-size:.8125rem;color:var(--color-text-secondary)}.layout-user-menu-divider{height:1px;background:var(--color-border)}.layout-user-menu-item{display:block;width:100%;text-align:left;padding:var(--space-3) var(--space-4);font-size:.875rem;color:var(--color-text-primary);transition:background var(--duration-fast) ease}.layout-user-menu-item:hover{background:var(--color-surface-elevated)}.layout-user-menu-logout{color:var(--color-destructive)}.layout-sidebar{width:260px;min-width:260px;background:var(--color-surface);border-right:1px solid var(--color-border);overflow-y:auto;padding:var(--space-4);transition:width var(--duration-normal) var(--ease-out),min-width var(--duration-normal) var(--ease-out),padding var(--duration-normal) var(--ease-out),opacity var(--duration-normal) var(--ease-out);flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-4)}.layout-sidebar.collapsed{width:0;min-width:0;padding:0;overflow:hidden;border-right:none}.layout-create-event-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:10px var(--space-4);background:var(--gradient-primary);color:var(--color-text-inverted);border-radius:var(--radius-md);font-weight:600;font-size:.875rem;transition:box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-primary);letter-spacing:-.01em}.layout-create-event-btn:hover{box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.layout-create-event-btn:active{transform:translateY(0)}.layout-mini-cal{margin-bottom:0}.layout-mini-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);padding:0 var(--space-1)}.layout-mini-cal-title{font-size:.8125rem;font-weight:600;color:var(--color-text-primary)}.layout-mini-cal-arrows{display:flex;gap:0}.layout-mini-cal-arrows .layout-topbar-btn{width:26px;height:26px}.layout-mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}.layout-mini-cal-day-name{text-align:center;font-size:.625rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;padding:var(--space-1) 0;letter-spacing:.04em}.layout-mini-cal-day{text-align:center;font-size:.75rem;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-primary);transition:background-color var(--duration-fast) var(--ease-out);margin:0 auto;cursor:pointer;font-weight:500}.layout-mini-cal-day:hover{background:var(--color-surface-elevated)}.layout-mini-cal-day.outside{color:var(--color-text-tertiary)}.layout-mini-cal-day.today{background:var(--gradient-primary);color:var(--color-text-inverted);font-weight:600;box-shadow:var(--shadow-today)}.layout-mini-cal-day.today:hover{opacity:.9}.layout-mini-cal-day.selected:not(.today){background:var(--color-primary-subtle);color:var(--color-primary);font-weight:600}.layout-section{padding:0}.layout-section-title{font-size:.6875rem;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2);padding:0 var(--space-1)}.layout-section-divider{height:1px;background:var(--color-border);margin:var(--space-1) 0}.layout-categories{display:flex;flex-direction:column;gap:2px}.layout-category-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-xs);cursor:pointer;transition:background var(--duration-fast) ease}.layout-category-item:hover{background:var(--color-surface-elevated)}.layout-category-dot{width:10px;height:10px;border-radius:var(--radius-xs);flex-shrink:0}.layout-category-name{font-size:.8125rem;color:var(--color-text-primary);font-weight:500}.layout-category-add{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);font-size:.8125rem;color:var(--color-text-tertiary);border-radius:var(--radius-xs);transition:all var(--duration-fast) ease}.layout-category-add:hover{background:var(--color-surface-elevated);color:var(--color-primary)}.layout-category-add-icon{width:10px;text-align:center;font-weight:600}.layout-category-name{cursor:pointer;border-radius:var(--radius-xs);padding:1px 4px;margin:-1px -4px;transition:background var(--duration-fast) ease}.layout-category-name:hover{background:var(--color-surface-elevated)}.layout-cat-edit{display:flex;flex-direction:column;gap:var(--space-2);width:100%;padding:var(--space-2);background:var(--color-surface-elevated);border-radius:var(--radius-sm)}.layout-cat-edit-colors{display:flex;gap:5px;flex-wrap:wrap}.layout-cat-color-btn{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s;padding:0}.layout-cat-color-btn:hover{transform:scale(1.15)}.layout-cat-color-btn.active{border-color:var(--color-text-primary);transform:scale(1.15);box-shadow:0 0 0 2px var(--color-surface)}.layout-cat-edit-input{width:100%;padding:5px 8px;font-size:.8125rem;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-surface);color:var(--color-text-primary);outline:none}.layout-cat-edit-input:focus{border-color:var(--color-primary)}.layout-cat-edit-actions{display:flex;gap:var(--space-2)}.layout-cat-save-btn{flex:1;padding:4px 8px;font-size:.6875rem;font-weight:600;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-xs);cursor:pointer;transition:opacity .15s}.layout-cat-save-btn:hover{opacity:.9}.layout-cat-save-btn:disabled{opacity:.4;cursor:not-allowed}.layout-cat-cancel-btn{flex:1;padding:4px 8px;font-size:.6875rem;font-weight:500;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xs);cursor:pointer;transition:background .15s}.layout-cat-cancel-btn:hover{background:var(--color-surface)}.layout-cat-delete-btn{width:20px;height:20px;border-radius:var(--radius-xs);border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:all .15s;margin-left:auto}.layout-category-item:hover .layout-cat-delete-btn{opacity:1}.layout-cat-delete-btn:hover{background:#ef44441a;color:var(--color-destructive)}.layout-cat-confirm-delete{display:flex;align-items:center;gap:var(--space-2);width:100%}.layout-cat-confirm-text{font-size:.75rem;font-weight:500;color:var(--color-destructive);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-cat-confirm-yes{padding:2px 8px;font-size:.6875rem;font-weight:600;background:var(--color-destructive);color:#fff;border:none;border-radius:var(--radius-xs);cursor:pointer;flex-shrink:0;transition:opacity .15s}.layout-cat-confirm-yes:hover{opacity:.9}.layout-upcoming{display:flex;flex-direction:column;gap:2px}.layout-upcoming-empty{font-size:.8125rem;color:var(--color-text-tertiary);padding:var(--space-2)}.layout-upcoming-item{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-2);border-radius:var(--radius-xs);cursor:pointer;transition:background var(--duration-fast) ease}.layout-upcoming-item:hover{background:var(--color-surface-elevated)}.layout-upcoming-dot{width:8px;height:8px;border-radius:var(--radius-xs);flex-shrink:0;margin-top:5px}.layout-upcoming-info{display:flex;flex-direction:column;min-width:0}.layout-upcoming-title{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-upcoming-date{font-size:.6875rem;color:var(--color-text-tertiary)}.layout-nav{display:flex;flex-direction:column;gap:2px}.layout-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-weight:500;font-size:.8125rem;transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.layout-nav-link:hover{background:var(--color-surface-elevated);color:var(--color-text-primary);text-decoration:none}.layout-nav-link.active{background:var(--color-primary-subtle);color:var(--color-primary);font-weight:600}.layout-nav-link svg{flex-shrink:0}.layout-nav-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--color-primary);color:#fff;font-size:.6875rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.layout-main{flex:1;overflow:auto;display:flex;flex-direction:column;min-height:0;background:var(--color-background)}.layout-overlay{display:none}@media(max-width:768px){.layout-topbar{height:56px;min-height:56px;padding:0 var(--space-3)}.layout-topbar-nav,.layout-topbar-date,.layout-view-toggle,.layout-ai-btn{display:none}.layout-sidebar{position:fixed;left:0;top:56px;bottom:0;z-index:100;transform:translate(-100%);transition:transform var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-float);width:280px;min-width:280px}.layout-sidebar.mobile-open{transform:translate(0)}.layout-sidebar.collapsed{width:280px;min-width:280px;padding:var(--space-4);overflow-y:auto;border-right:1px solid var(--color-border)}.layout-overlay{display:block;position:fixed;inset:56px 0 0;background:var(--color-overlay);z-index:90}.layout-main{padding-top:0}}@media(max-width:480px){.layout-logo-text{display:none}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;width:100%;padding:var(--space-4);background:var(--color-background);position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);top:-200px;right:-100px;pointer-events:none}.auth-page:after{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.08) 0%,transparent 70%);bottom:-150px;left:-100px;pointer-events:none}.auth-card{width:100%;max-width:420px;position:relative;z-index:1;animation:auth-card-in .5s var(--ease-out)}@keyframes auth-card-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:var(--space-7)}.auth-logo{width:60px;height:60px;background:var(--gradient-primary);color:var(--color-text-inverted);border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:1.5rem;font-family:var(--font-display);margin-bottom:var(--space-5);box-shadow:var(--shadow-primary);position:relative}.auth-logo:after{content:"";position:absolute;inset:-3px;border-radius:calc(var(--radius-lg) + 3px);background:var(--gradient-primary);opacity:.2;z-index:-1}.auth-title{font-size:1.625rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em}.auth-subtitle{font-size:.9375rem;color:var(--color-text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.auth-field{display:flex;flex-direction:column}.auth-submit{width:100%;margin-top:var(--space-2);padding:12px var(--space-6);font-size:.9375rem}.auth-footer{text-align:center;margin-top:var(--space-7);font-size:.875rem;color:var(--color-text-secondary)}.auth-footer a{font-weight:600}.pw-strength{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}.pw-meter{display:flex;gap:4px;flex:1}.pw-meter-bar{height:4px;flex:1;border-radius:2px;background:var(--color-border);transition:background .2s}.pw-meter-bar.weak{background:#ef4444}.pw-meter-bar.fair{background:#eab308}.pw-meter-bar.strong{background:#22c55e}.pw-meter-bar.very-strong{background:#06b6d4}.pw-strength-label{font-size:.6875rem;font-weight:600;flex-shrink:0;min-width:70px;text-align:right}.pw-strength-label.weak{color:#ef4444}.pw-strength-label.fair{color:#eab308}.pw-strength-label.strong{color:#22c55e}.pw-strength-label.very-strong{color:#06b6d4}.pw-checks{list-style:none;padding:0;margin:var(--space-3) 0 0;display:flex;flex-direction:column;gap:6px}.pw-check{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--color-text-tertiary);transition:color .15s}.pw-check.met{color:#22c55e}.pw-check-icon{flex-shrink:0;color:var(--color-text-tertiary)}.pw-check-icon.met{color:#22c55e}.pw-mismatch{font-size:.75rem;color:#ef4444;margin-top:var(--space-1)}.cal-month{display:flex;flex-direction:column;height:100%;min-height:0}.cal-month-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.cal-month-header-cell{text-align:center;padding:var(--space-2) 0;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.cal-month-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,1fr);flex:1;min-height:0}.cal-month-cell{border-right:1px solid var(--color-border-subtle);border-bottom:1px solid var(--color-border-subtle);padding:var(--space-1);min-height:0;overflow:hidden;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out);background:var(--color-surface)}.cal-month-cell:hover{background-color:var(--color-surface-elevated)}.cal-month-cell:nth-child(7n){border-right:none}.cal-month-cell.outside{background:var(--color-background)}.cal-month-cell.outside .cal-month-day-num{color:var(--color-text-tertiary)}.cal-month-cell.today{background:var(--color-primary-subtle)}.cal-month-cell.today .cal-month-day-num{background:var(--gradient-primary);color:var(--color-text-inverted);border-radius:var(--radius-sm);width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-weight:600;box-shadow:var(--shadow-today)}.cal-month-day-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:2px}.cal-month-day-num{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);padding-left:2px;line-height:26px}.cal-month-today-label{font-size:.5625rem;font-weight:700;color:var(--color-primary);letter-spacing:.05em;text-transform:uppercase}.cal-month-holiday-label{font-size:.5rem;font-weight:600;color:var(--color-destructive);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.cal-month-events{display:flex;flex-direction:column;gap:1px}.cal-event-pill{display:block;padding:1px 6px;border-radius:var(--radius-xs);font-size:.6875rem;font-weight:500;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;color:var(--color-text-inverted);transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.cal-event-pill:hover{opacity:.85;transform:translate(1px)}.cal-more-link{font-size:.6875rem;color:var(--color-text-secondary);padding:0 4px;cursor:pointer;font-weight:600;transition:color var(--duration-fast) ease}.cal-more-link:hover{color:var(--color-primary)}.cal-week{display:flex;flex-direction:column;height:100%;min-height:0}.cal-week-header{display:grid;grid-template-columns:48px repeat(7,1fr);border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);z-index:5}.cal-week-header-gutter{border-right:1px solid var(--color-border)}.cal-week-header-day{text-align:center;padding:var(--space-2) 0 var(--space-1);border-right:1px solid var(--color-border-subtle);transition:background var(--duration-fast) ease}.cal-week-header-day:last-child{border-right:none}.cal-week-header-day-name{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.cal-week-header-day-num{font-size:1.375rem;font-weight:500;color:var(--color-text-primary);line-height:1.2}.cal-week-header-day.today .cal-week-header-day-num{background:var(--gradient-primary);color:var(--color-text-inverted);border-radius:var(--radius-sm);width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-today)}.cal-week-holiday-label{font-size:.55rem;font-weight:600;color:var(--color-destructive);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.cal-week-header-day.today .cal-week-header-day-name{color:var(--color-primary)}.cal-week-body{flex:1;overflow:hidden;position:relative;padding-top:var(--space-2);padding-bottom:var(--space-4)}.cal-week-scroll{display:grid;grid-template-columns:48px repeat(7,1fr);position:relative;height:100%}.cal-week-times{border-right:1px solid var(--color-border);display:flex;flex-direction:column}.cal-week-time-slot{flex:1;display:flex;align-items:flex-start;justify-content:flex-end;padding-right:var(--space-1);font-size:.625rem;font-weight:500;color:var(--color-text-tertiary);position:relative;top:-5px;min-height:0}.cal-week-col{border-right:1px solid var(--color-border);position:relative;display:flex;flex-direction:column}.cal-week-col:last-child{border-right:none}.cal-week-col.today{background:var(--color-primary-subtle)}.cal-week-hour-slot{flex:1;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--duration-fast) ease;min-height:0}.cal-week-hour-slot:last-child{border-bottom:none}.cal-week-hour-slot:hover{background:var(--color-primary-subtle)}.cal-week-event{position:absolute;left:2px;right:2px;border-radius:var(--radius-xs);padding:3px 6px;font-size:.6875rem;font-weight:500;color:var(--color-text-inverted);overflow:hidden;cursor:pointer;z-index:2;min-height:20px;line-height:1.3;border-left:3px solid;transition:box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-xs)}.cal-week-event:hover{box-shadow:var(--shadow-sm);transform:translate(1px)}.cal-week-event-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-week-event-time{font-size:.625rem;opacity:.9}.cal-week-overlap-badge{position:absolute;left:2px;right:2px;border-radius:var(--radius-xs);border-left:3px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:all .15s;gap:1px}.cal-week-overlap-badge:hover{filter:brightness(1.15);transform:scale(1.02)}.cal-week-overlap-count{font-size:1rem;font-weight:700;line-height:1}.cal-week-overlap-label{font-size:.5625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;opacity:.8}.cal-overlap-popup-backdrop{position:fixed;inset:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center;animation:cal-popup-fade .15s ease}@keyframes cal-popup-fade{0%{opacity:0}}.cal-overlap-popup{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);width:380px;max-width:90vw;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;animation:cal-popup-in .2s var(--ease-out)}@keyframes cal-popup-in{0%{opacity:0;transform:scale(.96) translateY(8px)}}.cal-overlap-popup-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle)}.cal-overlap-popup-title{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.cal-overlap-popup-date{flex:1;font-size:.75rem;color:var(--color-text-tertiary)}.cal-overlap-popup-close{width:28px;height:28px;border-radius:var(--radius-xs);border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.cal-overlap-popup-close:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.cal-overlap-popup-list{overflow-y:auto;padding:var(--space-2) 0}.cal-overlap-popup-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);cursor:pointer;transition:background .15s}.cal-overlap-popup-item:hover{background:var(--color-surface-elevated)}.cal-overlap-popup-bar{width:4px;height:32px;border-radius:2px;flex-shrink:0}.cal-overlap-popup-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cal-overlap-popup-name{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-overlap-popup-time{font-size:.6875rem;color:var(--color-text-tertiary)}.cal-overlap-popup-badge{font-size:.625rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.cal-overlap-popup-badge.priority-critical{background:#ef44441a;color:#ef4444}.cal-overlap-popup-badge.priority-high{background:#f973161a;color:#f97316}.cal-overlap-popup-badge.priority-medium{background:#eab3081a;color:#ca8a04}.cal-overlap-popup-badge.priority-low{background:rgba(var(--primary-rgb),.1);color:rgb(var(--primary-rgb))}.cal-week-now-line{position:absolute;left:0;right:0;height:2px;background:var(--color-destructive);z-index:3;pointer-events:none}.cal-week-now-line:before{content:"";position:absolute;left:-5px;top:-4px;width:10px;height:10px;background:var(--color-destructive);border-radius:50%;box-shadow:0 0 6px #ef444466}.cal-month-cell .cal-add-btn{display:none;position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:var(--radius-xs);background:var(--color-primary);color:var(--color-text-inverted);font-size:14px;line-height:20px;text-align:center;cursor:pointer}.cal-month-cell:hover .cal-add-btn{display:block}@media(max-width:768px){.cal-month-header-cell{font-size:.625rem}.cal-month-day-num{font-size:.75rem}.cal-month-today-label{display:none}.cal-event-pill{font-size:.625rem;padding:0 3px}.cal-week-header,.cal-week-scroll{grid-template-columns:36px repeat(7,1fr)}.cal-week-header-day-num{font-size:1rem}.cal-week-header-day.today .cal-week-header-day-num{width:28px;height:28px}}.calendar-page{display:flex;flex-direction:column;height:100%;min-height:0;position:relative;background:var(--color-surface)}.calendar-loading{display:flex;align-items:center;justify-content:center;flex:1}.cal-select-toolbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface);min-height:40px}.cal-select-toggle{display:flex;align-items:center;gap:var(--space-1);padding:4px var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-surface-elevated);border:1px solid var(--color-border);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.cal-select-toggle:hover{background:var(--color-primary-subtle);color:var(--color-primary)}.cal-select-toggle.active{background:var(--color-primary);color:var(--color-text-inverted);border-color:var(--color-primary)}.cal-delete-selected{display:flex;align-items:center;gap:var(--space-1);padding:4px var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--color-text-inverted);background:var(--color-destructive);border:none;cursor:pointer;transition:background var(--duration-fast) var(--ease-out);animation:message-in .2s var(--ease-out)}.cal-delete-selected:hover{filter:brightness(1.1)}.cal-confirm-bar{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;font-weight:600;color:var(--color-text-primary);animation:message-in .2s var(--ease-out)}.cal-confirm-yes{padding:4px var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--color-text-inverted);background:var(--color-destructive);border:none;cursor:pointer}.cal-confirm-yes:disabled{opacity:.6;cursor:not-allowed}.cal-confirm-no{padding:4px var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-surface-elevated);border:1px solid var(--color-border);cursor:pointer}@keyframes message-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.cal-event-pill.selected{outline:2px solid var(--color-destructive);outline-offset:1px}.cal-event-check{font-size:.625rem;margin-right:2px}.cal-week-event.selected{outline:2px solid var(--color-destructive);outline-offset:-1px;z-index:5!important}.calendar-mobile-header{display:none}.calendar-fab{display:none;position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:var(--radius-lg);background:var(--gradient-primary);color:var(--color-text-inverted);box-shadow:var(--shadow-primary),var(--shadow-elevated);align-items:center;justify-content:center;z-index:30;transition:all var(--duration-fast) var(--ease-spring)}.calendar-fab:hover{transform:scale(1.08);box-shadow:0 8px 24px #6366f180}.calendar-fab:active{transform:scale(1)}@media(max-width:768px){.calendar-mobile-header{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.calendar-mobile-header-top{display:flex;align-items:center;justify-content:space-between}.calendar-mobile-date-title{font-size:1.0625rem;font-weight:600;color:var(--color-text-primary);letter-spacing:-.01em}.calendar-mobile-view-toggle{display:flex;background:var(--color-surface-elevated);border-radius:var(--radius-sm);padding:2px;gap:2px}.calendar-mobile-view-toggle .layout-view-btn{flex:1;text-align:center}.calendar-fab{display:flex}}.ai-page{display:flex;height:100%;min-height:0;background:var(--color-background)}.ai-sidebar{width:280px;min-width:280px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.ai-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border)}.ai-sidebar-title{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.ai-new-btn{padding:5px var(--space-3);font-size:.8125rem;gap:var(--space-1);background:var(--color-primary-subtle);color:var(--color-primary);border-radius:var(--radius-sm);font-weight:600;transition:background-color var(--duration-fast) var(--ease-out)}.ai-new-btn:hover{background:var(--color-primary-muted)}.ai-sidebar-list{flex:1;overflow-y:auto;padding:var(--space-2)}.ai-sidebar-loading{display:flex;justify-content:center;padding:var(--space-6)}.ai-sidebar-empty{text-align:center;color:var(--color-text-tertiary);font-size:.875rem;padding:var(--space-6)}.ai-sidebar-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);border-radius:var(--radius-sm);text-align:left;color:var(--color-text-primary);transition:background-color var(--duration-fast) var(--ease-out)}.ai-sidebar-item:hover{background:var(--color-surface-elevated)}.ai-sidebar-item.active{background:var(--color-primary-subtle)}.ai-sidebar-item-icon{color:var(--color-text-tertiary);flex-shrink:0}.ai-sidebar-item.active .ai-sidebar-item-icon{color:var(--color-primary)}.ai-sidebar-item-info{display:flex;flex-direction:column;min-width:0}.ai-sidebar-item-title{font-size:.8125rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-sidebar-item-date{font-size:.6875rem;color:var(--color-text-tertiary)}.ai-chat{flex:1;display:flex;flex-direction:column;min-width:0}.ai-chat-header{display:none}.ai-messages{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.ai-message{display:flex;gap:var(--space-3);max-width:720px;animation:message-in .3s var(--ease-out)}@keyframes message-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ai-message.user{align-self:flex-end;flex-direction:row-reverse}.ai-message.assistant{align-self:flex-start}.ai-message-avatar{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--color-surface-elevated);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0;font-size:.875rem}.ai-message.user .ai-message-avatar{background:var(--gradient-primary);color:var(--color-text-inverted)}.ai-message-content{display:flex;flex-direction:column;gap:var(--space-1)}.ai-message.user .ai-message-content{align-items:flex-end}.ai-message-bubble{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:.9375rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}.ai-message.user .ai-message-bubble{background:var(--gradient-primary);color:var(--color-text-inverted);border-bottom-right-radius:var(--space-1);box-shadow:var(--shadow-primary)}.ai-message.assistant .ai-message-bubble{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);border-bottom-left-radius:var(--space-1);box-shadow:var(--shadow-xs)}.ai-message-time{font-size:.6875rem;color:var(--color-text-tertiary);padding:0 var(--space-1)}.ai-avatar-thinking{animation:ai-avatar-pulse 2s infinite ease-in-out}@keyframes ai-avatar-pulse{0%,to{box-shadow:0 0 0 0 var(--color-primary-subtle)}50%{box-shadow:0 0 0 6px transparent}}.ai-thinking{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-5)}.ai-thinking-dots{display:flex;gap:6px;align-items:center}.ai-thinking-dot{width:7px;height:7px;background:var(--color-primary);border-radius:50%;animation:ai-bounce 1.4s infinite ease-in-out}.ai-thinking-dot:nth-child(2){animation-delay:.16s}.ai-thinking-dot:nth-child(3){animation-delay:.32s}@keyframes ai-bounce{0%,80%,to{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:1}}.ai-thinking-label{font-size:.75rem;color:var(--color-text-tertiary);font-weight:500;letter-spacing:.01em;animation:ai-fade-pulse 2s infinite ease-in-out}@keyframes ai-fade-pulse{0%,to{opacity:.5}50%{opacity:1}}.ai-typing-indicator{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-1);animation:message-in .3s var(--ease-out)}.ai-typing-bar{width:24px;height:3px;border-radius:2px;background:var(--color-primary);animation:ai-typing-pulse 1.2s infinite ease-in-out}@keyframes ai-typing-pulse{0%,to{opacity:.3;width:16px}50%{opacity:1;width:28px}}.ai-typing-label{font-size:.6875rem;font-weight:500;color:var(--color-text-tertiary);animation:ai-fade-pulse 2s infinite ease-in-out}.ai-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:var(--space-8)}.ai-empty-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--color-primary-subtle);color:var(--color-primary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-5)}.ai-empty-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em}.ai-empty-desc{font-size:.9375rem;color:var(--color-text-secondary);max-width:400px;line-height:1.5}.ai-input-bar{padding:var(--space-4);border-top:1px solid var(--color-border);background:var(--color-surface)}.ai-input-wrapper{display:flex;align-items:flex-end;gap:var(--space-2);background:var(--color-background);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.ai-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle),var(--shadow-glow)}.ai-input{flex:1;border:none;background:none;resize:none;font-size:.9375rem;line-height:1.5;color:var(--color-text-primary);padding:var(--space-1) 0;max-height:150px;overflow-y:auto}.ai-input:focus{outline:none}.ai-input::placeholder{color:var(--color-text-tertiary)}.ai-input:disabled{opacity:.6}.ai-send-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--gradient-primary);color:var(--color-text-inverted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),opacity var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-primary)}.ai-send-btn:hover:not(:disabled){box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.ai-stop-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--color-destructive);color:var(--color-text-inverted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);box-shadow:0 4px 14px #ef444459}.ai-stop-btn:hover{background:var(--color-destructive-dark);transform:translateY(-1px)}.ai-sidebar-item-delete{opacity:0;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);color:var(--color-text-tertiary);transition:opacity var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out);margin-left:auto}.ai-sidebar-item:hover .ai-sidebar-item-delete{opacity:1}.ai-sidebar-item-delete:hover{background:var(--color-destructive-subtle);color:var(--color-destructive)}.ai-sidebar-item-delete:disabled{opacity:.5;cursor:not-allowed}.ai-planner-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.ai-planner-toggle{display:flex;align-items:center;gap:var(--space-1);padding:4px var(--space-3);border-radius:999px;font-size:.75rem;font-weight:600;color:var(--color-primary);border:1.5px solid var(--color-primary);background:transparent;transition:all var(--duration-fast) var(--ease-out);cursor:pointer}.ai-planner-toggle:hover{background:var(--color-primary-subtle)}.ai-planner-toggle.active{background:var(--color-primary);color:var(--color-text-inverted);border-color:var(--color-primary)}.ai-mode-badge{font-size:.6875rem;font-weight:700;letter-spacing:.05em;padding:3px var(--space-2);border-radius:var(--radius-xs);background:var(--color-warning-subtle, rgba(234, 179, 8, .15));color:var(--color-warning, #ca8a04)}.ai-slash-hint{padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2);font-size:.8125rem;color:var(--color-text-secondary);background:var(--color-surface-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.ai-slash-commands-help{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);font-size:.8125rem;color:var(--color-text-tertiary)}.ai-slash-commands-help code{padding:2px var(--space-2);border-radius:var(--radius-xs);background:var(--color-surface-elevated);font-size:.75rem;font-weight:600;color:var(--color-primary)}.ai-slash-label{font-weight:500}.ai-schedule-banner{padding:0 var(--space-4) var(--space-2);animation:banner-in .3s var(--ease-out)}@keyframes banner-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ai-schedule-banner-inner{padding:var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-primary-muted);border-radius:var(--radius-md);box-shadow:0 4px 20px rgba(var(--color-primary-rgb, 99, 102, 241),.12),var(--shadow-md, 0 4px 12px rgba(0,0,0,.08))}.ai-schedule-banner-header{display:flex;align-items:center;gap:var(--space-2);font-size:.9375rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2)}.ai-schedule-banner-header svg{color:var(--color-primary);flex-shrink:0}.ai-schedule-banner-header.ai-schedule-ready svg{animation:ai-calendar-bounce .5s var(--ease-out)}@keyframes ai-calendar-bounce{0%{transform:scale(.8)}50%{transform:scale(1.15)}to{transform:scale(1)}}.ai-schedule-banner-prompt{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:var(--space-3);line-height:1.4}.ai-schedule-banner-header.ai-schedule-success svg{color:var(--color-success, #22c55e)}.ai-schedule-events-list{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.ai-schedule-event-item{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem}.ai-schedule-event-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.ai-schedule-event-title{color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.ai-schedule-event-time{color:var(--color-text-tertiary);font-size:.75rem;flex-shrink:0}.ai-regen-feedback{padding:var(--space-2) 0}.ai-regen-input{width:100%;padding:8px 12px;font-size:.8125rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);outline:none;transition:border-color .15s}.ai-regen-input:focus{border-color:rgb(var(--primary-rgb))}.ai-regen-input::placeholder{color:var(--color-text-tertiary)}.ai-schedule-banner-actions{display:flex;gap:var(--space-2)}.ai-schedule-btn-secondary{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--color-primary);background:var(--color-primary-subtle);border:none;cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.ai-schedule-btn-secondary:hover{background:var(--color-primary-muted)}.ai-schedule-btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--color-text-inverted);background:var(--gradient-primary);border:none;cursor:pointer;box-shadow:var(--shadow-primary);transition:box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.ai-schedule-btn-primary:hover{box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.ai-overlay{display:none}@media(max-width:768px){.ai-sidebar{position:fixed;left:0;top:56px;bottom:0;z-index:100;transform:translate(-100%);transition:transform var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-float)}.ai-sidebar.open{transform:translate(0)}.ai-overlay{display:block;position:fixed;inset:56px 0 0;background:var(--color-overlay);z-index:90}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.ai-chat-header-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background var(--duration-fast) ease}.ai-chat-header-btn:hover{background:var(--color-surface-elevated)}.ai-chat-header-title{font-weight:600;font-size:.9375rem}.ai-messages{padding:var(--space-4)}}.settings{padding:var(--space-7) var(--space-8);overflow-y:auto;height:100%}.settings-loading{display:flex;align-items:center;justify-content:center;height:100%}.settings-container{max-width:720px;margin:0 auto}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-7);gap:var(--space-4);flex-wrap:wrap}.settings-heading{font-size:1.75rem;font-weight:700;letter-spacing:-.03em}.settings-header-hint{font-size:.8125rem;color:var(--color-text-tertiary);margin-top:2px}.settings-header-hint strong{color:var(--color-primary);font-weight:600}.settings-header-actions{display:flex;align-items:center;gap:var(--space-3)}.settings-save-msg{font-size:.8125rem;font-weight:500;white-space:nowrap}.settings-section{margin-bottom:var(--space-7);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5)}.settings-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:var(--space-4)}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;gap:var(--space-4)}.settings-row+.settings-row{border-top:1px solid var(--color-border-subtle)}.settings-row-label{font-weight:500;font-size:.875rem;color:var(--color-text-primary)}.settings-row-value{color:var(--color-text-secondary);font-size:.875rem}.settings-row-hint{display:block;font-size:.8125rem;color:var(--color-text-tertiary);margin-top:var(--space-1)}.settings-toggle-group{display:flex;background:var(--color-surface-elevated);border-radius:var(--radius-sm);padding:2px;gap:2px;flex-shrink:0}.settings-toggle-btn{padding:6px var(--space-3);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);white-space:nowrap;border-radius:var(--radius-xs)}.settings-toggle-btn:hover{color:var(--color-text-primary)}.settings-toggle-btn.active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:var(--shadow-xs)}.settings-color-grid{display:flex;gap:var(--space-2);flex-wrap:wrap}.settings-color-btn{width:30px;height:30px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring),border-color var(--duration-fast) var(--ease-spring)}.settings-color-btn:hover{transform:scale(1.15)}.settings-color-btn.selected{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-surface),0 0 0 4px var(--color-text-primary);transform:scale(1.15)}.settings-select-small{width:auto;min-width:120px}.settings-time-row{display:flex;align-items:center;gap:var(--space-2)}.settings-time-colon{font-weight:600;color:var(--color-text-tertiary)}.settings-link-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;color:var(--color-text-primary);transition:opacity var(--duration-fast) ease}.settings-link-row:hover{text-decoration:none;opacity:.8}.settings-link-row svg{color:var(--color-text-tertiary);flex-shrink:0}.settings-account-actions{display:flex;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle);margin-top:var(--space-3)}.settings-delete-overlay{position:fixed;inset:0;background:#00000080;z-index:500;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:sdo-fade .15s ease}@keyframes sdo-fade{0%{opacity:0}}.settings-delete-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);width:440px;max-width:100%;padding:var(--space-6);text-align:center;animation:sdo-in .2s var(--ease-out)}@keyframes sdo-in{0%{opacity:0;transform:scale(.96) translateY(8px)}}.settings-delete-icon{width:48px;height:48px;border-radius:50%;background:#ef44441a;color:#ef4444;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}.settings-delete-title{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-2)}.settings-delete-body{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-5)}.settings-delete-body strong{color:#ef4444}.settings-delete-field{text-align:left;margin-bottom:var(--space-5)}.settings-delete-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.settings-delete-input{width:100%;text-align:center;font-size:.9375rem;font-weight:600;letter-spacing:.1em}.settings-delete-actions{display:flex;gap:var(--space-3);justify-content:flex-end}@media(max-width:768px){.settings,.settings-section{padding:var(--space-4)}.settings-header{flex-direction:column;align-items:flex-start}.settings-row{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.settings-toggle-group{width:100%}.settings-toggle-btn{flex:1;text-align:center}.settings-color-grid,.settings-select-small{width:100%}.settings-account-actions{flex-direction:column}.settings-account-actions .btn{width:100%;justify-content:center}}.canvas-page{max-width:600px;padding:var(--space-7)}.canvas-page-wide{max-width:800px}.canvas-heading{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-2);letter-spacing:-.03em}.canvas-subheading{color:var(--color-text-secondary);font-size:.9375rem;margin-bottom:var(--space-6);line-height:1.5}.canvas-loading{display:flex;justify-content:center;padding:var(--space-8) 0}.canvas-info-box{display:flex;gap:var(--space-3);background:var(--color-primary-subtle);border:1px solid var(--color-primary-muted);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-6);font-size:.875rem;line-height:1.55;color:var(--color-text-primary)}.canvas-info-icon{color:var(--color-primary);flex-shrink:0;margin-top:1px}.canvas-info-box strong{display:inline}.canvas-info-box p{margin-top:var(--space-2);color:var(--color-text-secondary)}.canvas-info-warning{color:var(--color-accent)!important;font-weight:600;margin-top:var(--space-3)!important}.canvas-form{display:flex;flex-direction:column;gap:var(--space-5)}.canvas-field-hint{font-size:.75rem;color:var(--color-text-tertiary);margin-top:var(--space-1)}.canvas-connected-card{margin-top:var(--space-2)}.canvas-connected-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.canvas-connected-title{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.canvas-connected-subtitle{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--space-1)}.canvas-connected-details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--space-5)}.canvas-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4)}.canvas-detail-row+.canvas-detail-row{border-top:1px solid var(--color-border-subtle)}.canvas-detail-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.canvas-detail-value{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.canvas-color-picker{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.canvas-color-label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.canvas-color-options{display:flex;gap:var(--space-2)}.canvas-color-dot{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.canvas-color-dot:hover{transform:scale(1.15)}.canvas-color-dot.selected{border-color:var(--color-text-inverted);box-shadow:0 0 0 2px currentColor,0 0 8px #0003;transform:scale(1.15)}.canvas-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-5)}.canvas-calendar-btn{border-color:var(--color-primary);color:var(--color-primary)}.canvas-assignments{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-5)}.canvas-assignments-title{font-size:.875rem;font-weight:600;color:var(--color-text-primary);letter-spacing:-.01em}.canvas-assignment-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:400px;overflow-y:auto}.canvas-assignment-item{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-sm);background:var(--color-background);border:1px solid var(--color-border-subtle);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.canvas-assignment-item:hover{border-color:var(--color-border);box-shadow:var(--shadow-xs)}.canvas-assignment-info{display:flex;flex-direction:column;gap:2px;min-width:0}.canvas-assignment-course{font-size:.6875rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em}.canvas-assignment-name{font-size:.875rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-assignment-due{font-size:.75rem;color:var(--color-text-tertiary)}.canvas-assignment-item.added{opacity:.7}.canvas-assignment-badge{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:600;color:var(--color-success);background:var(--color-success-subtle);padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.canvas-assignment-add-btn{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-primary);background:var(--color-primary-subtle);border:none;cursor:pointer;transition:background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.canvas-assignment-add-btn:hover:not(:disabled){background:var(--color-primary-muted);transform:scale(1.05)}.canvas-assignment-add-btn:disabled{opacity:.5;cursor:not-allowed}.canvas-assignment-no-date{font-size:.6875rem;color:var(--color-text-tertiary);flex-shrink:0}.canvas-assignments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.canvas-assignments-stats{font-size:.75rem;color:var(--color-text-tertiary);font-weight:500}.canvas-connected-footer{border-top:1px solid var(--color-border);padding-top:var(--space-4)}.canvas-disconnect-btn{border-color:var(--color-destructive);color:var(--color-destructive)}.canvas-disconnect-btn:hover{background-color:var(--color-destructive);color:var(--color-text-inverted)}.canvas-confirm-disconnect{background:var(--color-destructive-subtle);border:1px solid rgba(239,68,68,.15);border-radius:var(--radius-md);padding:var(--space-4)}.canvas-confirm-text{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--space-4);line-height:1.5}.canvas-confirm-actions{display:flex;gap:var(--space-3)}.dashboard{padding:var(--space-7)}.dashboard-welcome-section{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-6)}.dashboard-welcome-avatar{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--gradient-primary);color:var(--color-text-inverted);font-weight:700;font-size:1.25rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-primary)}.dashboard-heading{font-size:1.5rem;font-weight:700;margin-bottom:2px;letter-spacing:-.03em}.dashboard-subtitle{color:var(--color-text-secondary);font-size:.8125rem}.dashboard-card-loading{display:flex;justify-content:center;padding:var(--space-6) 0}.db-stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.db-stat-card{display:flex;flex-direction:column;align-items:center;padding:var(--space-4) var(--space-3);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);transition:box-shadow .15s,border-color .15s}.db-stat-card:hover{border-color:var(--color-border);box-shadow:var(--shadow-sm)}.db-stat-num{font-size:1.375rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.db-stat-num.accent{background:linear-gradient(135deg,#f59e0b,#f97316);-webkit-background-clip:text;background-clip:text}.db-stat-num.warn{background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;background-clip:text}.db-stat-num.done{background:linear-gradient(135deg,#22c55e,#16a34a);-webkit-background-clip:text;background-clip:text}.db-stat-label{font-size:.625rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.db-grid{display:grid;grid-template-columns:1fr minmax(320px,35%);gap:var(--space-5);align-items:start}.db-left{min-width:0}.db-right{display:flex;flex-direction:column;gap:var(--space-4)}.db-card-hdr{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.db-card-title{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.db-card-meta{font-size:.75rem;color:var(--color-text-tertiary)}.db-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.db-icon.checklist{background:rgba(var(--primary-rgb),.1);color:rgb(var(--primary-rgb))}.db-icon.add{background:#22c55e1a;color:#22c55e}.db-icon.timer{background:#f973161a;color:#f97316}.db-icon.sched{background:#3b82f61a;color:#3b82f6}.db-icon.canvas{background:#ef44441a;color:#ef4444}.db-icon.links{background:#a855f71a;color:#a855f7}.db-icon.timer.pulse{animation:iconPulse 1.5s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.db-ai-btn{gap:6px;flex-shrink:0;background:var(--gradient-primary);border:none;box-shadow:var(--shadow-primary)}.db-ai-btn:hover{box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.db-planning{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:rgba(var(--primary-rgb),.06);border-radius:var(--radius-sm);margin-bottom:var(--space-4);font-size:.8125rem;color:rgb(var(--primary-rgb));font-weight:500}.db-plan-spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(var(--primary-rgb),.2);border-top-color:rgb(var(--primary-rgb));animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.db-checklist{max-height:calc(100vh - 220px);overflow-y:auto;scrollbar-width:thin}.db-empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) 0;text-align:center;color:var(--color-text-secondary);font-size:.875rem}.db-empty-sub{font-size:.75rem;color:var(--color-text-tertiary);margin-top:var(--space-1)}.db-buckets{display:flex;flex-direction:column;gap:var(--space-4)}.db-bucket-hdr{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-radius:var(--radius-xs);background:var(--color-surface-elevated);margin-bottom:var(--space-2)}.db-bucket-hdr.overdue{background:var(--color-destructive-subtle)}.db-bucket-hdr.overdue .db-bucket-label{color:var(--color-destructive)}.db-bucket-hdr.today{background:rgba(var(--primary-rgb),.08)}.db-bucket-hdr.today .db-bucket-label{color:rgb(var(--primary-rgb))}.db-bucket-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary)}.db-bucket-count{font-size:.6875rem;font-weight:600;color:var(--color-text-tertiary);background:var(--color-surface);padding:1px 8px;border-radius:var(--radius-full);border:1px solid var(--color-border-subtle)}.db-check-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-sm);transition:background .15s,opacity .25s,transform .25s}.db-check-item:hover{background:var(--color-surface-elevated)}.db-check-item.done{opacity:.7}.db-check-item.done .db-check-name{text-decoration:line-through;color:var(--color-text-tertiary)}.db-cb{width:20px;height:20px;border-radius:6px;border:2px solid var(--color-border);background:var(--color-surface);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .15s}.db-cb:hover{border-color:rgb(var(--primary-rgb));transform:scale(1.1)}.db-cb.on{background:rgb(var(--primary-rgb));border-color:rgb(var(--primary-rgb));color:#fff}.db-check-bar{width:4px;height:28px;border-radius:2px;flex-shrink:0}.db-check-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.db-check-name{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-check-time{font-size:.6875rem;color:var(--color-text-tertiary)}.db-badge{font-size:.625rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.db-badge.priority-critical{background:#ef44441a;color:#ef4444}.db-badge.priority-high{background:#f973161a;color:#f97316}.db-badge.priority-medium{background:#eab3081a;color:#ca8a04}.db-badge.focus{background:rgba(var(--primary-rgb),.1);color:rgb(var(--primary-rgb))}.db-menu-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}.db-menu-btn:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.db-delete-mode-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.db-confirm-text{font-size:.75rem;font-weight:600;color:var(--color-destructive);white-space:nowrap}.db-confirm-del-btn{display:inline-flex;align-items:center;gap:4px;background:#ef444414!important;color:var(--color-destructive)!important;border:1px solid rgba(239,68,68,.25)!important;font-weight:600}.db-confirm-del-btn:hover:not(:disabled){background:#ef444426!important}.db-confirm-del-btn:disabled{opacity:.4;cursor:not-allowed}.db-cb-del{border-color:var(--color-destructive)}.db-cb-del:hover{border-color:var(--color-destructive);background:#ef44440f;transform:scale(1.1)}.db-cb-del.on{background:var(--color-destructive);border-color:var(--color-destructive);color:#fff}.db-check-item.del-selected{background:#ef44440a}.db-tool{padding:var(--space-5)}.db-tool .db-card-hdr{margin-bottom:var(--space-3)}.db-week-chart{display:flex;gap:var(--space-2);align-items:flex-end;height:140px;padding:var(--space-3) 0}.db-week-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);height:100%}.db-week-count{font-size:.6875rem;font-weight:700;color:var(--color-text-secondary);height:16px;display:flex;align-items:center}.db-week-bar-track{flex:1;width:100%;max-width:32px;background:var(--color-surface-elevated);border-radius:var(--radius-xs);display:flex;align-items:flex-end;overflow:hidden}.db-week-bar-stack{width:100%;min-height:4px;border-radius:var(--radius-xs);display:flex;flex-direction:column;overflow:hidden;transition:height .4s ease}.db-week-bar-segment{width:100%;min-height:2px;transition:flex .4s ease}.db-week-bar-segment:first-child{border-radius:var(--radius-xs) var(--radius-xs) 0 0}.db-week-bar-segment:last-child{border-radius:0 0 var(--radius-xs) var(--radius-xs)}.db-week-bar-segment:only-child{border-radius:var(--radius-xs)}.db-week-bar-fill{width:100%;min-height:4px;background:var(--color-surface-elevated);border-radius:var(--radius-xs);transition:height .4s ease}.db-week-col.today .db-week-bar-stack{box-shadow:0 0 8px #00000026}.db-week-col.today .db-week-day{color:rgb(var(--primary-rgb));font-weight:700}.db-week-day{font-size:.625rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em}.db-week-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle);margin-top:var(--space-3)}.db-week-legend-item{display:flex;align-items:center;gap:var(--space-1)}.db-week-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.db-week-legend-label{font-size:.625rem;font-weight:600;color:var(--color-text-tertiary);text-transform:capitalize}.db-qa-form{display:flex;flex-direction:column;gap:var(--space-2)}.db-qa-form .input-field{padding:8px 12px;font-size:.8125rem}.db-qa-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.db-qa-form .btn{margin-top:var(--space-1)}.db-timeline{display:flex;flex-direction:column;padding-left:var(--space-2)}.db-tl-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;position:relative}.db-tl-item:not(:last-child):before{content:"";position:absolute;left:5px;top:24px;bottom:-8px;width:1px;background:var(--color-border-subtle)}.db-tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;z-index:1}.db-tl-content{display:flex;flex-direction:column;gap:1px;min-width:0}.db-tl-time{font-size:.6875rem;color:var(--color-text-tertiary);font-weight:500}.db-tl-title{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-canvas-ok{display:flex;flex-direction:column;gap:var(--space-2)}.db-status-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:.75rem;font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);width:fit-content}.db-status-badge.ok{background:var(--color-success-subtle);color:var(--color-success)}.db-links{display:flex;flex-direction:column;gap:1px}.db-link{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);border-radius:var(--radius-xs);color:var(--color-text-primary);font-size:.8125rem;font-weight:500;transition:background .15s,transform .15s}.db-link:hover{background:var(--color-surface-elevated);text-decoration:none;transform:translate(2px)}.db-link svg{color:var(--color-text-tertiary);transition:color .15s}.db-link:hover svg{color:rgb(var(--primary-rgb))}@media(max-width:1100px){.db-grid{grid-template-columns:1fr minmax(280px,40%)}}@media(max-width:960px){.db-grid{grid-template-columns:1fr}.db-right{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.db-right>.db-tool:first-child{grid-column:1/-1}.db-stats-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.dashboard{padding:var(--space-5) var(--space-4)}.db-stats-row{grid-template-columns:repeat(2,1fr)}.dashboard-welcome-section{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.db-checklist{max-height:none}}.focus-timer{padding:var(--space-7);max-width:860px;margin:0 auto}.ft-header{margin-bottom:var(--space-6)}.ft-heading{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;margin-bottom:2px}.ft-subtitle{color:var(--color-text-secondary);font-size:.8125rem}.ft-ring-section{display:flex;justify-content:center;margin-bottom:var(--space-6)}.ft-ring-wrapper{position:relative;width:280px;height:280px}.ft-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.ft-ring-bg{fill:none;stroke:var(--color-border-subtle);stroke-width:10}.ft-ring-progress{fill:none;stroke:rgb(var(--primary-rgb));stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .8s ease}.ft-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.ft-ring-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary)}.ft-ring-time{font-size:3rem;font-weight:300;font-variant-numeric:tabular-nums;color:var(--color-text-primary);line-height:1;letter-spacing:-.02em}.ft-ring-elapsed{font-size:.75rem;color:var(--color-text-secondary)}.ft-ring-count{font-size:.6875rem;color:var(--color-text-tertiary);margin-top:2px}.ft-ring-task{font-size:.75rem;color:var(--color-text-secondary);font-weight:500;margin-top:2px;max-width:180px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ft-ring-label.ft-break{color:#22c55e}.ft-stats{display:flex;justify-content:center;gap:var(--space-5);margin-bottom:var(--space-5)}.ft-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.ft-stat-label{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.ft-stat-value{font-size:.9375rem;font-weight:700;color:var(--color-text-primary)}.ft-stat-eta{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ft-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-6)}.ft-btn-secondary{width:48px;height:48px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.ft-btn-secondary:hover:not(:disabled){border-color:var(--color-border);background:var(--color-surface-elevated);color:var(--color-text-primary)}.ft-btn-secondary:disabled{opacity:.35;cursor:not-allowed}.ft-btn-primary{width:64px;height:64px;border-radius:50%;border:none;background:var(--gradient-primary);color:var(--color-text-inverted);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-primary);transition:all .2s}.ft-btn-primary:hover:not(:disabled){box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.ft-btn-primary:disabled{opacity:.45;cursor:not-allowed}.ft-btn-add{width:48px;height:48px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:rgb(var(--primary-rgb));display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.ft-btn-add:hover{border-color:rgb(var(--primary-rgb));background:rgba(var(--primary-rgb),.06)}.ft-btn-extra{height:40px;padding:0 14px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);color:rgb(var(--primary-rgb));font-size:.75rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.ft-btn-extra:hover{border-color:rgb(var(--primary-rgb));background:rgba(var(--primary-rgb),.06)}.ft-queue{background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);overflow:hidden}.ft-queue-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle)}.ft-queue-title{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.ft-queue-meta{font-size:.75rem;color:var(--color-text-tertiary);background:var(--color-surface-elevated);padding:2px 10px;border-radius:var(--radius-full)}.ft-empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-5);text-align:center}.ft-empty-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-surface-elevated);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.ft-empty-title{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:4px}.ft-empty-sub{font-size:.75rem;color:var(--color-text-tertiary)}.ft-event{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);transition:background .15s}.ft-event:not(:last-child){border-bottom:1px solid var(--color-border-subtle)}.ft-event:hover{background:var(--color-surface-hover)}.ft-event-bar{width:4px;height:36px;border-radius:2px;flex-shrink:0}.ft-event-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ft-event-title-row{display:flex;align-items:center;gap:var(--space-2)}.ft-event-title{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ft-event-focus-icon{color:rgb(var(--primary-rgb));flex-shrink:0}.ft-event-meta{display:flex;align-items:center;gap:var(--space-2);font-size:.6875rem;color:var(--color-text-tertiary)}.ft-event-dot{width:3px;height:3px;border-radius:50%;background:var(--color-text-tertiary)}.ft-event-remove{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}.ft-event-remove:hover{background:var(--color-destructive-subtle, rgba(239,68,68,.1));color:var(--color-destructive)}.ft-picker-backdrop{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;animation:ftFadeIn .15s ease}@keyframes ftFadeIn{0%{opacity:0}}.ft-picker{width:480px;max-width:90vw;max-height:70vh;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-float);display:flex;flex-direction:column;animation:ftSlideUp .2s ease}@keyframes ftSlideUp{0%{opacity:0;transform:translateY(12px)}}.ft-picker-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle)}.ft-picker-title{font-size:.9375rem;font-weight:600}.ft-picker-close{width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.ft-picker-close:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.ft-picker-body{flex:1;overflow-y:auto;padding:var(--space-2) 0}.ft-picker-empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-5);text-align:center;color:var(--color-text-secondary);font-size:.875rem}.ft-picker-empty-sub{font-size:.75rem;color:var(--color-text-tertiary);margin-top:var(--space-1)}.ft-picker-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);transition:background .15s}.ft-picker-item:hover{background:var(--color-surface-hover)}.ft-picker-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.ft-picker-info{flex:1;min-width:0}.ft-picker-name{font-size:.8125rem;font-weight:500;color:var(--color-text-primary)}.ft-picker-time{font-size:.6875rem;color:var(--color-text-tertiary)}.ft-picker-add-btn{width:30px;height:30px;border-radius:50%;border:none;background:rgba(var(--primary-rgb),.1);color:rgb(var(--primary-rgb));display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}.ft-picker-add-btn:hover{background:rgba(var(--primary-rgb),.2);transform:scale(1.05)}.ft-pom-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);font-size:.8125rem;color:var(--color-text-secondary);transition:background .15s}.ft-pom-item:not(:last-child){border-bottom:1px solid var(--color-border-subtle)}.ft-pom-item.active{background:rgba(var(--primary-rgb),.06);color:var(--color-text-primary);font-weight:500}.ft-pom-item.ft-pom-break{color:var(--color-text-tertiary);font-style:italic}.ft-pom-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--color-border)}.ft-pom-item.active .ft-pom-indicator{box-shadow:0 0 6px currentColor}.ft-pom-item.ft-pom-break .ft-pom-indicator{background:#22c55e}.ft-pom-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ft-pom-dur{font-size:.6875rem;font-weight:600;color:var(--color-text-tertiary);flex-shrink:0}@media(max-width:768px){.focus-timer{padding:var(--space-5) var(--space-4)}.ft-ring-wrapper{width:240px;height:240px}.ft-ring-time{font-size:2.5rem}.ft-controls{gap:var(--space-4)}}.skills{padding:var(--space-7) var(--space-8);overflow-y:auto;height:100%}.skills-loading{display:flex;align-items:center;justify-content:center;height:100%}.skills-container{max-width:960px;margin:0 auto}.skills-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.skills-heading{font-size:1.75rem;font-weight:700;letter-spacing:-.03em}.skills-heading-sub{font-size:.875rem;color:var(--color-text-tertiary);margin-top:2px}.skills-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-6);background:var(--color-surface-elevated);border-radius:var(--radius-sm);padding:3px}.skills-tab{flex:1;padding:var(--space-2) var(--space-4);border:none;background:transparent;border-radius:var(--radius-xs);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.skills-tab:hover{color:var(--color-text-primary)}.skills-tab.active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:0 1px 3px #00000014}.skills-filters{display:flex;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}.skills-search{flex:1;min-width:200px;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.875rem;color:var(--color-text-primary);outline:none;transition:border-color .15s}.skills-search:focus{border-color:var(--color-primary)}.skills-filter-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.875rem;color:var(--color-text-primary);cursor:pointer;outline:none}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.skills-empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-text-tertiary);grid-column:1 / -1}.skills-empty-icon{font-size:2.5rem;margin-bottom:var(--space-3);opacity:.5}.skills-empty-text{font-size:.9375rem;margin-bottom:var(--space-4)}.skill-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;gap:var(--space-3)}.skill-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--primary-rgb),.1);transform:translateY(-1px)}.skill-card-top{display:flex;align-items:flex-start;gap:var(--space-3)}.skill-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--color-primary-subtle);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.skill-card-info{flex:1;min-width:0}.skill-card-name{font-size:.9375rem;font-weight:600;color:var(--color-text-primary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.skill-card-author{font-size:.75rem;color:var(--color-text-tertiary)}.skill-card-desc{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.skill-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:auto}.skill-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:.75rem;color:var(--color-text-tertiary)}.skill-card-meta-item{display:flex;align-items:center;gap:3px}.skill-card-badge{font-size:.6875rem;padding:2px 8px;border-radius:var(--radius-full);background:var(--color-surface-elevated);color:var(--color-text-secondary);font-weight:500}.skill-card-badge.official{background:var(--color-primary-subtle);color:var(--color-primary)}.skill-card-actions{display:flex;align-items:center;gap:var(--space-2)}.skill-toggle{position:relative;width:36px;height:20px;border-radius:10px;border:none;cursor:pointer;transition:background .2s;background:var(--color-surface-elevated);flex-shrink:0}.skill-toggle.active{background:var(--color-primary)}.skill-toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 2px #00000026}.skill-toggle.active:after{transform:translate(16px)}.skill-install-btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-xs);font-size:.75rem;font-weight:600;border:1px solid var(--color-primary);cursor:pointer;transition:all .15s;white-space:nowrap}.skill-install-btn.install{background:var(--color-primary);color:#fff}.skill-install-btn.install:hover{background:var(--color-primary-dark)}.skill-install-btn.installed{background:transparent;color:var(--color-primary)}.skill-install-btn.installed:hover{background:var(--color-destructive-subtle);border-color:var(--color-destructive);color:var(--color-destructive)}.skills-modal-overlay{position:fixed;inset:0;background:var(--color-overlay);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.skills-modal{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.skills-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-5) var(--space-3)}.skills-modal-title{font-size:1.25rem;font-weight:700}.skills-modal-close{width:32px;height:32px;border-radius:var(--radius-xs);border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);transition:background .15s}.skills-modal-close:hover{background:var(--color-surface-elevated)}.skills-modal-body{padding:0 var(--space-5) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.skills-form-group{display:flex;flex-direction:column;gap:var(--space-1)}.skills-form-label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary)}.skills-form-input,.skills-form-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.875rem;color:var(--color-text-primary);outline:none;transition:border-color .15s}.skills-form-input:focus,.skills-form-select:focus{border-color:var(--color-primary)}.skills-form-textarea{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.8125rem;font-family:SF Mono,Fira Code,monospace;color:var(--color-text-primary);outline:none;resize:vertical;min-height:120px;line-height:1.5;transition:border-color .15s}.skills-form-textarea:focus{border-color:var(--color-primary)}.skills-form-hint{font-size:.75rem;color:var(--color-text-tertiary)}.skills-form-row{display:flex;gap:var(--space-3)}.skills-form-row>*{flex:1}.skills-form-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) 0}.skills-form-toggle-label{font-size:.875rem;color:var(--color-text-primary)}.skills-form-toggle-hint{font-size:.75rem;color:var(--color-text-tertiary);margin-top:2px}.skills-form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-3);border-top:1px solid var(--color-border)}.skill-detail-icon{width:56px;height:56px;border-radius:var(--radius-md);background:var(--color-primary-subtle);display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin-bottom:var(--space-2)}.skill-detail-meta{display:flex;gap:var(--space-4);font-size:.8125rem;color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.skill-detail-desc{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-4)}.skill-detail-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:var(--space-2)}.skill-detail-instructions{background:var(--color-surface-elevated);border-radius:var(--radius-sm);padding:var(--space-3);font-size:.8125rem;font-family:SF Mono,Fira Code,monospace;color:var(--color-text-primary);line-height:1.5;white-space:pre-wrap;word-break:break-word;margin-bottom:var(--space-4);max-height:200px;overflow-y:auto}.skill-detail-actions{display:flex;gap:var(--space-3);align-items:center}.skill-stars{display:flex;gap:2px}.skill-star{width:20px;height:20px;border:none;background:transparent;cursor:pointer;padding:0;color:var(--color-border);transition:color .1s}.skill-star.filled,.skill-star:hover{color:#f59e0b}.skill-stars-display{display:flex;gap:1px;align-items:center}.skill-stars-display .star-filled{color:#f59e0b;font-size:.75rem}.skill-stars-display .star-empty{color:var(--color-border);font-size:.75rem}.skill-rating-section{border-top:1px solid var(--color-border);padding-top:var(--space-4)}.skill-rating-row{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.skill-rating-label{font-size:.8125rem;color:var(--color-text-secondary)}.skill-tags{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.skill-tag{font-size:.6875rem;padding:2px 8px;border-radius:var(--radius-full);background:var(--color-surface-elevated);color:var(--color-text-secondary)}.skills-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-6);font-size:.8125rem;color:var(--color-text-secondary)}.skills-pagination button{padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-surface);cursor:pointer;font-size:.8125rem;color:var(--color-text-primary);transition:all .15s}.skills-pagination button:disabled{opacity:.4;cursor:not-allowed}.skills-pagination button:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:768px){.skills{padding:var(--space-4) var(--space-3)}.skills-grid{grid-template-columns:1fr}.skills-tabs{overflow-x:auto}.skills-filters,.skills-form-row{flex-direction:column}}.eph-container{position:fixed;inset:0;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#050510;z-index:9999}.eph-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;mix-blend-mode:screen;will-change:transform}.eph-blob-1{width:600px;height:600px;background:radial-gradient(circle,#1a0a4e 0%,#2d1b69 40%,transparent 70%);top:-10%;left:-10%;animation:blob-dance-1 12s ease-in-out infinite}.eph-blob-2{width:500px;height:500px;background:radial-gradient(circle,#0a2a4e 0%,#0d3868 40%,transparent 70%);bottom:-15%;right:-5%;animation:blob-dance-2 15s ease-in-out infinite}.eph-blob-3{width:450px;height:450px;background:radial-gradient(circle,#1a044e 0%,#4a1a6e 40%,transparent 70%);top:30%;right:15%;animation:blob-dance-3 18s ease-in-out infinite}.eph-blob-4{width:550px;height:550px;background:radial-gradient(circle,#041e3e 0%,#0a3a5e 40%,transparent 70%);bottom:10%;left:20%;animation:blob-dance-4 14s ease-in-out infinite}.eph-blob-5{width:350px;height:350px;background:radial-gradient(circle,#2a0a3e 0%,#5a2080 40%,transparent 70%);top:60%;left:60%;animation:blob-dance-5 20s ease-in-out infinite}.eph-blob-6{width:400px;height:400px;background:radial-gradient(circle,#0a1a3e 0%,#1a4a6e 40%,transparent 70%);top:5%;right:30%;animation:blob-dance-6 16s ease-in-out infinite}@keyframes blob-dance-1{0%{transform:translateZ(0) scale(1)}25%{transform:translate3d(120px,80px,0) scale(1.2)}50%{transform:translate3d(60px,160px,0) scale(.9)}75%{transform:translate3d(-40px,60px,0) scale(1.15)}to{transform:translateZ(0) scale(1)}}@keyframes blob-dance-2{0%{transform:translateZ(0) scale(1)}20%{transform:translate3d(-100px,-60px,0) scale(1.1)}40%{transform:translate3d(-160px,40px,0) scale(1.25)}60%{transform:translate3d(-60px,-120px,0) scale(.85)}80%{transform:translate3d(40px,-40px,0) scale(1.15)}to{transform:translateZ(0) scale(1)}}@keyframes blob-dance-3{0%{transform:translateZ(0) scale(1) rotate(0)}33%{transform:translate3d(-80px,100px,0) scale(1.3) rotate(30deg)}66%{transform:translate3d(60px,-80px,0) scale(.8) rotate(-20deg)}to{transform:translateZ(0) scale(1) rotate(0)}}@keyframes blob-dance-4{0%{transform:translateZ(0) scale(1)}30%{transform:translate3d(80px,-100px,0) scale(1.2)}60%{transform:translate3d(-120px,-60px,0) scale(.9)}to{transform:translateZ(0) scale(1)}}@keyframes blob-dance-5{0%{transform:translateZ(0) scale(1) rotate(0)}25%{transform:translate3d(-100px,-80px,0) scale(1.4) rotate(45deg)}50%{transform:translate3d(40px,-140px,0) scale(.7) rotate(0)}75%{transform:translate3d(80px,20px,0) scale(1.2) rotate(-30deg)}to{transform:translateZ(0) scale(1) rotate(0)}}@keyframes blob-dance-6{0%{transform:translateZ(0) scale(1)}35%{transform:translate3d(60px,120px,0) scale(1.15)}70%{transform:translate3d(-80px,40px,0) scale(.85)}to{transform:translateZ(0) scale(1)}}.eph-particles{position:absolute;inset:0;pointer-events:none}.eph-particle{position:absolute;border-radius:50%;animation:eph-twinkle-drift linear infinite;will-change:transform,opacity}.eph-particle--sm{width:2px;height:2px;background:#ffffffb3}.eph-particle--md{width:3px;height:3px;background:#c8dcffcc;box-shadow:0 0 4px #c8dcff66}.eph-particle--lg{width:4px;height:4px;background:#b4c8ffe6;box-shadow:0 0 8px #b4c8ff80,0 0 16px #b4c8ff33}@keyframes eph-twinkle-drift{0%{transform:translateZ(0) scale(1);opacity:0}5%{opacity:var(--star-opacity, .6)}20%{opacity:calc(var(--star-opacity, .6) * .3);transform:translate3d(calc(var(--drift-x, 10px) * .2),calc(var(--drift-y, -100vh) * .2),0) scale(var(--star-pulse, 1.2))}40%{opacity:var(--star-opacity, .6);transform:translate3d(calc(var(--drift-x, 10px) * .4),calc(var(--drift-y, -100vh) * .4),0) scale(.8)}60%{opacity:calc(var(--star-opacity, .6) * .5);transform:translate3d(calc(var(--drift-x, 10px) * .6),calc(var(--drift-y, -100vh) * .6),0) scale(var(--star-pulse, 1.2))}80%{opacity:var(--star-opacity, .6);transform:translate3d(calc(var(--drift-x, 10px) * .8),calc(var(--drift-y, -100vh) * .8),0) scale(.9)}95%{opacity:calc(var(--star-opacity, .6) * .2)}to{transform:translate3d(var(--drift-x, 10px),var(--drift-y, -100vh),0) scale(1);opacity:0}}.eph-particle:nth-child(1){left:2%;bottom:-3%;animation-duration:14s;animation-delay:0s;--star-opacity: .7;--drift-x: 20px;--drift-y: -105vh;--star-pulse: 1.5}.eph-particle:nth-child(2){left:6%;bottom:-8%;animation-duration:20s;animation-delay:.8s;--star-opacity: .4;--drift-x: -15px;--drift-y: -110vh;--star-pulse: 1.2}.eph-particle:nth-child(3){left:10%;bottom:-2%;animation-duration:16s;animation-delay:2.5s;--star-opacity: .8;--drift-x: 30px;--drift-y: -108vh;--star-pulse: 1.8}.eph-particle:nth-child(4){left:14%;bottom:-6%;animation-duration:22s;animation-delay:1.2s;--star-opacity: .3;--drift-x: -25px;--drift-y: -103vh;--star-pulse: 1.1}.eph-particle:nth-child(5){left:18%;bottom:-4%;animation-duration:13s;animation-delay:3.8s;--star-opacity: .9;--drift-x: 12px;--drift-y: -115vh;--star-pulse: 1.6}.eph-particle:nth-child(6){left:22%;bottom:-7%;animation-duration:19s;animation-delay:.3s;--star-opacity: .5;--drift-x: -18px;--drift-y: -106vh;--star-pulse: 1.3}.eph-particle:nth-child(7){left:26%;bottom:-1%;animation-duration:15s;animation-delay:4.5s;--star-opacity: .7;--drift-x: 35px;--drift-y: -112vh;--star-pulse: 1.4}.eph-particle:nth-child(8){left:30%;bottom:-5%;animation-duration:21s;animation-delay:1.8s;--star-opacity: .6;--drift-x: -22px;--drift-y: -104vh;--star-pulse: 1.7}.eph-particle:nth-child(9){left:34%;bottom:-3%;animation-duration:17s;animation-delay:5.2s;--star-opacity: .4;--drift-x: 8px;--drift-y: -109vh;--star-pulse: 1.2}.eph-particle:nth-child(10){left:38%;bottom:-8%;animation-duration:23s;animation-delay:.6s;--star-opacity: .8;--drift-x: -12px;--drift-y: -107vh;--star-pulse: 1.5}.eph-particle:nth-child(11){left:42%;bottom:-2%;animation-duration:14s;animation-delay:3.1s;--star-opacity: .3;--drift-x: 28px;--drift-y: -113vh;--star-pulse: 1.1}.eph-particle:nth-child(12){left:46%;bottom:-6%;animation-duration:18s;animation-delay:6s;--star-opacity: .9;--drift-x: -30px;--drift-y: -102vh;--star-pulse: 1.9}.eph-particle:nth-child(13){left:50%;bottom:-4%;animation-duration:16s;animation-delay:1.5s;--star-opacity: .5;--drift-x: 18px;--drift-y: -111vh;--star-pulse: 1.3}.eph-particle:nth-child(14){left:54%;bottom:-7%;animation-duration:24s;animation-delay:4s;--star-opacity: .7;--drift-x: -20px;--drift-y: -105vh;--star-pulse: 1.6}.eph-particle:nth-child(15){left:58%;bottom:-1%;animation-duration:13s;animation-delay:2.2s;--star-opacity: .6;--drift-x: 25px;--drift-y: -116vh;--star-pulse: 1.4}.eph-particle:nth-child(16){left:62%;bottom:-5%;animation-duration:20s;animation-delay:7s;--star-opacity: .4;--drift-x: -14px;--drift-y: -108vh;--star-pulse: 1.2}.eph-particle:nth-child(17){left:66%;bottom:-3%;animation-duration:15s;animation-delay:.9s;--star-opacity: .8;--drift-x: 32px;--drift-y: -110vh;--star-pulse: 1.7}.eph-particle:nth-child(18){left:70%;bottom:-8%;animation-duration:22s;animation-delay:3.5s;--star-opacity: .3;--drift-x: -28px;--drift-y: -103vh;--star-pulse: 1.1}.eph-particle:nth-child(19){left:74%;bottom:-2%;animation-duration:17s;animation-delay:5.8s;--star-opacity: .7;--drift-x: 10px;--drift-y: -114vh;--star-pulse: 1.5}.eph-particle:nth-child(20){left:78%;bottom:-6%;animation-duration:19s;animation-delay:1.1s;--star-opacity: .5;--drift-x: -16px;--drift-y: -106vh;--star-pulse: 1.3}.eph-particle:nth-child(21){left:82%;bottom:-4%;animation-duration:14s;animation-delay:4.8s;--star-opacity: .9;--drift-x: 22px;--drift-y: -109vh;--star-pulse: 1.8}.eph-particle:nth-child(22){left:86%;bottom:-7%;animation-duration:21s;animation-delay:2s;--star-opacity: .4;--drift-x: -24px;--drift-y: -112vh;--star-pulse: 1.2}.eph-particle:nth-child(23){left:90%;bottom:-1%;animation-duration:16s;animation-delay:6.5s;--star-opacity: .6;--drift-x: 15px;--drift-y: -107vh;--star-pulse: 1.4}.eph-particle:nth-child(24){left:94%;bottom:-5%;animation-duration:23s;animation-delay:.4s;--star-opacity: .8;--drift-x: -10px;--drift-y: -115vh;--star-pulse: 1.6}.eph-particle:nth-child(25){left:97%;bottom:-3%;animation-duration:18s;animation-delay:3.3s;--star-opacity: .5;--drift-x: 26px;--drift-y: -104vh;--star-pulse: 1.3}.eph-particle:nth-child(26){left:4%;bottom:-9%;animation-duration:25s;animation-delay:7.5s;--star-opacity: .6;--drift-x: -8px;--drift-y: -118vh;--star-pulse: 1.5}.eph-particle:nth-child(27){left:12%;bottom:-1%;animation-duration:12s;animation-delay:8s;--star-opacity: .9;--drift-x: 40px;--drift-y: -105vh;--star-pulse: 2}.eph-particle:nth-child(28){left:24%;bottom:-4%;animation-duration:20s;animation-delay:2.8s;--star-opacity: .3;--drift-x: -35px;--drift-y: -110vh;--star-pulse: 1.1}.eph-particle:nth-child(29){left:36%;bottom:-7%;animation-duration:15s;animation-delay:5.5s;--star-opacity: .7;--drift-x: 16px;--drift-y: -113vh;--star-pulse: 1.6}.eph-particle:nth-child(30){left:44%;bottom:-2%;animation-duration:18s;animation-delay:1.4s;--star-opacity: .5;--drift-x: -20px;--drift-y: -108vh;--star-pulse: 1.3}.eph-particle:nth-child(31){left:52%;bottom:-6%;animation-duration:22s;animation-delay:4.2s;--star-opacity: .8;--drift-x: 24px;--drift-y: -106vh;--star-pulse: 1.7}.eph-particle:nth-child(32){left:60%;bottom:-3%;animation-duration:13s;animation-delay:6.8s;--star-opacity: .4;--drift-x: -18px;--drift-y: -112vh;--star-pulse: 1.2}.eph-particle:nth-child(33){left:68%;bottom:-8%;animation-duration:24s;animation-delay:.7s;--star-opacity: .6;--drift-x: 14px;--drift-y: -104vh;--star-pulse: 1.4}.eph-particle:nth-child(34){left:76%;bottom:-1%;animation-duration:16s;animation-delay:3.9s;--star-opacity: .9;--drift-x: -32px;--drift-y: -117vh;--star-pulse: 1.9}.eph-particle:nth-child(35){left:84%;bottom:-5%;animation-duration:19s;animation-delay:7.8s;--star-opacity: .3;--drift-x: 20px;--drift-y: -109vh;--star-pulse: 1.1}.eph-particle:nth-child(36){left:16%;bottom:-6%;animation-duration:26s;animation-delay:9s;--star-opacity: .7;--drift-x: -12px;--drift-y: -111vh;--star-pulse: 1.5}.eph-particle:nth-child(37){left:40%;bottom:-3%;animation-duration:14s;animation-delay:8.5s;--star-opacity: .5;--drift-x: 28px;--drift-y: -107vh;--star-pulse: 1.3}.eph-particle:nth-child(38){left:56%;bottom:-7%;animation-duration:21s;animation-delay:9.5s;--star-opacity: .8;--drift-x: -22px;--drift-y: -114vh;--star-pulse: 1.6}.eph-particle:nth-child(39){left:72%;bottom:-2%;animation-duration:17s;animation-delay:10s;--star-opacity: .4;--drift-x: 36px;--drift-y: -103vh;--star-pulse: 1.2}.eph-particle:nth-child(40){left:92%;bottom:-4%;animation-duration:15s;animation-delay:8.2s;--star-opacity: .6;--drift-x: -26px;--drift-y: -116vh;--star-pulse: 1.8}.eph-scene{position:absolute;max-width:700px;padding:0 2rem;text-align:center;opacity:0;transition:opacity 1.5s ease;z-index:2}.eph-scene.eph-visible{opacity:1}.eph-quote-text{font-family:Georgia,Times New Roman,serif;font-size:2.2rem;font-weight:300;line-height:1.5;color:#ffffffeb;letter-spacing:.01em;margin:0 0 1.5rem}.eph-quote-attribution{font-family:Georgia,Times New Roman,serif;font-size:1rem;font-style:italic;color:#ffffff73;letter-spacing:.05em}.eph-statement{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.8rem;font-weight:600;line-height:1.5;color:#ffffffe0;margin:0}.eph-blackout{position:fixed;inset:0;background:#000;opacity:0;transition:opacity 2s ease;pointer-events:none;z-index:10000}.eph-blackout.eph-active{opacity:1}@media(max-width:600px){.eph-quote-text{font-size:1.5rem}.eph-quote-attribution{font-size:.85rem}.eph-statement{font-size:1.3rem}.eph-scene{padding:0 1.25rem}.eph-blob{filter:blur(60px)}}
