:root{--font-main: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--text-3xs: .5rem;--text-2xs: .625rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--space-half: 2px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-smooth: .3s cubic-bezier(.16, 1, .3, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1)}[data-theme=dark]{--bg-base: #09090b;--bg-elevated: #18181b;--bg-surface: #27272a;--bg-hover: #3f3f46;--bg-header: rgba(24, 24, 27, .85);--bg-nav: rgba(24, 24, 27, .6);--bg-controls: rgba(24, 24, 27, .4);--bg-stats: rgba(39, 39, 42, .5);--bg-stat-hover: rgba(63, 63, 70, .5);--bg-segment: rgba(39, 39, 42, .6);--bg-button: rgba(39, 39, 42, .6);--bg-input: rgba(24, 24, 27, .8);--bg-input-focus: rgba(24, 24, 27, .95);--bg-card: rgba(24, 24, 27, .6);--bg-badge: rgba(39, 39, 42, .8);--bg-tooltip: rgba(24, 24, 27, .95);--bg-overlay: rgba(0, 0, 0, .7);--bg-modal: rgba(24, 24, 27, .98);--bg-action: rgba(24, 24, 27, .9);--bg-progress: rgba(39, 39, 42, .5);--bg-goal: rgba(24, 24, 27, .4);--bg-goal-hover: rgba(39, 39, 42, .5);--bg-annual-goal: rgba(24, 24, 27, .6);--bg-day: rgba(39, 39, 42, .4);--bg-day-hover: rgba(63, 63, 70, .5);--bg-event: rgba(245, 158, 11, .12);--bg-event-item: rgba(39, 39, 42, .4);--bg-event-item-hover: rgba(63, 63, 70, .5);--bg-holiday: rgba(34, 197, 94, .1);--accent: #f59e0b;--accent-dim: rgba(245, 158, 11, .15);--accent-subtle: rgba(245, 158, 11, .1);--accent-muted: rgba(245, 158, 11, .4);--accent-strong: rgba(245, 158, 11, .8);--accent-border: rgba(245, 158, 11, .3);--accent-glow: rgba(245, 158, 11, .2);--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--text-muted: #52525b;--text-on-accent: #18181b;--text-weekend: #f87171;--border: #27272a;--border-subtle: rgba(255, 255, 255, .06);--border-glass: rgba(255, 255, 255, .08);--border-shine: rgba(255, 255, 255, .04);--success: #22c55e;--success-subtle: rgba(34, 197, 94, .1);--success-border: rgba(34, 197, 94, .3);--error: #ef4444;--error-subtle: rgba(239, 68, 68, .1);--error-border: rgba(239, 68, 68, .3);--warning: #f59e0b;--warning-subtle: rgba(245, 158, 11, .1);--info: #3b82f6;--info-subtle: rgba(59, 130, 246, .1);--weekend: #f87171;--gradient-accent: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-today: linear-gradient(135deg, #f59e0b 0%, #ea580c 100%);--gradient-progress: linear-gradient(90deg, #f59e0b 0%, #d97706 100%);--gradient-card-hover: linear-gradient(135deg, rgba(245, 158, 11, .05) 0%, transparent 100%);--gradient-radial-accent: radial-gradient(ellipse at top right, rgba(245, 158, 11, .08) 0%, transparent 50%);--shadow: 0 4px 20px rgba(0, 0, 0, .5);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-elevated: 0 8px 32px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .05);--shadow-inset: inset 0 1px 2px rgba(0, 0, 0, .2);--shadow-focus: 0 0 0 3px rgba(245, 158, 11, .2);--shadow-day-hover: 0 2px 8px rgba(0, 0, 0, .3);--shadow-today: 0 2px 12px rgba(245, 158, 11, .3);--shadow-today-hover: 0 4px 16px rgba(245, 158, 11, .4);--shadow-accent: 0 4px 16px rgba(245, 158, 11, .25);--shadow-accent-sm: 0 2px 8px rgba(245, 158, 11, .2);--shadow-accent-lg: 0 8px 24px rgba(245, 158, 11, .3);--shadow-modal: 0 24px 48px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .05);--shadow-floating: 0 8px 24px rgba(0, 0, 0, .4);--shadow-floating-hover: 0 12px 32px rgba(0, 0, 0, .5)}[data-theme=light]{--bg-base: #fafafa;--bg-elevated: #ffffff;--bg-surface: #f4f4f5;--bg-hover: #e4e4e7;--bg-header: rgba(255, 255, 255, .85);--bg-nav: rgba(255, 255, 255, .6);--bg-controls: rgba(255, 255, 255, .4);--bg-stats: rgba(244, 244, 245, .8);--bg-stat-hover: rgba(228, 228, 231, .8);--bg-segment: rgba(244, 244, 245, .8);--bg-button: rgba(244, 244, 245, .8);--bg-input: rgba(255, 255, 255, .9);--bg-input-focus: rgba(255, 255, 255, 1);--bg-card: rgba(255, 255, 255, .8);--bg-badge: rgba(244, 244, 245, .9);--bg-tooltip: rgba(255, 255, 255, .98);--bg-overlay: rgba(0, 0, 0, .4);--bg-modal: rgba(255, 255, 255, .98);--bg-action: rgba(255, 255, 255, .95);--bg-progress: rgba(228, 228, 231, .5);--bg-goal: rgba(255, 255, 255, .6);--bg-goal-hover: rgba(244, 244, 245, .8);--bg-annual-goal: rgba(255, 255, 255, .8);--bg-day: rgba(244, 244, 245, .6);--bg-day-hover: rgba(228, 228, 231, .8);--bg-event: rgba(217, 119, 6, .1);--bg-event-item: rgba(244, 244, 245, .6);--bg-event-item-hover: rgba(228, 228, 231, .8);--bg-holiday: rgba(22, 163, 74, .08);--accent: #d97706;--accent-dim: rgba(217, 119, 6, .1);--accent-subtle: rgba(217, 119, 6, .08);--accent-muted: rgba(217, 119, 6, .4);--accent-strong: rgba(217, 119, 6, .9);--accent-border: rgba(217, 119, 6, .3);--accent-glow: rgba(217, 119, 6, .15);--text-primary: #18181b;--text-secondary: #52525b;--text-tertiary: #71717a;--text-muted: #a1a1aa;--text-on-accent: #ffffff;--text-weekend: #dc2626;--border: #e4e4e7;--border-subtle: rgba(0, 0, 0, .06);--border-glass: rgba(0, 0, 0, .08);--border-shine: rgba(255, 255, 255, .6);--success: #16a34a;--success-subtle: rgba(22, 163, 74, .1);--success-border: rgba(22, 163, 74, .3);--error: #dc2626;--error-subtle: rgba(220, 38, 38, .1);--error-border: rgba(220, 38, 38, .3);--warning: #d97706;--warning-subtle: rgba(217, 119, 6, .1);--info: #2563eb;--info-subtle: rgba(37, 99, 235, .1);--weekend: #dc2626;--gradient-accent: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-today: linear-gradient(135deg, #f59e0b 0%, #ea580c 100%);--gradient-progress: linear-gradient(90deg, #f59e0b 0%, #d97706 100%);--gradient-card-hover: linear-gradient(135deg, rgba(217, 119, 6, .03) 0%, transparent 100%);--gradient-radial-accent: radial-gradient(ellipse at top right, rgba(217, 119, 6, .06) 0%, transparent 50%);--shadow: 0 4px 20px rgba(0, 0, 0, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-elevated: 0 8px 32px rgba(0, 0, 0, .1), 0 0 0 1px rgba(0, 0, 0, .03);--shadow-inset: inset 0 1px 2px rgba(0, 0, 0, .06);--shadow-focus: 0 0 0 3px rgba(217, 119, 6, .2);--shadow-day-hover: 0 2px 8px rgba(0, 0, 0, .08);--shadow-today: 0 2px 12px rgba(217, 119, 6, .25);--shadow-today-hover: 0 4px 16px rgba(217, 119, 6, .35);--shadow-accent: 0 4px 16px rgba(217, 119, 6, .2);--shadow-accent-sm: 0 2px 8px rgba(217, 119, 6, .15);--shadow-accent-lg: 0 8px 24px rgba(217, 119, 6, .25);--shadow-modal: 0 24px 48px rgba(0, 0, 0, .15), 0 0 0 1px rgba(0, 0, 0, .03);--shadow-floating: 0 8px 24px rgba(0, 0, 0, .12);--shadow-floating-hover: 0 12px 32px rgba(0, 0, 0, .18)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-main);background:var(--bg-base);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background-color var(--transition-smooth),color var(--transition-smooth)}.app{padding:0;position:relative;min-height:100vh;background:var(--bg-base)}.app-frame{background:var(--bg-elevated);min-height:100vh;overflow:hidden;position:relative}.app-header{padding:var(--space-4) var(--space-5);background:var(--bg-header);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);position:relative;width:100%;box-sizing:border-box}.app-header:after{content:"";position:absolute;bottom:0;left:var(--space-5);right:var(--space-5);height:1px;background:linear-gradient(90deg,transparent,var(--accent-glow),transparent);opacity:.3}.app-header-top{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);width:100%;flex-wrap:wrap}.app-title{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);letter-spacing:-.03em;margin:0;display:flex;align-items:baseline;gap:var(--space-2)}.app-title span{font-weight:400;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-stats{display:flex;gap:var(--space-2);background:var(--bg-stats);padding:var(--space-1);border-radius:var(--radius-full);border:1px solid var(--border-subtle)}.app-stat{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);transition:var(--transition-fast);cursor:default}.app-stat:hover{background:var(--bg-stat-hover)}.app-stat-value{font-size:var(--text-sm);font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1}.app-stat-label{font-size:var(--text-2xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.app-header-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);flex-wrap:wrap;flex-shrink:1;min-width:0;max-width:100%}.faq-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;background:var(--bg-button);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-tertiary);text-decoration:none;font-size:var(--text-xs);font-weight:700;transition:var(--transition-fast);flex-shrink:0}.faq-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-1px)}.theme-toggle{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-button);border:1px solid var(--border-subtle);border-radius:var(--radius-full);cursor:pointer;font-family:var(--font-main);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);transition:var(--transition-fast);flex-shrink:0;white-space:nowrap}.theme-toggle:hover{border-color:var(--text-tertiary);color:var(--text-primary);transform:translateY(-1px)}.theme-icon{font-size:var(--text-xs);line-height:1}.user-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-button);border:1px solid var(--border-subtle);border-radius:var(--radius-full);cursor:pointer;font-family:var(--font-main);font-size:var(--text-xs);font-weight:600;transition:var(--transition-fast);flex-shrink:0}.user-btn:hover{border-color:var(--accent-muted)}.user-btn:hover .user-logout{color:var(--error)}.user-email{color:var(--text-secondary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-logout{color:var(--text-tertiary);transition:var(--transition-fast);white-space:nowrap;flex-shrink:0}.nav-section{padding:var(--space-3) var(--space-5);background:var(--bg-nav);border-bottom:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.quarter-nav{order:2;display:flex;gap:var(--space-1);background:var(--bg-segment);padding:var(--space-1);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.quarter-btn{padding:var(--space-2) var(--space-4);background:transparent;border:none;color:var(--text-tertiary);font-family:var(--font-main);font-size:var(--text-xs);font-weight:600;cursor:pointer;border-radius:var(--radius-md);transition:var(--transition-fast);-webkit-tap-highlight-color:transparent;position:relative}.quarter-btn:hover:not(.active){color:var(--text-secondary);background:var(--bg-hover)}.quarter-btn.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm)}.view-toggle{order:1;display:flex;gap:var(--space-1);background:var(--bg-segment);padding:var(--space-1);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.view-btn{padding:var(--space-2) var(--space-3);background:transparent;border:none;color:var(--text-tertiary);font-family:var(--font-main);font-size:var(--text-2xs);font-weight:600;cursor:pointer;border-radius:var(--radius-md);transition:var(--transition-fast);-webkit-tap-highlight-color:transparent;text-transform:uppercase;letter-spacing:.05em}.view-btn:hover:not(.active){color:var(--text-secondary);background:var(--bg-hover)}.view-btn.active{background:var(--accent);color:var(--text-on-accent);box-shadow:var(--shadow-accent)}.controls{padding:var(--space-3) var(--space-5);background:var(--bg-controls)}.search-box{display:flex;align-items:center;max-width:360px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);gap:var(--space-3);transition:var(--transition-fast);box-shadow:var(--shadow-inset)}.search-box:focus-within{border-color:var(--accent);box-shadow:var(--shadow-focus);background:var(--bg-input-focus)}.search-icon{color:var(--text-tertiary);font-size:var(--text-sm);opacity:.7}.search-box input{flex:1;background:none;border:none;color:var(--text-primary);font-family:var(--font-main);font-size:var(--text-sm)}.search-box input::placeholder{color:var(--text-tertiary)}.search-box input:focus{outline:none}.search-results{font-size:var(--text-2xs);color:var(--accent);font-weight:700;white-space:nowrap;padding:var(--space-1) var(--space-2);background:var(--accent-subtle);border-radius:var(--radius-full)}.search-clear{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);font-size:var(--text-sm);transition:var(--transition-fast);border-radius:var(--radius-full);width:24px;height:24px;display:flex;align-items:center;justify-content:center}.search-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.year-container{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-subtle);padding:0}.month-card{background:var(--bg-card);padding:var(--space-4);transition:var(--transition-fast);position:relative}.month-card:before{content:"";position:absolute;inset:0;background:var(--gradient-card-hover);opacity:0;transition:var(--transition-fast);pointer-events:none}.month-card:hover:before{opacity:1}.month-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);position:relative;z-index:1}.month-name{font-size:var(--text-sm);font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.month-badge{font-size:var(--text-2xs);font-weight:600;color:var(--text-tertiary);padding:var(--space-1) var(--space-2);background:var(--bg-badge);border-radius:var(--radius-full)}.day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--space-2)}.day-headers span{font-size:var(--text-3xs);font-weight:700;color:var(--text-tertiary);text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;position:relative;z-index:1}.day-header{text-align:center;padding:var(--space-1) 0;font-size:var(--text-3xs);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.day-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);background:var(--bg-day);transition:var(--transition-fast);position:relative;-webkit-tap-highlight-color:transparent}.day-cell:hover:not(.empty){transform:scale(1.15);z-index:2;box-shadow:var(--shadow-day-hover);background:var(--bg-day-hover)}.day-cell:active:not(.empty){transform:scale(1.05)}.day-cell.empty{cursor:default;background:transparent}.day-cell.weekend{color:var(--text-weekend);opacity:.5}.day-cell.today{background:var(--gradient-today);color:var(--text-on-accent);font-weight:800;box-shadow:var(--shadow-today)}.day-cell.has-event{background:var(--bg-event);color:var(--accent);font-weight:700;border:1px solid var(--accent-border)}.day-cell.has-event:after{display:none}.day-cell.today.has-event:after{display:none}.day-cell.holiday{background:var(--bg-holiday);color:var(--success);font-weight:700;border:1px solid var(--success-border)}.day-cell.holiday:before{display:none}.day-cell.holiday.today{background:var(--gradient-today);color:var(--text-on-accent)}.day-cell.holiday.today:before{display:none}.events-section{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-subtle);max-height:140px;overflow-y:auto;position:relative;z-index:1}.event-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-event-item);border-radius:var(--radius-md);margin-bottom:var(--space-2);font-size:var(--text-sm);transition:var(--transition-fast);cursor:pointer;border:1px solid transparent}.event-item:hover{background:var(--bg-event-item-hover);border-color:var(--border-subtle);transform:translate(2px)}.event-item.search-match,.goal-item.search-match{border-left:3px solid var(--accent);background:var(--accent-subtle)}.event-date{min-width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--gradient-accent);color:var(--text-on-accent);border-radius:var(--radius-md);font-weight:800;font-size:var(--text-xs);box-shadow:var(--shadow-accent-sm)}.event-icon{font-size:var(--text-base)}.event-text{flex:1;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);opacity:0;transition:var(--transition-fast);font-size:var(--text-sm);border-radius:var(--radius-sm)}.event-item:hover .event-delete{opacity:1}.event-delete:hover{color:var(--error);background:var(--error-subtle)}.compact-container{display:none;padding:0 0 5rem;overflow:hidden}.compact-container.active{display:block}.compact-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:var(--space-4)}.compact-table{border-collapse:separate;border-spacing:3px;margin:0 auto;min-width:max-content}.compact-header-row th{padding:var(--space-1) 0 var(--space-2);font-size:var(--text-2xs);font-weight:700;color:var(--text-secondary);text-align:center;min-width:32px;position:sticky;top:0;background:var(--bg-base);z-index:5}.compact-header-row th:first-child{min-width:80px;text-align:left;position:sticky;left:0;background:var(--bg-base);z-index:10;padding-left:var(--space-2)}.compact-month-row td{padding:0;vertical-align:middle}.compact-month-label{position:sticky;left:0;background:var(--bg-base);z-index:5;padding-right:var(--space-3)!important;padding-left:var(--space-2)!important;white-space:nowrap}.month-label-inner{display:flex;align-items:center;gap:var(--space-2)}.month-label-text{font-size:var(--text-sm);font-weight:800;color:var(--text-primary)}.month-label-count{font-size:var(--text-2xs);font-weight:600;color:var(--text-tertiary);background:var(--bg-badge);padding:var(--space-half) var(--space-2);border-radius:var(--radius-full)}.compact-day{width:32px;height:32px;border-radius:var(--radius-md);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:var(--transition-fast);background:var(--bg-day);color:var(--text-secondary);border:1px solid transparent;-webkit-tap-highlight-color:transparent;position:relative}.compact-day .day-letter{font-size:var(--text-3xs);font-weight:700;color:var(--text-tertiary);margin-top:1px;line-height:1}.compact-day.weekend .day-letter{color:var(--text-weekend)}.compact-day:hover:not(.empty){background:var(--bg-day-hover);border-color:var(--accent-border);transform:scale(1.15);z-index:10;position:relative}.compact-day:active:not(.empty){transform:scale(.95)}.compact-day.empty{background:transparent;cursor:default}.compact-day.empty:hover{transform:none}.compact-day.weekend{color:var(--text-weekend);opacity:.6}.compact-day.today{background:var(--gradient-today);color:var(--text-on-accent);font-weight:800;border:2px solid var(--accent-strong);box-shadow:var(--shadow-today)}.compact-day.today .day-letter{color:var(--text-on-accent);opacity:.8}.compact-day.has-event{background:var(--bg-event);color:var(--accent);border-color:var(--accent-border)}.compact-day.has-event .day-letter{color:var(--accent)}.compact-day.weekend.has-event{opacity:1}.compact-day.holiday{background:var(--bg-holiday);color:var(--success);border-color:var(--success-border)}.compact-day.holiday .day-letter{color:var(--success)}.quarter-label-row td{padding-top:var(--space-5);padding-bottom:var(--space-2)}.quarter-label{display:inline-flex;align-items:center;gap:var(--space-3);font-size:var(--text-2xs);font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.12em}.quarter-label:after{content:"";display:block;width:80px;height:1px;background:linear-gradient(90deg,var(--accent-border),transparent)}.compact-day .tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-tooltip);border:1px solid var(--border-glass);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-xs);white-space:nowrap;z-index:100;box-shadow:var(--shadow-elevated);color:var(--text-primary);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.compact-day:hover .tooltip{display:block}.compact-legend{display:flex;justify-content:center;gap:var(--space-5);margin-top:var(--space-6);padding:var(--space-4);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-2xs);font-weight:600;color:var(--text-tertiary)}.legend-dot{width:20px;height:20px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--text-3xs);font-weight:800}.legend-dot.today{background:var(--gradient-today);color:var(--text-on-accent);border:2px solid var(--accent-strong);box-shadow:var(--shadow-today)}.legend-dot.event{background:var(--bg-event);border:1px solid var(--accent-border);color:var(--accent)}.legend-dot.weekend{background:var(--bg-day);color:var(--text-weekend)}.legend-dot.normal{background:var(--bg-day);color:var(--text-secondary)}.legend-dot.holiday{background:var(--bg-holiday);color:var(--success)}.calendar-legend{display:none;justify-content:center;gap:var(--space-5);padding:var(--space-4) var(--space-6) var(--space-8);flex-wrap:wrap;max-width:1400px;margin:0 auto}.calendar-legend.active{display:flex}.full-calendar-container{display:none;padding:0 var(--space-6) 5rem;overflow:visible;position:relative}.full-calendar-container.active{display:block;animation:fullCalendarReveal .5s cubic-bezier(.16,1,.3,1)}.full-calendar-container.fullscreen{position:fixed;inset:0;z-index:999;background:var(--bg-base);padding:0;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}.full-calendar-container.fullscreen .full-calendar-grid{padding:var(--space-4) var(--space-2) var(--space-2);overflow:visible;display:grid!important;--title-height: 2.5rem;--grid-padding: 1.5rem;--available-width: calc(100vw - 1rem) ;--available-height: calc(100vh - var(--title-height) - var(--grid-padding) * 2);--columns: 26;--rows: 15;--gap-ratio: .06;--cell-from-width: calc(var(--available-width) / (var(--columns) + var(--columns) * var(--gap-ratio)));--cell-from-height: calc(var(--available-height) / (var(--rows) + var(--rows) * var(--gap-ratio)));--cell-size: min(var(--cell-from-width), var(--cell-from-height));--cell-gap: calc(var(--cell-size) * var(--gap-ratio));grid-template-columns:repeat(var(--columns),var(--cell-size))!important;grid-auto-rows:var(--cell-size)!important;gap:var(--cell-gap)!important;justify-content:center;align-content:center}.full-calendar-container.fullscreen .full-day{width:var(--cell-size)!important;height:var(--cell-size)!important;min-width:unset!important;max-width:unset!important;aspect-ratio:unset!important;font-size:clamp(.45rem,calc(var(--cell-size) * .3),.85rem);border-radius:clamp(4px,calc(var(--cell-size) * .12),8px);padding:clamp(1px,calc(var(--cell-size) * .05),4px)}.full-calendar-container.fullscreen .full-day .day-abbrev{font-size:clamp(.25rem,calc(var(--cell-size) * .2),.5rem);top:clamp(0px,calc(var(--cell-size) * .03),2px);left:clamp(1px,calc(var(--cell-size) * .05),3px)}.full-calendar-container.fullscreen .full-day .day-num{font-size:clamp(.5rem,calc(var(--cell-size) * .35),.9rem)}.full-calendar-container.fullscreen .full-day .month-label{display:block;font-size:clamp(.35rem,calc(var(--cell-size) * .22),.55rem);top:calc(var(--cell-size) * -.4);padding:0 3px}.full-calendar-title{display:none;font-size:var(--text-lg);font-weight:800;color:var(--text-primary);letter-spacing:-.03em;margin:0;padding:0;line-height:1}.full-calendar-title span{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:400}.full-calendar-container.fullscreen .full-calendar-title{display:block;height:2.5rem;margin:0 0 var(--space-2) 0;padding:var(--space-2) 0;font-size:clamp(1.2rem,3vw,2rem);text-align:center;line-height:1.5rem}.full-calendar-fullscreen-btn{position:absolute;top:-48px;right:var(--space-6);background:var(--bg-button);border:1px solid var(--border-subtle);color:var(--text-secondary);width:36px;height:36px;border-radius:var(--radius-md);cursor:pointer;display:none;align-items:center;justify-content:center;transition:var(--transition-fast);z-index:100}@media(min-width:768px){.full-calendar-fullscreen-btn{display:flex}}.full-calendar-fullscreen-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-1px)}.fullscreen-icon{font-size:var(--text-base);line-height:1}.full-calendar-container.fullscreen .full-calendar-fullscreen-btn{display:flex!important;position:fixed;top:var(--space-4);right:var(--space-4)}@keyframes fullCalendarReveal{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.full-calendar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:4px;row-gap:20px;padding:var(--space-8) 0 var(--space-6);width:100%}.full-day{aspect-ratio:1;min-width:38px;max-width:60px;background:var(--bg-day);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;position:relative;transition:all .15s ease;border:1px solid transparent;-webkit-tap-highlight-color:transparent;padding:var(--space-1);gap:1px}.full-day .day-abbrev{position:absolute;top:3px;left:4px;font-size:var(--text-3xs);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:-.02em;opacity:.6}.full-day .day-num{font-variant-numeric:tabular-nums;line-height:1;font-size:var(--text-sm);font-weight:700}.full-day:hover:not(.outside){background:var(--bg-day-hover);color:var(--text-primary);transform:scale(1.2);z-index:5;border-color:var(--accent-border);box-shadow:var(--shadow-day-hover)}.full-day:active:not(.outside){transform:scale(1.1)}.full-day.today{background:var(--gradient-today);color:var(--text-on-accent);font-weight:800;border:1px solid var(--accent-strong);box-shadow:var(--shadow-today);z-index:2}.full-day.today .day-abbrev{color:var(--text-on-accent);opacity:.7}.full-day.today:hover{transform:scale(1.25);box-shadow:var(--shadow-today-hover)}.full-day.weekend{opacity:.5}.full-day.weekend .day-abbrev{color:var(--text-weekend)}.full-day.weekend:hover{opacity:1}.full-day.has-event{background:var(--bg-event);color:var(--accent);font-weight:700;border-color:var(--accent-border)}.full-day .event-dots{position:absolute;bottom:2px;left:50%;transform:translate(-50%);display:flex;gap:2px;max-width:90%;overflow:hidden}.full-day .event-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}.full-day .event-dot.general{background:var(--accent)}.full-day .event-dot.deadline{background:var(--error)}.full-day .event-dot.meeting{background:#3b82f6}.full-day .event-dot.birthday{background:#ec4899}.full-day .event-dot.travel{background:#8b5cf6}.full-day .event-dot.milestone{background:var(--success)}.full-day .event-dot.health{background:#14b8a6}.full-day .event-dot.finance{background:#eab308}.full-day .event-dot.learning{background:#f97316}.full-day .event-dot.fitness{background:#06b6d4}.full-day.today .event-dot{background:var(--text-on-accent);opacity:.8}.full-calendar-container.fullscreen .full-day .event-dot{width:5px;height:5px}.full-calendar-container.fullscreen .full-day .event-dots{bottom:4px;gap:3px}.full-day.holiday{background:var(--bg-holiday);color:var(--success);font-weight:700;border-color:var(--success-border)}.full-day.holiday:before{content:"";position:absolute;top:2px;right:2px;width:4px;height:4px;background:var(--success);border-radius:50%}.full-day.holiday.today{background:var(--gradient-today);color:var(--text-on-accent)}.full-day.holiday.today:before{background:var(--text-on-accent)}.full-day.month-start{border-left:3px solid var(--accent);border-top-left-radius:0;border-bottom-left-radius:0}.full-day .month-label{position:absolute;top:-16px;left:-2px;font-size:var(--text-2xs);font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;pointer-events:none;background:var(--bg-base);padding:0 var(--space-1);border-radius:var(--radius-sm)}@media(min-width:640px){.full-calendar-container{padding:0 var(--space-8) 5rem}.full-calendar-fullscreen-btn{right:var(--space-8)}.full-calendar-grid{grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:4px;row-gap:22px}.full-day{min-width:44px;max-width:68px}.full-day .day-abbrev{font-size:var(--text-2xs)}.full-day .day-num{font-size:var(--text-sm)}.full-day .month-label{font-size:var(--text-2xs);top:-17px}}@media(min-width:1024px){.full-calendar-container{padding:0 var(--space-10) 5rem}.full-calendar-fullscreen-btn{right:var(--space-10)}.full-calendar-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:5px;row-gap:24px}.full-day{min-width:50px;max-width:76px}.full-day .day-abbrev{font-size:var(--text-2xs)}.full-day .day-num{font-size:var(--text-base)}.full-day .month-label{font-size:var(--text-xs);top:-19px}}@media(hover:none)and (pointer:coarse){.full-calendar-fullscreen-btn{display:none!important}.full-day:hover:not(.outside){transform:none;box-shadow:none;border-color:transparent;background:var(--bg-day);color:var(--text-secondary)}.full-day.today:hover{transform:none;box-shadow:var(--shadow-today)}.full-day.has-event:hover{background:var(--bg-event);color:var(--accent);border-color:var(--accent-border)}.full-day.weekend:hover{opacity:.5}}@media print{.full-calendar-container{display:block!important}.full-calendar-fullscreen-btn{display:none}.full-day{border:1px solid #ccc}.full-day.today{background:#f59e0b!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}.goals-panel{display:none;padding:var(--space-4);background:var(--bg-card)}.goals-panel.active{display:flex;flex-direction:column;gap:var(--space-4)}.annual-goal-card{background:var(--bg-annual-goal);border:1px solid var(--accent-border);border-radius:var(--radius-xl);padding:var(--space-5);position:relative;overflow:hidden}.annual-goal-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:var(--gradient-radial-accent);opacity:.05;pointer-events:none}.annual-goal-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-glow),transparent)}.annual-goal-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);position:relative;z-index:1}.annual-goal-label{font-size:var(--text-2xs);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em}.annual-goal-badge{font-size:var(--text-2xs);font-weight:800;padding:var(--space-1) var(--space-2);background:var(--accent-subtle);color:var(--accent);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.annual-goal-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);line-height:1.3;margin-bottom:var(--space-2);position:relative;z-index:1}.annual-goal-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-3);position:relative;z-index:1;white-space:pre-wrap;word-wrap:break-word}.annual-goal-motivation{font-size:var(--text-sm);color:var(--text-tertiary);font-style:italic;line-height:1.6;padding-left:var(--space-4);border-left:2px solid var(--accent-subtle);margin-bottom:var(--space-4);position:relative;z-index:1;white-space:pre-wrap;word-wrap:break-word}.annual-goal-progress{display:flex;align-items:center;gap:var(--space-3);position:relative;z-index:1}.annual-progress-bar{flex:1;height:6px;background:var(--bg-progress);border-radius:var(--radius-full);overflow:hidden}.annual-progress-fill{height:100%;background:var(--gradient-progress);border-radius:var(--radius-full);transition:width .4s cubic-bezier(.16,1,.3,1)}.annual-progress-text{font-size:var(--text-xs);font-weight:800;color:var(--text-tertiary);min-width:32px;text-align:right}.annual-goal-edit{background:var(--bg-button);border:1px solid var(--border-subtle);color:var(--text-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-xs);font-weight:600;transition:var(--transition-fast)}.annual-goal-edit:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.annual-goal-empty{text-align:center;padding:var(--space-8);position:relative;z-index:1}.annual-goal-empty p{color:var(--text-tertiary);margin-bottom:var(--space-4);font-size:var(--text-base)}.annual-goal-empty button{background:var(--gradient-accent);color:var(--text-on-accent);border:none;padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:700;cursor:pointer;transition:var(--transition-fast);box-shadow:var(--shadow-accent)}.annual-goal-empty button:hover{transform:translateY(-2px);box-shadow:var(--shadow-accent-lg)}.annual-goal-status{font-size:var(--text-2xs);font-weight:700;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;margin-left:var(--space-3)}.annual-goal-status.active,.annual-goal-status.in_progress{background:var(--info-subtle);color:var(--info)}.annual-goal-status.completed{background:var(--success-subtle);color:var(--success)}.annual-goal-status.abandoned{background:var(--error-subtle);color:var(--error)}.goals-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(max-width:768px){.goals-grid{grid-template-columns:1fr}}@media(min-width:1400px){.goals-grid{grid-template-columns:repeat(4,1fr)}}.quarter-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-4);transition:var(--transition-fast)}.quarter-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-sm)}.quarter-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.quarter-title{font-size:var(--text-xs);font-weight:800;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.add-goal-btn{background:var(--bg-button);border:1px solid var(--border-subtle);color:var(--text-secondary);width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-lg);display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.add-goal-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-1px)}.goals-list{display:flex;flex-direction:column;gap:var(--space-3)}.goal-item{background:var(--bg-goal);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:var(--transition-fast);border:1px solid transparent}.goal-item:hover{background:var(--bg-goal-hover);border-color:var(--border-subtle);transform:translate(2px)}.goal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3)}.goal-title{font-size:var(--text-sm);font-weight:700;color:var(--text-primary);flex:1}.goal-status{font-size:var(--text-2xs);font-weight:700;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.goal-status.pending{background:var(--bg-badge);color:var(--text-tertiary)}.goal-status.in_progress{background:var(--info-subtle);color:var(--info)}.goal-status.completed{background:var(--success-subtle);color:var(--success)}.goal-status.abandoned{background:var(--error-subtle);color:var(--error)}.goal-milestones{margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);position:relative}.goal-milestones-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-1)}.add-milestone-inline-btn{background:none;border:1px dashed var(--border-subtle);color:var(--text-tertiary);cursor:pointer;padding:var(--space-1) var(--space-3);font-size:var(--text-2xs);font-family:var(--font-main);font-weight:700;border-radius:var(--radius-full);transition:var(--transition-fast);display:flex;align-items:center;gap:var(--space-1)}.add-milestone-inline-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.goal-milestone-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);padding:var(--space-2) var(--space-2);margin:0 calc(var(--space-2) * -1);border-radius:var(--radius-md);transition:var(--transition-fast);cursor:pointer;position:relative}.goal-milestone-item:hover{background:var(--bg-hover)}.goal-milestone-item.checked{color:var(--text-tertiary)}.goal-milestone-item.checked .milestone-text{text-decoration:line-through;opacity:.5}.goal-milestone-item.checked .milestone-check{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.milestone-check{width:16px;height:16px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-2xs);color:transparent;flex-shrink:0;cursor:pointer;transition:var(--transition-fast)}.goal-milestone-item.dragging{opacity:.4;background:var(--accent-subtle)}.goal-milestone-item.drag-over{border-top:2px solid var(--accent);margin-top:-2px}.milestone-drag-handle-card{cursor:grab;color:var(--text-tertiary);font-size:var(--text-xs);opacity:0;transition:var(--transition-fast);padding:var(--space-half);user-select:none}.goal-milestone-item:hover .milestone-drag-handle-card{opacity:.5}.milestone-drag-handle-card:hover{opacity:1!important;color:var(--accent)}.milestone-drag-handle-card:active{cursor:grabbing}.milestone-toggle{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}.milestone-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.milestone-due-badge{font-size:var(--text-2xs);padding:var(--space-half) var(--space-2);border-radius:var(--radius-full);font-weight:700;white-space:nowrap;letter-spacing:-.01em}.milestone-due-badge.overdue{background:var(--error-subtle);color:var(--error)}.milestone-due-badge.due-soon{background:var(--warning-subtle);color:var(--warning)}.milestone-due-badge.due-future{background:var(--bg-badge);color:var(--text-tertiary)}.goal-progress-text{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-3);font-weight:700}.goal-delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);opacity:0;transition:var(--transition-fast);font-size:var(--text-sm);border-radius:var(--radius-sm)}.goal-item:hover .goal-delete{opacity:1}.goal-delete:hover{color:var(--error);background:var(--error-subtle)}.empty-goals{text-align:center;padding:var(--space-6);color:var(--text-tertiary);font-size:var(--text-sm)}.quarter-progress{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.quarter-progress-bar{flex:1;height:6px;background:var(--bg-progress);border-radius:var(--radius-full);overflow:hidden}.quarter-progress-fill{height:100%;background:var(--gradient-accent);border-radius:var(--radius-full);transition:width .4s cubic-bezier(.16,1,.3,1)}.quarter-progress-text{font-size:var(--text-xs);font-weight:800;color:var(--text-tertiary);min-width:40px;text-align:right}.all-events-panel{display:none;max-width:580px;margin:0 auto;padding:0 var(--space-6) var(--space-6);min-height:calc(100vh - 180px)}.all-events-panel.active{display:flex;flex-direction:column}.all-events-list{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-2xl);padding:var(--space-5);flex:1;min-height:400px}.event-group{margin-bottom:var(--space-5)}.event-group:last-child{margin-bottom:0}.event-group-header{font-size:var(--text-base);font-weight:800;color:var(--accent);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.empty-state{text-align:center;padding:var(--space-10);color:var(--text-tertiary)}.empty-state p{font-size:var(--text-sm);font-weight:500}.modal-overlay{display:none;position:fixed;inset:0;background:var(--bg-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;align-items:center;justify-content:center;padding:var(--space-6)}.modal-overlay.active{display:flex}.modal{background:var(--bg-modal);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);padding:var(--space-6);width:100%;max-width:400px;max-height:90vh;overflow-y:auto;animation:modalReveal .25s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-modal);position:relative}.modal:before{content:"";position:absolute;inset:-1px;border-radius:var(--radius-2xl);padding:1px;background:linear-gradient(135deg,var(--border-shine),transparent,var(--border-shine));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.3}@keyframes modalReveal{0%{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h2{font-size:var(--text-xl);font-weight:800;color:var(--text-primary);margin-bottom:var(--space-5);letter-spacing:-.02em}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;margin-bottom:var(--space-2);font-size:var(--text-2xs);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-main);font-size:var(--text-sm);font-weight:500;transition:var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus);background:var(--bg-input-focus)}.form-group select{cursor:pointer;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 fill='%2371717a' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center}.form-group textarea{resize:vertical;min-height:80px}.day-summary-modal{max-width:440px;padding:0;overflow:hidden}.day-summary-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle)}.day-summary-header h2{margin:0;font-size:var(--text-lg)}.day-summary-close{background:none;border:none;color:var(--text-tertiary);font-size:var(--text-2xl);cursor:pointer;padding:0;line-height:1;transition:var(--transition-fast);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.day-summary-close:hover{color:var(--text-primary);background:var(--bg-hover)}.day-summary-events{padding:var(--space-4) var(--space-6);max-height:50vh;overflow-y:auto}.day-summary-event{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--bg-event-item);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-3);cursor:pointer;transition:var(--transition-fast)}.day-summary-event:last-child{margin-bottom:0}.day-summary-event:hover{border-color:var(--accent-border);background:var(--bg-event-item-hover);transform:translate(2px)}.day-summary-event-icon{font-size:var(--text-xl);flex-shrink:0}.day-summary-event-content{flex:1;min-width:0}.day-summary-event-title{font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.day-summary-event-type{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:capitalize}.day-summary-event-notes{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-2);line-height:1.5}.day-summary-event-delete{background:none;border:none;color:var(--text-tertiary);font-size:var(--text-base);cursor:pointer;padding:var(--space-1);opacity:0;transition:var(--transition-fast);border-radius:var(--radius-sm)}.day-summary-event:hover .day-summary-event-delete{opacity:1}.day-summary-event-delete:hover{color:var(--error);background:var(--error-subtle)}.day-summary-actions{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle)}.day-summary-actions .btn{width:100%}.day-summary-holiday{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--success-subtle);border:1px solid var(--success-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);font-size:var(--text-sm);color:var(--success);font-weight:600}.day-summary-holiday-icon{font-size:var(--text-base)}.goal-modal-hint{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--accent-subtle);border:1px solid var(--accent-border);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-secondary)}.goal-modal-hint .hint-icon{font-size:var(--text-base)}.btn-group{display:flex;gap:var(--space-3);margin-top:var(--space-5)}.btn{flex:1;padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-family:var(--font-main);font-size:var(--text-sm);font-weight:700;cursor:pointer;transition:var(--transition-fast);border:none;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--gradient-accent);color:var(--text-on-accent);box-shadow:var(--shadow-accent-sm)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-accent)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--bg-button);color:var(--text-secondary);border:1px solid var(--border-subtle)}.btn-secondary:hover{border-color:var(--text-tertiary);color:var(--text-primary);transform:translateY(-1px)}.milestone-editor-overlay{position:fixed;inset:0;background:var(--bg-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:var(--transition-fast)}.milestone-editor-overlay.active{opacity:1;visibility:visible}.milestone-editor{background:var(--bg-modal);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);padding:var(--space-5);width:90%;max-width:380px;box-shadow:var(--shadow-modal);transform:scale(.95) translateY(10px);transition:var(--transition-smooth);position:relative}.milestone-editor:before{content:"";position:absolute;inset:-1px;border-radius:var(--radius-2xl);padding:1px;background:linear-gradient(135deg,var(--border-shine),transparent,var(--border-shine));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.3}.milestone-editor-overlay.active .milestone-editor{transform:scale(1) translateY(0)}.milestone-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.milestone-editor-title{font-size:var(--text-base);font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.milestone-editor-title:before{content:"";width:8px;height:8px;background:var(--accent);border-radius:2px;transform:rotate(45deg)}.milestone-editor-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);font-size:var(--text-base);line-height:1;transition:var(--transition-fast);border-radius:var(--radius-md);width:28px;height:28px;display:flex;align-items:center;justify-content:center}.milestone-editor-close:hover{color:var(--text-primary);background:var(--bg-hover)}.milestone-editor-field{margin-bottom:var(--space-4)}.milestone-editor-label{display:block;font-size:var(--text-2xs);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2)}.milestone-editor-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-main);font-size:var(--text-sm);transition:var(--transition-fast)}.milestone-editor-input:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus);background:var(--bg-input-focus)}.milestone-editor-input::placeholder{color:var(--text-tertiary)}.milestone-editor-actions{display:flex;gap:var(--space-2);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--border-subtle)}.milestone-editor-btn{flex:1;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-family:var(--font-main);font-size:var(--text-sm);font-weight:700;cursor:pointer;transition:var(--transition-fast)}.milestone-editor-btn.primary{background:var(--gradient-accent);border:none;color:var(--text-on-accent);box-shadow:var(--shadow-accent-sm)}.milestone-editor-btn.primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-accent)}.milestone-editor-btn.secondary{background:var(--bg-button);border:1px solid var(--border-subtle);color:var(--text-secondary)}.milestone-editor-btn.secondary:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.milestone-editor-btn.danger{background:var(--error-subtle);border:1px solid var(--error-border);color:var(--error);flex:0 0 auto;padding:var(--space-3)}.milestone-editor-btn.danger:hover{background:var(--error);border-color:var(--error);color:#fff}.action-buttons{position:fixed;bottom:var(--space-5);right:var(--space-5);display:flex;gap:var(--space-2);z-index:100}.action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-action);border:1px solid var(--border-glass);color:var(--text-secondary);font-family:var(--font-main);font-size:var(--text-xs);font-weight:700;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-smooth);box-shadow:var(--shadow-floating);-webkit-tap-highlight-color:transparent;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.action-btn:hover{border-color:var(--accent-border);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-floating-hover)}.action-btn:active{transform:scale(.98)}.action-btn.save-btn{border-color:var(--accent-border);color:var(--accent)}.action-btn.save-btn:hover{background:var(--accent);color:var(--text-on-accent)}.action-btn.save-btn.has-changes{background:var(--gradient-accent);color:var(--text-on-accent);border-color:transparent}.toast{position:fixed;bottom:var(--space-16);left:50%;transform:translate(-50%) translateY(10px);background:var(--success);color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700;opacity:0;transition:var(--transition-smooth);z-index:1001;pointer-events:none;box-shadow:var(--shadow-elevated)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.auth-overlay{position:fixed;inset:0;background:var(--bg-base);z-index:9999;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.auth-overlay.hidden{display:none}.auth-container{text-align:center;max-width:400px;width:100%}.auth-logo h1{font-size:var(--text-4xl);font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--space-1)}.auth-logo h1 span{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{font-size:var(--text-base);color:var(--text-tertiary);margin-bottom:var(--space-10)}.auth-step{animation:fadeIn .3s ease}.auth-step.hidden{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-label{text-align:left;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:calc(var(--space-2) * -1)}.auth-input{width:100%;padding:var(--space-4) var(--space-5);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);color:var(--text-primary);font-family:var(--font-main);font-size:var(--text-base);transition:var(--transition-smooth)}.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus);background:var(--bg-input-focus)}.auth-input::placeholder{color:var(--text-tertiary)}.auth-input.auth-otp{font-size:var(--text-3xl);letter-spacing:.5rem;text-align:center;font-family:SF Mono,Monaco,Inconsolata,monospace;padding:var(--space-5)}.auth-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;padding:var(--space-4) var(--space-6);background:var(--gradient-accent);border:none;border-radius:var(--radius-xl);color:var(--text-on-accent);font-family:var(--font-main);font-size:var(--text-base);font-weight:700;cursor:pointer;transition:var(--transition-smooth);box-shadow:var(--shadow-accent)}.auth-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-accent-lg)}.auth-btn:active{transform:translateY(0)}.auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-btn-icon{font-size:var(--text-lg)}.auth-link-btn{background:none;border:none;color:var(--text-tertiary);font-family:var(--font-main);font-size:var(--text-sm);cursor:pointer;padding:var(--space-2);transition:var(--transition-fast)}.auth-link-btn:hover{color:var(--accent)}.auth-info{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-1)}.auth-email-display{font-size:var(--text-lg);font-weight:700;color:var(--accent);margin-bottom:var(--space-6)}.auth-spinner{width:48px;height:48px;border:3px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--space-4)}@keyframes spin{to{transform:rotate(360deg)}}.auth-loading-text{color:var(--text-tertiary);font-size:var(--text-base)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent)}@media(max-width:768px){.app-header{padding:var(--space-3) var(--space-4)}.app-header:after{left:var(--space-4);right:var(--space-4)}.app-header-top{flex-direction:column;gap:var(--space-3)}.app-header-actions{order:1;width:100%;justify-content:center;gap:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.app-title{order:2;font-size:var(--text-base);justify-content:center}.app-stats{order:3;gap:var(--space-1);justify-content:center;padding:var(--space-half)}.app-stat{padding:var(--space-1) var(--space-2)}.nav-section{flex-direction:column;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.quarter-nav{flex-wrap:wrap;gap:var(--space-1);justify-content:center}.quarter-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-2xs)}.view-toggle{width:100%;justify-content:center}.view-btn{padding:var(--space-2) var(--space-2);font-size:var(--text-3xs)}.controls{padding:var(--space-3) var(--space-4)}.search-box{max-width:100%}.year-container{grid-template-columns:1fr}.month-card{padding:var(--space-4)}.compact-day{width:28px;height:28px;font-size:var(--text-2xs)}.compact-day .day-letter{font-size:var(--text-3xs)}.compact-header-row th{font-size:var(--text-3xs);min-width:28px}.action-buttons{bottom:var(--space-4);right:var(--space-4)}.action-btn{padding:var(--space-3) var(--space-4);font-size:var(--text-2xs)}.modal{padding:var(--space-5)}}@media(max-width:480px){.app-header{padding:var(--space-3) var(--space-4)}.app-header-top{flex-direction:column;gap:var(--space-3)}.app-header-actions{order:1;position:static;width:100%;justify-content:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-1)}.app-title{order:2;flex:unset;text-align:center;justify-content:center;font-size:var(--text-lg)}.app-stats{order:3;background:transparent;border:none;padding:0;flex:unset;width:100%;justify-content:center}.app-stat{flex-direction:column;align-items:center;gap:0;padding:var(--space-1);background:var(--bg-stats);border-radius:var(--radius-md)}.theme-toggle{min-height:40px;padding:var(--space-2) var(--space-4)}.faq-link{width:40px;height:40px;font-size:var(--text-sm)}.user-btn{min-height:40px;padding:var(--space-2) var(--space-3)}.user-email{display:none}.quarter-btn{padding:var(--space-2);font-size:var(--text-3xs)}.view-toggle{position:fixed;bottom:0;left:0;right:0;background:var(--bg-elevated);border-top:1px solid var(--border-subtle);padding:var(--space-2) var(--space-3);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom,0px));z-index:100;justify-content:space-around;gap:var(--space-1);box-shadow:0 -2px 10px #0000001a}.view-btn{flex:1;justify-content:center;padding:var(--space-2) var(--space-1);font-size:var(--text-2xs);min-height:44px}.app-frame{padding-bottom:70px}.compact-legend{gap:var(--space-3);padding:var(--space-3);padding-bottom:calc(var(--space-3) + 70px)}.legend-item{font-size:var(--text-3xs)}.legend-dot{width:18px;height:18px}.action-buttons{bottom:calc(70px + var(--space-4))}}@media(hover:none)and (pointer:coarse){.day-cell:hover:not(.empty){transform:none;box-shadow:none;background:var(--bg-day);color:var(--text-secondary)}.day-cell.weekend:hover{color:var(--text-weekend)}.day-cell.has-event:hover{background:var(--bg-event);color:var(--accent)}.day-cell.today:hover{background:var(--gradient-today);color:var(--text-on-accent)}.compact-day:hover:not(.empty){transform:none;border-color:transparent}.compact-day.has-event:hover{border-color:var(--accent-border)}.event-delete{opacity:1}.compact-day .tooltip{display:none!important}}@media(max-width:768px){body{overscroll-behavior-y:contain}}@media print{.action-buttons,.toast,.search-box,.theme-toggle{display:none!important}body{background:#fff;color:#000}.month-card{break-inside:avoid;border:1px solid #ccc}}.add-goal-btn.disabled,.add-milestone-inline-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;background:var(--bg-badge);color:var(--text-tertiary);font-size:var(--text-2xs)}.day-summary-actions .btn:disabled{opacity:.4;cursor:not-allowed;background:var(--bg-badge);color:var(--text-tertiary)}.day-cell.limit-reached,.compact-day.limit-reached,.full-day.limit-reached{animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.header{padding:var(--space-10) var(--space-6) var(--space-6);text-align:center;position:relative}.header-top{display:flex;justify-content:flex-end;align-items:center;gap:var(--space-2);position:absolute;top:var(--space-4);right:var(--space-4)}.header h1{font-size:clamp(2rem,6vw,3rem);font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--space-1)}.header h1 span{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-sub{font-size:var(--text-sm);font-weight:400;color:var(--text-tertiary);letter-spacing:.05em}.stats{display:flex;justify-content:center;gap:var(--space-10);margin:var(--space-6) 0;padding:var(--space-4)}.stat{text-align:center}.stat-value{font-size:var(--text-3xl);font-weight:800;color:var(--accent);line-height:1}.stat-label{font-size:var(--text-2xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.12em;margin-top:var(--space-2)}
