@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";.bento-header{padding:var(--space-md) var(--space-lg);position:sticky;top:0;z-index:var(--z-sticky);background:transparent}.header-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-neu-out);border:1px solid var(--border-light)}.header-brand{display:flex;align-items:center;gap:var(--space-md)}.brand-logo{position:relative;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);border-radius:var(--radius-lg);color:#fff;box-shadow:0 4px 15px var(--accent-glow)}.logo-glow{position:absolute;inset:-4px;background:var(--accent-gradient);border-radius:var(--radius-lg);filter:blur(12px);opacity:.4;z-index:-1;animation:pulse 3s ease-in-out infinite}.brand-text{display:flex;flex-direction:column;gap:2px}.brand-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin:0}.brand-time{display:flex;align-items:center;gap:8px;font-size:.8rem}.time-value{font-weight:600;color:var(--accent-color);font-variant-numeric:tabular-nums}.time-dot{width:6px;height:6px;background:var(--success);border-radius:50%;animation:pulse 2s ease-in-out infinite}.time-label{color:var(--text-muted);font-weight:500}.header-actions{display:flex;align-items:center;gap:var(--space-sm)}.action-btn{display:flex;align-items:center;gap:8px;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:none}.action-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color);transform:translateY(-1px);box-shadow:var(--shadow-neu-out-sm)}.lang-btn{min-width:140px}.lang-flag{font-size:1.1rem}.lang-name{flex:1;text-align:left}.dropdown-arrow{transition:transform var(--transition-fast);color:var(--text-muted)}.dropdown-arrow.open{transform:rotate(180deg)}.theme-btn{width:44px;height:44px;padding:0;justify-content:center;overflow:hidden}.theme-icon-wrapper{position:relative;width:18px;height:18px}.theme-icon{position:absolute;top:0;left:0;transition:all var(--transition-base)}.theme-icon.sun{opacity:0;transform:rotate(-90deg) scale(.5)}.theme-icon.moon{opacity:0;transform:rotate(90deg) scale(.5)}.theme-icon.active{opacity:1;transform:rotate(0) scale(1)}.dropdown-wrapper{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);padding:var(--space-xs);z-index:var(--z-dropdown);overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:none}.dropdown-item:hover{background:var(--bg-tertiary);transform:none}.dropdown-item.active{background:var(--accent-gradient);color:#fff}.item-flag{font-size:1.1rem}.item-name{flex:1;text-align:left}@media(max-width:640px){.bento-header{padding:var(--space-sm)}.header-container{padding:var(--space-sm) var(--space-md);flex-wrap:wrap;gap:var(--space-sm)}.header-brand{flex:1;min-width:0}.brand-logo{width:40px;height:40px;min-width:40px;flex-shrink:0}.brand-logo svg{width:20px;height:20px}.brand-title{font-size:.95rem;overflow:visible;text-overflow:unset;white-space:normal;word-wrap:break-word;line-height:1.2;max-width:none}.brand-time{display:none}.lang-btn{min-width:auto;padding:var(--space-xs) var(--space-sm)}.lang-name{display:none}.theme-btn{width:38px;height:38px}}.bento-controls{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);margin:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-neu-out);border:1px solid var(--border-light);gap:var(--space-lg);flex-wrap:wrap}.controls-nav{display:flex;align-items:center;gap:var(--space-sm)}.nav-buttons{display:flex;gap:var(--space-xs)}.nav-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);padding:0;cursor:pointer;transition:all var(--transition-fast);box-shadow:none}.nav-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color);color:var(--accent-color);transform:scale(1.05);box-shadow:var(--shadow-neu-out-sm)}.nav-btn:active{transform:scale(.95)}.today-btn,.shared-btn{display:flex;align-items:center;gap:6px;padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-full);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.today-btn{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px var(--accent-glow)}.today-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.today-btn:active{transform:translateY(0)}.shared-btn{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:none}.shared-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-neu-out-sm)}.btn-text{position:relative;z-index:1}.controls-period{display:flex;align-items:center;gap:var(--space-md);flex:1;justify-content:center}.period-day{font-size:3rem;font-weight:800;color:var(--text-primary);line-height:1;background:linear-gradient(135deg,var(--accent-start),var(--accent-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.period-details{display:flex;flex-direction:column;gap:2px}.period-weekday{font-size:1rem;font-weight:600;color:var(--text-primary);text-transform:capitalize}.period-month{font-size:.875rem;color:var(--text-secondary);text-transform:capitalize}.controls-views{display:flex;align-items:center}.view-switcher{display:flex;position:relative;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:4px}.view-btn{display:flex;align-items:center;gap:6px;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-full);color:var(--text-secondary);font-weight:500;font-size:.8rem;cursor:pointer;transition:color var(--transition-fast);position:relative;z-index:2;box-shadow:none}.view-btn:hover{color:var(--text-primary);transform:none;box-shadow:none}.view-btn.active{color:#fff}.view-indicator{position:absolute;top:4px;left:4px;height:calc(100% - 8px);background:var(--accent-gradient);border-radius:var(--radius-full);transition:transform var(--transition-bounce);z-index:1;box-shadow:0 2px 8px var(--accent-glow)}.view-label{display:none}@media(min-width:900px){.view-label{display:inline}}@media(max-width:768px){.bento-controls{margin:var(--space-sm);padding:var(--space-md);gap:var(--space-md)}.controls-period{order:-1;width:100%;justify-content:flex-start;padding-bottom:var(--space-md);border-bottom:1px solid var(--border-light)}.period-day{font-size:2.5rem}.controls-nav{flex:1}.controls-views{flex:1;justify-content:flex-end}.view-btn{padding:var(--space-sm)}}@media(max-width:480px){.today-btn,.shared-btn{padding:var(--space-xs) var(--space-sm);font-size:.75rem}.shared-btn .btn-text{display:none}.shared-btn{width:36px;height:36px;padding:0;justify-content:center}.period-day{font-size:2rem}.period-weekday{font-size:.875rem}.period-month{font-size:.75rem}.nav-btn{width:36px;height:36px}}.shift-chip.compact{display:flex;flex-direction:column;padding:4px 8px;border-radius:var(--radius-md);background:var(--chip-color);color:var(--chip-text);font-weight:600;transition:transform var(--transition-fast),box-shadow var(--transition-fast);cursor:default;box-shadow:0 2px 6px #00000026;width:100%;position:relative}.shift-chip.compact:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000040;z-index:10}.shift-chip.compact .chip-moon{position:absolute;top:2px;right:3px;opacity:.8}.chip-desktop{display:flex;flex-direction:column;gap:2px}.chip-time-full{font-size:.7rem;font-weight:700;white-space:nowrap}.chip-title-full{font-size:.65rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.95}.chip-mobile{display:none;flex-direction:row;align-items:center;gap:4px}.chip-time-short{font-size:.6rem;font-weight:700;flex-shrink:0}.chip-title-short{font-size:.55rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.shift-chip.expanded{display:flex;background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);border:1px solid var(--border-light);transition:transform var(--transition-base),box-shadow var(--transition-base)}.shift-chip.expanded:hover{transform:translateY(-2px) scale(1.01);box-shadow:var(--shadow-hover)}.shift-chip.expanded.continuation{opacity:.85;border-style:dashed}.chip-color-bar{width:5px;flex-shrink:0;border-radius:var(--radius-full);margin:8px 0 8px 8px}.chip-content{flex:1;padding:var(--space-sm) var(--space-md);display:flex;flex-direction:column;gap:4px;min-width:0}.chip-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.chip-time-wrapper{display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.chip-clock-icon{opacity:.7;flex-shrink:0}.chip-time-text{font-size:.8rem;font-weight:600;letter-spacing:.02em}.chip-overnight-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-tertiary);border-radius:var(--radius-full);color:var(--accent-color)}html.dark .chip-overnight-badge{background:#8b5cf626}.chip-title-row{display:flex;align-items:center;gap:var(--space-sm)}.chip-title-text{font-size:1rem;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-continues{font-size:.7rem;color:var(--text-muted);font-style:italic}.chip-notes{font-size:.8rem;color:var(--text-muted);line-height:1.4;padding-top:4px;border-top:1px solid var(--border-light);margin-top:4px}@media(max-width:768px){.shift-chip.expanded{border-radius:var(--radius-md)}.chip-content{padding:var(--space-xs) var(--space-sm)}.chip-title-text{font-size:.9rem}.chip-time-text{font-size:.75rem}.chip-desktop{display:none}.chip-mobile{display:flex}.shift-chip.compact{padding:3px 6px;border-radius:var(--radius-sm)}.shift-chip.compact .chip-moon{display:none}}@media(max-width:480px){.shift-chip.compact{padding:2px 4px}.chip-time-short{font-size:.55rem}.chip-title-short{font-size:.5rem}}.mobile-shift-chip{display:inline-flex;align-items:center;justify-content:center;gap:1px;padding:3px 6px;border-radius:4px;background:var(--chip-bg);color:var(--chip-text);font-weight:700;font-size:.65rem;line-height:1;white-space:nowrap;box-shadow:0 1px 3px #0003;transition:transform .15s ease,box-shadow .15s ease;cursor:default;width:100%;box-sizing:border-box;min-height:18px}.mobile-shift-chip:hover{transform:scale(1.02);box-shadow:0 2px 6px #00000040;z-index:10}.mobile-shift-chip.overnight{border:1px dashed rgba(255,255,255,.5)}.mobile-shift-chip.continuation{opacity:.85}.mobile-chip-prefix{font-size:.55rem;opacity:.9;margin-right:1px}.mobile-chip-time{font-weight:700;letter-spacing:-.02em}@media(max-width:400px){.mobile-shift-chip{padding:2px 4px;font-size:.6rem;min-height:16px;border-radius:3px}.mobile-chip-prefix{font-size:.5rem}}@media(min-width:401px)and (max-width:600px){.mobile-shift-chip{padding:3px 8px;font-size:.7rem}}.calendar-container{padding:0 var(--space-lg) var(--space-xl);width:100%;max-width:1400px;margin:0 auto;box-sizing:border-box}.calendar-grid{display:grid;gap:var(--space-md);animation:fadeIn var(--transition-slow) ease-out}.calendar-grid.week-view{grid-template-columns:1fr}@media(min-width:768px){.calendar-grid.week-view{grid-template-columns:repeat(7,1fr);gap:var(--space-sm)}}.month-view-wrapper{display:flex;flex-direction:column;gap:var(--space-lg)}.calendar-grid.month-view{grid-template-columns:repeat(7,1fr);gap:6px}.calendar-grid.day-view{max-width:600px;margin:0 auto}.weekday-header{padding:var(--space-sm) var(--space-xs);text-align:center;font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.day-card{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-light);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-fast);display:flex;flex-direction:column}.day-card:hover{box-shadow:var(--shadow-hover);border-color:var(--accent-color)}.day-card.clickable{cursor:pointer}.day-card.clickable:hover{transform:translateY(-2px)}.day-card.today{border:2px solid var(--accent-color);box-shadow:0 0 0 4px var(--accent-glow),var(--shadow-card)}.day-card.today .day-number{background:var(--accent-gradient);color:#fff}.day-card.selected{border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-glow)}.day-card.outside-month{opacity:.4}.day-card.outside-month:hover{opacity:.6;transform:none;box-shadow:none}.day-card.month-day{min-height:120px}.day-header{padding:var(--space-sm) var(--space-md);display:flex;align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--border-light);background:var(--bg-tertiary)}.day-name{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.day-number{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--space-xs);font-size:.95rem;font-weight:700;color:var(--text-primary);background:var(--bg-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.month-day .day-header{padding:var(--space-xs) var(--space-sm);border-bottom:none;background:transparent}.month-day .day-number{min-width:28px;height:28px;font-size:.9rem;background:transparent}.week-view .day-header,.day-view .day-header{flex-direction:column;align-items:center;padding:var(--space-md);gap:var(--space-xs)}.week-view .day-number,.day-view .day-number{font-size:1.5rem;min-width:48px;height:48px;border-radius:var(--radius-lg)}.day-view .day-header{padding:var(--space-lg)}.day-view .day-number{font-size:3rem;min-width:80px;height:80px;border-radius:var(--radius-xl);background:var(--accent-gradient);color:#fff;box-shadow:0 8px 24px var(--accent-glow)}.day-view .day-name{font-size:1rem;order:-1}.day-content{padding:var(--space-xs);display:flex;flex-direction:column;gap:4px;flex-grow:1}.shifts-desktop{display:flex;flex-direction:column;gap:4px}.shifts-mobile{display:none;flex-direction:column;gap:3px}.more-shifts-indicator{font-size:.6rem;font-weight:700;color:var(--accent-color);text-align:center;padding:2px 6px;background:var(--accent-glow);border-radius:var(--radius-full);cursor:pointer}.week-view .day-content,.day-view .day-content{padding:var(--space-md);gap:var(--space-sm);min-height:120px;align-items:stretch}.day-view .day-content{padding:var(--space-lg);gap:var(--space-md);min-height:auto}.empty-day{display:flex;align-items:center;justify-content:center;flex-grow:1;color:var(--text-muted);font-size:.8rem;font-style:italic;padding:var(--space-lg);text-align:center}.week-view .empty-day,.day-view .empty-day{font-size:.9rem;padding:var(--space-xl)}.day-view .empty-day{flex-direction:column;gap:var(--space-md)}.empty-icon{width:64px;height:64px;background:var(--bg-tertiary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:var(--space-sm)}.day-details-panel{display:none;background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-neu-out);border:1px solid var(--border-light);overflow:hidden}.details-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);background:var(--bg-tertiary)}.details-date{display:flex;align-items:center;gap:var(--space-md)}.details-day-number{font-size:2rem;font-weight:800;color:var(--accent-color);line-height:1}.details-date-text{display:flex;flex-direction:column;gap:2px}.details-weekday{font-size:1rem;font-weight:600;color:var(--text-primary);text-transform:capitalize}.details-month{font-size:.8rem;color:var(--text-secondary);text-transform:capitalize}.details-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);padding:0;cursor:pointer;transition:all var(--transition-fast)}.details-close:hover{background:var(--bg-tertiary);color:var(--text-primary);box-shadow:none;transform:none}.details-shifts{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);max-height:300px;overflow-y:auto}@media(max-width:768px){.calendar-container{padding:0 var(--space-sm) var(--space-lg)}.calendar-grid.month-view{gap:3px}.day-card{border-radius:var(--radius-md)}.day-card.month-day{min-height:70px}.day-header{padding:var(--space-xs)}.day-number{min-width:24px;height:24px;font-size:.8rem;border-radius:var(--radius-sm)}.day-name{display:none}.week-view .day-name{display:block}.shifts-desktop{display:none}.shifts-mobile{display:flex}.day-details-panel{display:block}}@media(max-width:480px){.calendar-grid.month-view{gap:2px}.day-card.month-day{min-height:60px;border-radius:var(--radius-sm)}.month-day .day-header{padding:2px}.month-day .day-number{min-width:20px;height:20px;font-size:.7rem}.month-day .day-content{padding:2px}.weekday-header{font-size:.6rem;padding:var(--space-xs) 0;letter-spacing:0}.more-shifts-indicator{font-size:.5rem;padding:1px 4px}.details-header{padding:var(--space-sm) var(--space-md)}.details-day-number{font-size:1.5rem}.details-weekday{font-size:.9rem}}.floating-today-btn{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;border-radius:50%;background:var(--accent-gradient);color:#fff;border:none;box-shadow:0 4px 16px rgba(var(--accent-rgb),.4);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:100;transition:all .3s cubic-bezier(.34,1.56,.64,1);opacity:0;transform:translateY(20px) scale(.9);pointer-events:none}.floating-today-btn.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.floating-today-btn:active{transform:scale(.95)}@media(max-width:768px){.floating-today-btn{display:flex}}.day-view .day-card{border:none;background:transparent;box-shadow:none;overflow:visible}.day-view .day-header{flex-direction:row;align-items:center;justify-content:flex-start;padding:var(--space-md) var(--space-lg);gap:var(--space-md);background:transparent;border-bottom:none}.day-view .day-number{font-size:3.5rem;font-weight:800;line-height:1;min-width:auto;height:auto;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding:0;border-radius:0;box-shadow:none;letter-spacing:-2px}.day-view .day-text-group{display:flex;flex-direction:column;justify-content:center}.day-view .day-name{font-size:1.2rem;font-weight:700;color:var(--text-primary);text-transform:capitalize;letter-spacing:-.5px;order:0}.day-view .day-month-year{font-size:.9rem;color:var(--text-secondary);font-weight:500}.day-view .day-content{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--space-lg);box-shadow:var(--shadow-sm);min-height:200px;border:1px solid var(--border-light)}.day-view .day-card.today{border:none;box-shadow:none;background:transparent}.day-view .day-card.today .day-number{background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;box-shadow:none;border:none}.app-wrapper{display:flex;flex-direction:column;min-height:100vh;width:100%}.state-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg)}.state-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-3xl);background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-neu-out);border:1px solid var(--border-light);max-width:400px;width:100%}.state-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:var(--space-lg) 0 var(--space-sm)}.state-message{color:var(--text-secondary);font-size:.95rem;margin:0}.loading-animation{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.loading-ring{position:absolute;inset:0;border-radius:50%;border:4px solid var(--border-color);border-top-color:var(--accent-color);animation:spin 1s linear infinite}.loading-icon{color:var(--accent-color);animation:pulse 2s ease-in-out infinite}.error-icon-wrapper{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border-radius:50%;color:var(--error)}html.dark .error-icon-wrapper{background:#ef444426}.retry-btn{margin-top:var(--space-lg);padding:var(--space-sm) var(--space-xl);background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-full);font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 15px var(--accent-glow)}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.more-shifts{font-size:.65rem;font-weight:600;color:var(--text-muted);text-align:center;padding:2px 8px;background:var(--bg-tertiary);border-radius:var(--radius-full);margin-top:2px}:root{--bg-primary: #F8FAFF;--bg-secondary: #FFFFFF;--bg-tertiary: #F1F5F9;--text-primary: #1A1A2E;--text-secondary: #6B7280;--text-muted: #9CA3AF;--accent-start: #8B5CF6;--accent-end: #3B82F6;--accent-color: #8B5CF6;--accent-gradient: linear-gradient(135deg, var(--accent-start) 0%, var(--accent-end) 100%);--accent-glow: rgba(139, 92, 246, .3);--border-color: #E5E7EB;--border-light: #F3F4F6;--success: #10B981;--warning: #F59E0B;--error: #EF4444;--shadow-neu-out: 6px 6px 16px rgba(163, 177, 198, .4), -6px -6px 16px rgba(255, 255, 255, .9);--shadow-neu-out-sm: 3px 3px 8px rgba(163, 177, 198, .3), -3px -3px 8px rgba(255, 255, 255, .8);--shadow-neu-in: inset 3px 3px 8px rgba(163, 177, 198, .3), inset -3px -3px 8px rgba(255, 255, 255, .8);--shadow-float: 0 20px 40px rgba(0, 0, 0, .08), 0 10px 20px rgba(0, 0, 0, .04);--shadow-card: 0 4px 20px rgba(0, 0, 0, .06), 0 2px 8px rgba(0, 0, 0, .04);--shadow-hover: 0 8px 30px rgba(139, 92, 246, .15), 0 4px 12px rgba(0, 0, 0, .05);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-tooltip: 400}html.dark{--bg-primary: #0F0F1A;--bg-secondary: #1A1A2E;--bg-tertiary: #252542;--text-primary: #F8FAFF;--text-secondary: #9CA3AF;--text-muted: #6B7280;--accent-start: #A78BFA;--accent-end: #60A5FA;--accent-color: #A78BFA;--accent-glow: rgba(167, 139, 250, .25);--border-color: #2D2D44;--border-light: #3D3D5C;--shadow-neu-out: 6px 6px 16px rgba(0, 0, 0, .5), -6px -6px 16px rgba(60, 60, 90, .15);--shadow-neu-out-sm: 3px 3px 8px rgba(0, 0, 0, .4), -3px -3px 8px rgba(60, 60, 90, .1);--shadow-neu-in: inset 3px 3px 8px rgba(0, 0, 0, .4), inset -3px -3px 8px rgba(60, 60, 90, .1);--shadow-float: 0 20px 40px rgba(0, 0, 0, .4), 0 10px 20px rgba(0, 0, 0, .2);--shadow-card: 0 4px 20px rgba(0, 0, 0, .3), 0 2px 8px rgba(0, 0, 0, .2);--shadow-hover: 0 8px 30px rgba(139, 92, 246, .2), 0 4px 12px rgba(0, 0, 0, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Outfit,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh;min-width:320px;background:var(--bg-primary);position:relative;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 20% -20%,rgba(139,92,246,.15) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 0%,rgba(59,130,246,.12) 0%,transparent 45%),radial-gradient(ellipse 50% 30% at 10% 100%,rgba(236,72,153,.08) 0%,transparent 40%);pointer-events:none;z-index:-1;animation:gradientShift 20s ease-in-out infinite alternate}html.dark body:before{background:radial-gradient(ellipse 80% 50% at 20% -20%,rgba(139,92,246,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 0%,rgba(59,130,246,.06) 0%,transparent 45%),radial-gradient(ellipse 50% 30% at 90% 100%,rgba(236,72,153,.04) 0%,transparent 40%)}#root{width:100%;max-width:1400px;margin:0 auto;display:flex;flex-direction:column;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:700;letter-spacing:-.02em;line-height:1.2;color:var(--text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{color:var(--text-secondary);font-size:1rem}button{font-family:"Outfit",inherit;font-weight:500;font-size:.9rem;cursor:pointer;border:none;outline:none;background:var(--bg-secondary);color:var(--text-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);box-shadow:var(--shadow-neu-out-sm);transition:transform var(--transition-fast),box-shadow var(--transition-base),background var(--transition-fast)}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}button:active{transform:translateY(0);box-shadow:var(--shadow-neu-in)}button.primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px var(--accent-glow),var(--shadow-neu-out-sm)}button.primary:hover{box-shadow:0 6px 20px var(--accent-glow),var(--shadow-hover)}button.icon-btn{width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.bento-card{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);border:1px solid var(--border-light);transition:transform var(--transition-base),box-shadow var(--transition-base)}.bento-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--accent-color)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}@keyframes gradientShift{0%{opacity:1}50%{opacity:.8}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes glow{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 30px var(--accent-glow),0 0 40px var(--accent-glow)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-slide-down{animation:slideDown var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-color);color:#fff}@media(max-width:768px){h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}#root{padding:var(--space-sm)}}.loading-spinner{width:48px;height:48px;border-radius:50%;background:var(--accent-gradient);position:relative;animation:spin 1s linear infinite}.loading-spinner:before{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--bg-primary)}@keyframes spin{to{transform:rotate(360deg)}}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:var(--space-xs) var(--space-sm);background:var(--text-primary);color:var(--bg-primary);font-size:.75rem;font-weight:500;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:var(--z-tooltip)}[data-tooltip]:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}
