.milestone-card{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:150px;height:180px;padding:var(--space-6);border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--color-milestone-accent-start) 0%,var(--color-milestone-accent-end) 100%);border:1px solid var(--color-border-default);box-shadow:var(--shadow-md);transition:all var(--transition-base);cursor:pointer;position:relative;overflow:hidden}.milestone-card:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,#fff0,#ffffff4d,#fff0);transition:left .5s ease;pointer-events:none}.milestone-card:hover:after{left:100%}.milestone-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.milestone-card:focus-visible{outline:2px solid var(--color-action-primary);outline-offset:2px;transform:translateY(-2px)}.milestone-card:active{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.milestone-card__icon{font-size:var(--font-size-4xl);margin-bottom:var(--space-2);line-height:1}.milestone-card__count{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);font-family:var(--font-family-mono);line-height:var(--line-height-tight);margin-bottom:var(--space-1);color:var(--color-milestone-count)}.milestone-card__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px;color:var(--color-milestone-text);text-align:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.milestone-card--skeleton{background:var(--color-surface-raised);cursor:default;position:relative;overflow:hidden;pointer-events:none}.skeleton-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.skeleton-icon,.skeleton-count,.skeleton-label{background:var(--color-neutral-200);border-radius:var(--radius-md)}@media(prefers-color-scheme:dark){.skeleton-icon,.skeleton-count,.skeleton-label{background:var(--color-neutral-700)}}.skeleton-icon{width:48px;height:48px;margin-bottom:var(--space-2)}.skeleton-count{width:60px;height:48px;margin-bottom:var(--space-1)}.skeleton-label{width:80px;height:14px}@media(prefers-reduced-motion:reduce){.milestone-card{transition:none}.milestone-card:hover{transform:none}.milestone-card:after{display:none}.skeleton-shimmer{animation:none}}@media(max-width:768px){.milestone-card{min-width:120px;height:160px;padding:var(--space-4)}.milestone-card__icon,.milestone-card__count{font-size:var(--font-size-3xl)}.milestone-card__label{font-size:var(--font-size-xs)}}.milestone-config__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-surface-overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:1rem;animation:fadeIn var(--transition-base) ease-out}.milestone-config__modal{background:var(--color-surface-default);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-2xl);animation:slideUp var(--transition-base) ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.milestone-config__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border-default)}.milestone-config__header h3{margin:0;font-size:1.5rem;color:var(--color-text-strong)}.milestone-config__close-button{background:none;border:none;font-size:24px;cursor:pointer;padding:.25rem;color:var(--color-text-subtle);transition:color var(--transition-fast)}.milestone-config__close-button:hover{color:var(--color-text-strong)}.milestone-config__content{padding:1.5rem}.milestone-config__section{margin-bottom:2rem}.milestone-config__section:last-child{margin-bottom:0}.milestone-config__section h4{margin-top:0;margin-bottom:1rem;font-size:1rem;color:var(--color-text-strong)}.milestone-config__checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.milestone-config__checkbox{display:flex;align-items:center;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s ease}.milestone-config__checkbox:hover{background:var(--color-surface-raised)}.milestone-config__checkbox input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid var(--color-border-strong);border-radius:var(--radius-sm);margin-right:var(--space-3);cursor:pointer;position:relative;transition:all var(--transition-fast);background:var(--color-surface-default)}.milestone-config__checkbox input[type=checkbox]:hover{border-color:var(--color-action-primary)}.milestone-config__checkbox input[type=checkbox]:checked{background:var(--color-action-primary);border-color:var(--color-action-primary)}.milestone-config__checkbox input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.milestone-config__checkbox input[type=checkbox]:focus-visible{outline:2px solid var(--color-action-primary);outline-offset:2px}.milestone-config__checkbox-label{font-size:14px;color:var(--color-text-default);-webkit-user-select:none;user-select:none}.milestone-config__footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--color-border-default)}.milestone-config__cancel-button,.milestone-config__save-button{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none}.milestone-config__cancel-button{background:var(--color-surface-raised);border:1px solid var(--color-border-default);color:var(--color-text-default)}.milestone-config__cancel-button:hover{background:var(--color-surface-canvas)}.milestone-config__save-button{background:var(--color-action-primary);color:var(--color-text-inverse)}.milestone-config__save-button:hover{background:var(--color-action-primary-hover)}@media(prefers-reduced-motion:reduce){.milestone-config__overlay,.milestone-config__modal{animation:none}}@media(max-width:768px){.milestone-config__modal{max-height:100vh;border-radius:0}.milestone-config__checkbox-grid{grid-template-columns:1fr}.milestone-config__header h3{font-size:1.25rem}.milestone-config__content,.milestone-config__footer{padding:1rem}}.future-outlook{margin-top:var(--space-section-gap);padding:var(--space-8);border-top:1px solid var(--color-border-default)}.future-outlook__header{position:relative;text-align:center;margin-bottom:var(--space-8)}.future-outlook__title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-3);color:var(--color-text-strong);letter-spacing:-.025em}.future-outlook__tagline{font-size:var(--font-size-lg);font-style:italic;font-weight:var(--font-weight-medium);color:var(--color-text-subtle);margin:0;margin-top:var(--space-2)}.future-outlook__tagline--animated{animation:fadeInOut 1s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-5px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(5px)}}.future-outlook__config-button{position:absolute;top:0;right:0;width:var(--space-10);height:var(--space-10);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-raised);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-xl);cursor:pointer;padding:var(--space-2);transition:all var(--transition-base);color:var(--color-text-subtle)}.future-outlook__config-button:hover{background:var(--color-surface-canvas);color:var(--color-text-strong);transform:rotate(90deg);border-color:var(--color-border-strong)}.future-outlook__config-button:active{transform:rotate(90deg) scale(.95);background:var(--color-action-primary-subtle)}.future-outlook__config-button:focus-visible{outline:2px solid var(--color-action-primary);outline-offset:2px}.future-outlook__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-6);max-width:1200px;margin:0 auto}.future-outlook__celebration{text-align:center;max-width:600px;margin:var(--space-12) auto;padding:var(--space-8);background:linear-gradient(135deg,var(--color-success-50) 0%,var(--color-success-100) 100%);border:2px solid var(--color-success-500);border-radius:var(--radius-2xl)}.future-outlook__celebration-icon{font-size:var(--font-size-6xl);margin-bottom:var(--space-4);animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.future-outlook__celebration-text{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-success-700);margin-bottom:var(--space-3)}.future-outlook__celebration-subtext{font-size:var(--font-size-lg);color:var(--color-success-600);line-height:var(--line-height-relaxed)}@media(prefers-color-scheme:dark){.future-outlook__celebration{background:#10b9811a;border-color:var(--color-success-500)}.future-outlook__celebration-text{color:var(--color-success-400)}.future-outlook__celebration-subtext{color:var(--color-success-300)}}.future-outlook__empty{text-align:center;max-width:500px;margin:var(--space-12) auto;padding:var(--space-8)}.future-outlook__empty-icon{font-size:var(--font-size-6xl);margin-bottom:var(--space-4)}.future-outlook__empty-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-strong);margin-bottom:var(--space-3)}.future-outlook__empty-description{font-size:var(--font-size-base);color:var(--color-text-subtle);line-height:var(--line-height-relaxed);margin-bottom:var(--space-6)}.future-outlook__empty-button{padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-inverse);background:var(--color-action-primary);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.future-outlook__empty-button:hover{background:var(--color-action-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.future-outlook__empty-button:active{transform:translateY(0)}.future-outlook__empty-button:focus-visible{outline:2px solid var(--color-action-primary);outline-offset:2px}.future-outlook__config-placeholder{margin-top:2rem;padding:1.5rem;background:var(--color-neutral-100);border-radius:8px;text-align:center}.future-outlook__config-placeholder button{margin-top:1rem;padding:.5rem 1rem;background:var(--color-neutral-700);color:#fff;border:none;border-radius:4px;cursor:pointer}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.future-outlook__config-button:hover,.future-outlook__empty-button:hover{transform:none}.future-outlook__celebration-icon,.future-outlook__tagline--animated{animation:none}}@media(max-width:768px){.future-outlook{padding:var(--space-4)}.future-outlook__title{font-size:var(--font-size-2xl)}.future-outlook__grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-4)}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-800: #1e40af;--color-primary-900: #1e3a8a;--color-neutral-50: #f9fafb;--color-neutral-100: #f3f4f6;--color-neutral-200: #e5e7eb;--color-neutral-300: #d1d5db;--color-neutral-400: #9ca3af;--color-neutral-500: #6b7280;--color-neutral-600: #4b5563;--color-neutral-700: #374151;--color-neutral-800: #1f2937;--color-neutral-900: #111827;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-500: #10b981;--color-success-600: #059669;--color-success-700: #047857;--color-error-50: #fef2f2;--color-error-100: #fee2e2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-error-700: #b91c1c;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-surface-canvas: var(--color-neutral-50);--color-surface-default: #ffffff;--color-surface-raised: #ffffff;--color-surface-overlay: rgba(17, 24, 39, .5);--color-text-strong: var(--color-neutral-900);--color-text-default: var(--color-neutral-900);--color-text-subtle: var(--color-neutral-600);--color-text-disabled: var(--color-neutral-400);--color-text-inverse: #ffffff;--color-text-link: var(--color-primary-600);--color-text-link-hover: var(--color-primary-700);--color-border-default: var(--color-neutral-200);--color-border-strong: var(--color-neutral-300);--color-border-subtle: var(--color-neutral-100);--color-action-primary: var(--color-primary-500);--color-action-primary-hover: var(--color-primary-600);--color-action-primary-active: var(--color-primary-700);--color-action-primary-subtle: var(--color-primary-50);--font-family-display: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-body: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas, "DejaVu Sans Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-size-6xl: 3.75rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 2;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-section-gap: var(--space-12);--space-element-gap: var(--space-6);--space-inline-gap: var(--space-4);--radius-none: 0;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--z-base: 0;--z-dropdown: 1000;--z-sticky: 1100;--z-fixed: 1200;--z-modal-backdrop: 1300;--z-modal: 1400;--z-popover: 1500;--z-tooltip: 1600;--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);--spacing-xs: var(--space-2);--spacing-sm: var(--space-3);--spacing-md: var(--space-4);--spacing-lg: var(--space-6);--spacing-xl: var(--space-8);--spacing-2xl: var(--space-12);--font-family-base: var(--font-family-body);--shadow-sm: var(--shadow-md)}@media(prefers-color-scheme:dark){:root,:root[data-theme]{--color-surface-canvas: var(--color-neutral-900);--color-surface-default: var(--color-neutral-800);--color-surface-raised: var(--color-neutral-700);--color-surface-overlay: rgba(0, 0, 0, .7);--color-text-strong: var(--color-neutral-50);--color-text-default: var(--color-neutral-100);--color-text-subtle: var(--color-neutral-400);--color-text-disabled: var(--color-neutral-600);--color-text-inverse: var(--color-neutral-900);--color-border-default: var(--color-neutral-700);--color-border-strong: var(--color-neutral-600);--color-border-subtle: var(--color-neutral-800);--color-action-primary: var(--color-primary-400);--color-action-primary-hover: var(--color-primary-300);--color-action-primary-active: var(--color-primary-200);--color-action-primary-subtle: var(--color-primary-900);--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .4), 0 1px 2px -1px rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4), 0 4px 6px -4px rgb(0 0 0 / .3);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .4), 0 8px 10px -6px rgb(0 0 0 / .3);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .5);--color-text-primary: var(--color-text-default);--color-text-secondary: var(--color-text-subtle);--color-bg-main: var(--color-surface-canvas);--color-border: var(--color-border-default)}:root[data-theme=ocean-sunset],:root[data-theme=neon-dreams],:root[data-theme=forest-fire],:root[data-theme=cyber-glow],:root[data-theme=grape-punch],:root[data-theme=sunset-glow],:root[data-theme=electric-storm],:root[data-theme=tropical-vibes]{--color-lived-bg: rgba(59, 130, 246, .1);--color-remaining-bg: rgba(139, 92, 246, .1)}}:root,[data-theme=ocean-sunset]{--color-lived-primary: var(--color-primary-500);--color-lived-secondary: var(--color-primary-400);--color-lived-bg: var(--color-primary-50);--color-remaining-primary: #8b5cf6;--color-remaining-secondary: #a78bfa;--color-remaining-bg: #f5f3ff;--color-text-primary: var(--color-text-default);--color-text-secondary: var(--color-text-subtle);--color-bg-main: var(--color-surface-canvas);--color-border: var(--color-border-default);--color-error: var(--color-error-500);--color-success: var(--color-success-500)}[data-theme=neon-dreams]{--color-lived-primary: #ec4899;--color-lived-secondary: #f472b6;--color-lived-bg: #fdf2f8;--color-remaining-primary: #8b5cf6;--color-remaining-secondary: #a78bfa;--color-remaining-bg: #f5f3ff}[data-theme=forest-fire]{--color-lived-primary: #059669;--color-lived-secondary: #10b981;--color-lived-bg: #ecfdf5;--color-remaining-primary: #dc2626;--color-remaining-secondary: #ef4444;--color-remaining-bg: #fef2f2}[data-theme=cyber-glow]{--color-lived-primary: #06b6d4;--color-lived-secondary: #22d3ee;--color-lived-bg: #ecfeff;--color-remaining-primary: #f59e0b;--color-remaining-secondary: #fbbf24;--color-remaining-bg: #fffbeb}[data-theme=grape-punch]{--color-lived-primary: #7c3aed;--color-lived-secondary: #8b5cf6;--color-lived-bg: #f5f3ff;--color-remaining-primary: #e11d48;--color-remaining-secondary: #f43f5e;--color-remaining-bg: #fff1f2}[data-theme=sunset-glow]{--color-lived-primary: #f97316;--color-lived-secondary: #fb923c;--color-lived-bg: #fff7ed;--color-remaining-primary: #a855f7;--color-remaining-secondary: #c084fc;--color-remaining-bg: #faf5ff}[data-theme=electric-storm]{--color-lived-primary: #6366f1;--color-lived-secondary: #818cf8;--color-lived-bg: #eef2ff;--color-remaining-primary: #eab308;--color-remaining-secondary: #fbbf24;--color-remaining-bg: #fefce8}[data-theme=tropical-vibes]{--color-lived-primary: #84cc16;--color-lived-secondary: #a3e635;--color-lived-bg: #f7fee7;--color-remaining-primary: #ec4899;--color-remaining-secondary: #f472b6;--color-remaining-bg: #fdf2f8}:root,[data-theme=ocean-sunset]{--color-milestone-accent-start: var(--color-primary-100);--color-milestone-accent-end: var(--color-primary-200);--color-milestone-bg: var(--color-surface-raised);--color-milestone-text: var(--color-text-default);--color-milestone-count: var(--color-text-strong)}[data-theme=neon-dreams]{--color-milestone-accent-start: #fdf2f8;--color-milestone-accent-end: #fce7f3}[data-theme=forest-fire]{--color-milestone-accent-start: #ecfdf5;--color-milestone-accent-end: #d1fae5}[data-theme=cyber-glow]{--color-milestone-accent-start: #ecfeff;--color-milestone-accent-end: #cffafe}[data-theme=grape-punch]{--color-milestone-accent-start: #f5f3ff;--color-milestone-accent-end: #ede9fe}[data-theme=sunset-glow]{--color-milestone-accent-start: #fff7ed;--color-milestone-accent-end: #ffedd5}[data-theme=electric-storm]{--color-milestone-accent-start: #eef2ff;--color-milestone-accent-end: #e0e7ff}[data-theme=tropical-vibes]{--color-milestone-accent-start: #f7fee7;--color-milestone-accent-end: #ecfccb}@media(prefers-color-scheme:dark){:root,:root[data-theme]{--color-milestone-accent-start: rgba(59, 130, 246, .15);--color-milestone-accent-end: rgba(59, 130, 246, .25);--color-milestone-bg: var(--color-surface-raised);--color-milestone-text: var(--color-text-default);--color-milestone-count: var(--color-text-strong)}[data-theme=neon-dreams]{--color-milestone-accent-start: rgba(236, 72, 153, .15);--color-milestone-accent-end: rgba(236, 72, 153, .25)}[data-theme=forest-fire]{--color-milestone-accent-start: rgba(5, 150, 105, .15);--color-milestone-accent-end: rgba(5, 150, 105, .25)}[data-theme=cyber-glow]{--color-milestone-accent-start: rgba(6, 182, 212, .15);--color-milestone-accent-end: rgba(6, 182, 212, .25)}[data-theme=grape-punch]{--color-milestone-accent-start: rgba(124, 58, 237, .15);--color-milestone-accent-end: rgba(124, 58, 237, .25)}[data-theme=sunset-glow]{--color-milestone-accent-start: rgba(249, 115, 22, .15);--color-milestone-accent-end: rgba(249, 115, 22, .25)}[data-theme=electric-storm]{--color-milestone-accent-start: rgba(99, 102, 241, .15);--color-milestone-accent-end: rgba(99, 102, 241, .25)}[data-theme=tropical-vibes]{--color-milestone-accent-start: rgba(132, 204, 22, .15);--color-milestone-accent-end: rgba(132, 204, 22, .25)}}body{font-family:var(--font-family-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-main);color:var(--color-text-primary);line-height:1.6}.app-header,.clock-display,.timeline-icon,.granularity-button,.submit-button,.settings-header h2,.theme-card{transition:background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;padding:var(--space-8) var(--space-4) var(--space-6);background:var(--color-surface-default);border-bottom:1px solid var(--color-border-default)}.app-header h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin-bottom:var(--space-2);letter-spacing:-.02em;background:linear-gradient(135deg,var(--color-primary-500),var(--color-remaining-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:var(--color-text-strong)}.tagline{font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-subtle)}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;position:relative}.header-title{flex:1;text-align:center}.settings-button{position:absolute;right:0;background:transparent;border:1px solid var(--color-border-default);border-radius:var(--radius-md);padding:var(--space-2);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.settings-button:hover{background:var(--color-surface-canvas);border-color:var(--color-border-strong);transform:scale(1.05)}.settings-icon{width:24px;height:24px;color:var(--color-text-default)}.user-info-badge{position:absolute;left:0;background:transparent;border:1px solid var(--color-border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-default);font-weight:var(--font-weight-medium)}.user-info-badge:hover{background:var(--color-surface-canvas);border-color:var(--color-border-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.user-icon{width:20px;height:20px;color:var(--color-text-subtle);flex-shrink:0}.user-info-text{display:flex;align-items:center;gap:var(--space-1)}.user-age{font-weight:var(--font-weight-semibold);color:var(--color-text-strong)}.user-birthday-separator,.user-birthday{color:var(--color-text-subtle)}.edit-icon{width:16px;height:16px;color:var(--color-text-subtle);flex-shrink:0}@media(max-width:768px){.user-info-badge{padding:var(--space-2);gap:var(--space-1)}.user-icon,.user-birthday-separator,.user-birthday{display:none}.edit-icon{width:14px;height:14px}}.settings-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.settings-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-surface-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:1001;max-width:600px;width:90%;max-height:85vh;overflow-y:auto;animation:slideIn .3s ease-out}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.settings-header h2{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--color-lived-primary),var(--color-remaining-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:var(--color-text-secondary);transition:color .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.settings-close:hover{color:var(--color-text-primary)}.settings-content{padding:var(--spacing-xl)}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section:last-child{margin-bottom:0}.settings-section h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.settings-description{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.profile-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.profile-save-button{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--color-lived-primary),var(--color-remaining-primary));border:none;border-radius:var(--radius-md);cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-md);margin-top:var(--spacing-md)}.profile-save-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.profile-save-button:active{transform:translateY(0)}.profile-save-button:focus{outline:2px solid var(--color-lived-primary);outline-offset:2px}.income-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-border-subtle)}.income-section-header h4{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-strong);margin-bottom:var(--spacing-xs)}.income-section-description{font-size:var(--font-size-sm);color:var(--color-text-subtle);margin-bottom:var(--spacing-lg);line-height:1.5}.add-income-section{padding:var(--spacing-lg);background:var(--color-surface-secondary);border-radius:var(--radius-md);text-align:center;margin:var(--spacing-md) 0}.add-income-description{font-size:var(--font-size-sm);color:var(--color-text-subtle);margin-bottom:var(--spacing-md);line-height:1.5}.add-income-button{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:500;color:var(--color-action-primary);background:var(--color-action-primary-subtle);border:2px dashed var(--color-action-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;min-height:44px}.add-income-button:hover{background:#3b82f61a;border-color:var(--color-action-primary-hover);color:var(--color-action-primary-hover)}.add-income-button:focus{outline:2px solid var(--color-action-primary);outline-offset:2px}.income-input-wrapper,.income-display{margin-top:var(--spacing-md)}.income-estimate-box{padding:var(--spacing-lg);background:linear-gradient(135deg,#3b82f60d,#a855f70d);border:2px solid var(--color-border-subtle);border-radius:var(--radius-lg)}.estimate-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-subtle)}.estimate-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.5px}.estimate-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-strong)}.estimate-details{margin-bottom:var(--spacing-md)}.estimate-detail{font-size:var(--font-size-sm);color:var(--color-text-default);margin-bottom:var(--spacing-xs)}.estimate-detail strong{font-weight:600}.estimate-difference{font-size:var(--font-size-sm);margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);display:inline-block}.estimate-difference.positive{color:var(--color-success-700);background:var(--color-success-50);font-weight:500}.estimate-difference.neutral{color:var(--color-text-subtle);background:var(--color-surface-canvas)}.income-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.edit-income-button,.remove-income-button{flex:1;padding:10px 16px;font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;min-height:44px}.edit-income-button{color:var(--color-action-primary);background:#fff;border:2px solid var(--color-action-primary)}.edit-income-button:hover{background:var(--color-action-primary);color:#fff}.edit-income-button:focus{outline:2px solid var(--color-action-primary);outline-offset:2px}.remove-income-button{color:var(--color-error-600);background:#fff;border:2px solid var(--color-error-500)}.remove-income-button:hover{background:var(--color-error-50);border-color:var(--color-error-600)}.remove-income-button:focus{outline:2px solid var(--color-error-500);outline-offset:2px}@media(max-width:768px){.income-estimate-box{padding:var(--spacing-md)}.estimate-value{font-size:var(--font-size-lg)}.income-actions{flex-direction:column}.edit-income-button,.remove-income-button{width:100%}}.theme-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.theme-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-default);cursor:pointer;transition:all .2s;text-align:left;position:relative}.theme-card:hover{border-color:var(--color-lived-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.theme-card.active{border-color:var(--color-lived-primary);box-shadow:0 0 0 3px #3b82f61a}.theme-preview{display:flex;gap:var(--spacing-xs);flex-shrink:0}.theme-color{width:32px;height:32px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.theme-info{flex:1}.theme-name{font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.theme-description{font-size:.875rem;color:var(--color-text-secondary)}.theme-check{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:24px;height:24px;background:var(--color-lived-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.reset-button{width:100%;margin-top:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-border);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.reset-button:hover:not(:disabled){background:var(--color-text-secondary);color:#fff;border-color:var(--color-text-secondary)}.reset-button:disabled{opacity:.5;cursor:not-allowed}.app-main{flex:1;padding:var(--space-12) var(--space-4);max-width:1200px;width:100%;margin:0 auto}.clocks-container{display:grid;grid-template-columns:1fr;gap:var(--space-element-gap);margin-bottom:var(--space-section-gap)}@media(min-width:768px){.clocks-container{grid-template-columns:repeat(2,1fr);gap:var(--space-8)}}.clock-display{background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-base),transform var(--transition-fast);position:relative}.clock-display:hover{box-shadow:var(--shadow-lg)}.clock-lived{border-left:3px solid var(--color-lived-primary)}.clock-remaining{border-left:3px solid var(--color-remaining-primary)}.clock-label{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin-bottom:var(--space-6);color:var(--color-text-default);display:flex;align-items:center;gap:var(--space-3)}.clock-lived .clock-label:before{content:"";display:inline-block;width:12px;height:12px;border-radius:var(--radius-full);background-color:var(--color-lived-primary);flex-shrink:0}.clock-remaining .clock-label:before{content:"";display:inline-block;width:12px;height:12px;border-radius:var(--radius-full);background-color:var(--color-remaining-primary);flex-shrink:0}.clock-lived .clock-label{color:var(--color-lived-primary)}.clock-remaining .clock-label{color:var(--color-remaining-primary)}.clock-content{display:flex;flex-direction:column;gap:var(--space-6)}.time-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.time-unit{display:flex;flex-direction:column;align-items:center;text-align:center}.time-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);font-variant-numeric:tabular-nums;color:var(--color-text-strong)}.clock-lived .time-value{color:var(--color-lived-primary)}.clock-remaining .time-value{color:var(--color-remaining-primary)}.time-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-2)}.time-display{text-align:center;padding:var(--space-6);background:var(--color-surface-canvas);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle)}.time-hms{font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);font-family:var(--font-family-mono);letter-spacing:.05em;font-variant-numeric:tabular-nums;color:var(--color-text-strong)}.clock-lived .time-hms{color:var(--color-lived-primary)}.clock-remaining .time-hms{color:var(--color-remaining-primary)}.over-expectancy{border-left:3px solid var(--color-success-500)}.over-expectancy .clock-label:before{background-color:var(--color-success-500)}.expectancy-message{font-size:2rem;font-weight:600;text-align:center;color:var(--color-success);margin-bottom:var(--spacing-md)}.expectancy-submessage{font-size:1.125rem;text-align:center;color:var(--color-text-secondary);line-height:1.6}.actions{text-align:center;margin-top:var(--spacing-2xl)}.edit-button{padding:var(--spacing-md) var(--spacing-xl);font-size:1rem;font-weight:500;color:var(--color-text-primary);background:var(--color-surface-default);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.edit-button:hover{background:var(--color-bg-main);border-color:var(--color-lived-primary);color:var(--color-lived-primary);box-shadow:var(--shadow-md)}.edit-button:focus{outline:2px solid var(--color-lived-primary);outline-offset:2px}.user-input-form{max-width:500px;margin:0 auto;background:var(--color-surface-default);padding:var(--spacing-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.form-header{text-align:center;margin-bottom:var(--spacing-2xl)}.form-header h2{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,var(--color-lived-primary),var(--color-remaining-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-header p{color:var(--color-text-secondary);font-size:1rem}.privacy-badge{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:#ecfdf5;border:1px solid #6ee7b7;border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);color:#065f46;font-size:.875rem;font-weight:500}.privacy-icon{flex-shrink:0;color:#10b981}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;font-weight:500;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.field-info{font-size:.875rem;color:var(--color-text-secondary);margin:var(--spacing-xs) 0 var(--spacing-sm) 0;line-height:1.5}.required{color:var(--color-error);margin-left:var(--spacing-xs)}.form-group input[type=date],.form-group select{width:100%;padding:var(--spacing-md);font-size:1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s,box-shadow .2s;font-family:inherit}.form-group input[type=date]:focus,.form-group select:focus{outline:none;border-color:var(--color-lived-primary);box-shadow:0 0 0 3px #3b82f61a}.form-group input.error,.form-group select.error{border-color:var(--color-error)}.form-group input.error:focus,.form-group select.error:focus{box-shadow:0 0 0 3px #ef44441a}.radio-group{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.radio-label{display:inline-flex;align-items:center;gap:.75rem;cursor:pointer;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all .2s;white-space:nowrap}.radio-label span{display:inline-block;vertical-align:middle;margin-left:.5rem}.radio-label:hover{background:var(--color-bg-main);border-color:var(--color-lived-primary)}.radio-label input[type=radio]{cursor:pointer;width:1.25rem;height:1.25rem;margin:0;vertical-align:middle;flex-shrink:0}.radio-label input[type=radio]:checked+span{font-weight:600;color:var(--color-lived-primary)}.error-message{display:block;color:var(--color-error);font-size:.875rem;margin-top:var(--spacing-xs)}.submit-button{width:100%;padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--color-lived-primary),var(--color-remaining-primary));border:none;border-radius:var(--radius-md);cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-md);margin-top:var(--spacing-md)}.submit-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.submit-button:active{transform:translateY(0)}.submit-button:focus{outline:2px solid var(--color-lived-primary);outline-offset:2px}.income-input{padding:var(--spacing-lg);background:var(--color-surface-raised);border:2px solid var(--color-border-subtle);border-radius:var(--radius-lg);margin-top:var(--spacing-md)}.income-input-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.income-input-label{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-strong);display:flex;align-items:center;gap:var(--spacing-sm)}.optional-badge{font-size:var(--font-size-sm);font-weight:400;color:var(--color-text-subtle);background:var(--color-surface-canvas);padding:2px 8px;border-radius:var(--radius-sm)}.skip-button{padding:8px 16px;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-subtle);background:transparent;border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;min-height:44px;min-width:44px}.skip-button:hover{background:var(--color-surface-canvas);border-color:var(--color-border-strong);color:var(--color-text-default)}.skip-button:focus{outline:2px solid var(--color-action-primary);outline-offset:2px}.income-input-description{font-size:var(--font-size-sm);color:var(--color-text-subtle);line-height:1.5;margin-bottom:var(--spacing-lg)}.slider-container{margin:var(--spacing-xl) 0;padding:var(--spacing-md) 0;position:relative;isolation:isolate}.income-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:44px;background:transparent;cursor:pointer;position:relative;padding:0;margin:0}.income-slider::-webkit-slider-track{width:100%;height:8px;background:linear-gradient(to right,var(--color-lived-primary) 0%,var(--color-remaining-primary) 100%);border-radius:var(--radius-full);border:none;box-shadow:inset 0 1px 2px #0000001a}.income-slider::-moz-range-track{width:100%;height:8px;background:linear-gradient(to right,var(--color-lived-primary) 0%,var(--color-remaining-primary) 100%);border-radius:var(--radius-full);border:none;box-shadow:inset 0 1px 2px #0000001a}.income-slider:before{content:"";position:absolute;top:50%;left:0;right:0;height:8px;transform:translateY(-50%);background:linear-gradient(to right,var(--color-lived-primary) 0%,var(--color-remaining-primary) 100%);border-radius:var(--radius-full);z-index:0;pointer-events:none}.income-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--color-action-primary);cursor:pointer;margin-top:-8px;box-shadow:0 2px 4px #0000001a;transition:all .2s;position:relative;z-index:1}.income-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--color-action-primary);cursor:pointer;box-shadow:0 2px 4px #0000001a;transition:all .2s;position:relative;z-index:1}.income-slider:hover::-webkit-slider-thumb{transform:scale(1.1);border-color:var(--color-action-primary-hover)}.income-slider:hover::-moz-range-thumb{transform:scale(1.1);border-color:var(--color-action-primary-hover)}.income-slider:focus{outline:none}.income-slider:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px #3b82f64d;border-color:var(--color-action-primary)}.income-slider:focus::-moz-range-thumb{box-shadow:0 0 0 4px #3b82f64d;border-color:var(--color-action-primary)}.percentile-markers{display:flex;justify-content:space-between;margin-top:var(--spacing-sm);padding:0 4px}.percentile-markers .marker{font-size:var(--font-size-xs);color:var(--color-text-subtle);font-weight:500}.percentile-display{text-align:center;margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-surface-canvas);border-radius:var(--radius-md)}.percentile-display strong{font-size:var(--font-size-lg);color:var(--color-text-strong);display:block;margin-bottom:var(--spacing-xs)}.dollar-amount{font-size:var(--font-size-base);color:var(--color-text-subtle)}.live-preview{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background:linear-gradient(135deg,#3b82f60d,#a855f70d);border:2px solid var(--color-border-subtle);border-radius:var(--radius-lg)}.preview-content{margin-bottom:var(--spacing-md)}.preview-title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-subtle);margin-bottom:var(--spacing-xs)}.preview-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-strong);margin:var(--spacing-sm) 0}.preview-difference{font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.preview-difference.positive{color:var(--color-success-600);font-weight:500}.preview-difference.neutral{color:var(--color-text-subtle)}.preview-disclaimer{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-subtle);font-size:var(--font-size-xs);color:var(--color-text-subtle);line-height:1.5}.preview-disclaimer .info-icon{width:16px;height:16px;flex-shrink:0;margin-top:2px;opacity:.7}.income-field-container{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.income-input{padding:var(--spacing-md)}.income-input-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.skip-button{align-self:flex-end}.percentile-markers .marker{font-size:10px}.preview-value{font-size:var(--font-size-xl)}}.app-footer{text-align:center;padding:var(--spacing-xl) var(--spacing-md);color:var(--color-text-secondary);font-size:.875rem;border-top:1px solid var(--color-border)}@media(max-width:768px){.app-header{padding:var(--space-6) var(--space-4) var(--space-4)}.app-header h1{font-size:var(--font-size-3xl)}.tagline{font-size:var(--font-size-base)}.app-main{padding:var(--space-8) var(--space-4)}.time-value{font-size:var(--font-size-2xl)}.time-hms{font-size:var(--font-size-3xl)}.clock-label{font-size:var(--font-size-lg)}.clock-display{padding:var(--space-6)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid var(--color-lived-primary);outline-offset:2px;box-shadow:0 0 0 4px #3b82f61a}.clock-label-with-badge{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap;margin-bottom:var(--space-6)}.clock-label-with-badge .clock-label{margin:0}.label-separator{color:var(--color-text-subtle);font-size:var(--font-size-lg);opacity:.5;-webkit-user-select:none;user-select:none}.clock-label-with-badge .data-source-badge-container{position:relative;display:inline-block;margin:0}.data-source-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:4px var(--spacing-sm);background:var(--color-surface-secondary);border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-size:var(--font-size-sm);color:var(--color-text-default);min-height:28px;line-height:1.2}.clock-label-with-badge .data-source-badge{font-size:var(--font-size-xs);padding:2px var(--spacing-xs);min-height:24px}.data-source-badge:hover{background:var(--color-surface-canvas);border-color:var(--color-border-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.data-source-badge:focus{outline:2px solid var(--color-action-primary);outline-offset:2px}.badge-icon{font-size:16px;line-height:1}.badge-text{font-weight:var(--font-weight-medium)}.badge-detail{font-weight:var(--font-weight-normal);color:var(--color-text-subtle)}.badge-chevron{width:16px;height:16px;transition:transform .2s;color:var(--color-text-subtle)}.badge-chevron.open{transform:rotate(180deg)}.data-source-popover{position:absolute;top:calc(100% + var(--spacing-xs));left:0;min-width:320px;max-width:400px;background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;animation:popoverFadeIn .15s ease-out}@keyframes popoverFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.popover-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-border-default)}.popover-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-strong);margin:0}.popover-close{background:transparent;border:none;cursor:pointer;padding:var(--spacing-xs);color:var(--color-text-subtle);transition:color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.popover-close:hover{color:var(--color-text-default)}.popover-close svg{width:16px;height:16px}.popover-content{padding:var(--spacing-md)}.popover-section{margin-bottom:var(--spacing-md)}.popover-section:last-child{margin-bottom:0}.popover-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-subtle);margin:0 0 var(--spacing-xs) 0}.popover-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-strong);margin:0}.popover-text{font-size:var(--font-size-sm);color:var(--color-text-default);margin:0;line-height:1.5}.popover-text-small{font-size:var(--font-size-xs);color:var(--color-text-subtle);margin:0;line-height:1.5}.popover-note{font-size:var(--font-size-xs);color:var(--color-text-subtle);margin:var(--spacing-xs) 0 0 0;font-style:italic}.popover-list{margin:0;padding-left:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-default)}.popover-list li{margin:var(--spacing-xs) 0}.popover-comparison{background:var(--color-surface-secondary);padding:var(--spacing-sm);border-radius:var(--radius-md)}.popover-footer{padding-top:var(--spacing-md);border-top:1px solid var(--color-border-default)}.popover-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-action-primary);text-decoration:none;transition:color .2s}.popover-link:hover{color:var(--color-action-primary-hover);text-decoration:underline}@media(max-width:768px){.data-source-popover{left:50%;transform:translate(-50%);min-width:280px;max-width:calc(100vw - 32px)}}@media(max-width:480px){.clock-label-with-badge .badge-detail{display:none}.badge-text{font-size:var(--font-size-xs)}}.life-timeline{margin-top:var(--spacing-2xl);background:var(--color-surface-default);border-radius:var(--radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg)}.timeline-header{text-align:center;margin-bottom:var(--spacing-xl)}.timeline-title{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,var(--color-lived-primary),var(--color-remaining-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.timeline-stats{font-size:1.125rem;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap}.stat-lived{color:var(--color-lived-primary);font-weight:600}.stat-total{color:var(--color-text-primary);font-weight:600}.stat-percentage{color:var(--color-text-secondary);font-size:1rem}.timeline-controls{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-bg-main);border-radius:var(--radius-md);flex-wrap:wrap}.granularity-switcher{display:flex;gap:var(--spacing-xs);background:var(--color-surface-default);padding:var(--spacing-xs);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.granularity-button{padding:var(--spacing-sm) var(--spacing-lg);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.granularity-button:hover{background:var(--color-surface-canvas);color:var(--color-text-default)}.granularity-button.active{background:var(--color-lived-primary);color:var(--color-text-inverse);font-weight:600}.icon-style-switcher{display:flex;align-items:center;gap:var(--spacing-sm)}.icon-style-switcher label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.icon-style-select{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-default);cursor:pointer;transition:border-color .2s}.icon-style-select:focus{outline:none;border-color:var(--color-lived-primary)}.timeline-grid-container{position:relative;width:100%;display:flex;flex-direction:column;align-items:center}.timeline-tooltip{position:absolute;background:var(--color-surface-default);color:var(--color-text-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:.875rem;pointer-events:none;z-index:1000;white-space:nowrap;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);top:-40px;left:50%;transform:translate(-50%);animation:tooltipFadeIn .15s ease-out}.timeline-tooltip:after{content:"";position:absolute;bottom:-7px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--color-surface-default)}@keyframes tooltipFadeIn{0%{opacity:0;top:-35px}to{opacity:1;top:-40px}}.mobile-year-labels{display:none}@media(max-width:768px){.mobile-year-labels{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);width:100%}.year-label{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-main);border-radius:var(--radius-sm);border-left:3px solid var(--color-lived-primary)}}.timeline-grid{display:grid;margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-surface-default);border-radius:var(--radius-md);overflow-x:auto;max-height:600px;overflow-y:auto;width:fit-content;max-width:100%}.timeline-mobile-grouped{width:100%;display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-surface-default);border-radius:var(--radius-md);max-height:600px;overflow-y:auto}.timeline-year-group{border-left:3px solid var(--color-border);padding-left:var(--spacing-md);padding-bottom:var(--spacing-md);transition:border-color .2s ease}.timeline-year-group:has(.timeline-icon.current){border-left-color:var(--color-success);background-color:#10b98108;border-radius:var(--radius-sm);padding-right:var(--spacing-md)}.year-group-label{display:flex;align-items:baseline;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);position:sticky;top:0;background:var(--color-surface-default);padding:var(--spacing-sm) 0;z-index:5}.year-age{font-size:1.125rem;font-weight:700;color:var(--color-text-primary)}.year-range{font-size:.875rem;color:var(--color-text-secondary)}.year-group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:var(--spacing-sm);max-width:100%}.timeline-grid-months{gap:4px}@media(min-width:769px){.timeline-grid-months-multi{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-surface-default);border-radius:var(--radius-md);max-height:600px;overflow-y:auto;width:100%}.timeline-multi-year-row{display:flex;flex-direction:column;gap:var(--spacing-sm)}.timeline-year-labels-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.timeline-year-label{font-size:.875rem;font-weight:600;color:var(--color-text-primary);display:flex;align-items:baseline;gap:var(--spacing-xs)}.timeline-year-label .age-label{font-size:.75rem;font-weight:400;color:var(--color-text-secondary);opacity:.7}.timeline-months-icons-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md)}.timeline-year-months{display:grid;grid-template-columns:repeat(12,1fr);gap:4px}.timeline-year-months:not(:last-child){position:relative}.timeline-year-months:not(:last-child):after{content:"";position:absolute;right:calc(var(--spacing-md) / -2);top:0;bottom:0;width:1px;background-color:var(--color-border);opacity:.3}}.timeline-grid-weeks{gap:3px}.timeline-grid-years{gap:8px}.timeline-icon{cursor:pointer;transition:all .15s ease-out;position:relative;animation:fadeIn .3s ease-out backwards}.timeline-icon:nth-child(n){animation-delay:calc(.01s * var(--icon-index, 0))}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.timeline-icon{animation:none}}.icon-style-squares,.timeline-grid-months .icon-style-squares{width:12px;height:12px;border-radius:2px}.timeline-grid-weeks .icon-style-squares{width:10px;height:10px;border-radius:2px}.timeline-grid-years .icon-style-squares{width:18px;height:18px;border-radius:3px}.icon-style-circles{width:12px;height:12px;border-radius:50%}.timeline-grid-months .icon-style-circles{width:12px;height:12px}.timeline-grid-weeks .icon-style-circles{width:10px;height:10px}.timeline-grid-years .icon-style-circles{width:18px;height:18px}.icon-style-rounded-rect,.timeline-grid-months .icon-style-rounded-rect{width:12px;height:12px;border-radius:3px}.timeline-grid-weeks .icon-style-rounded-rect{width:10px;height:10px;border-radius:2px}.timeline-grid-years .icon-style-rounded-rect{width:18px;height:18px;border-radius:4px}.icon-style-unicode{font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.timeline-grid-months .icon-style-unicode{font-size:14px}.timeline-grid-weeks .icon-style-unicode{font-size:8px}.timeline-grid-years .icon-style-unicode{font-size:18px}.timeline-icon.lived:not(.icon-style-unicode){background-color:var(--color-lived-primary);box-shadow:0 1px 2px #0000001a}.timeline-icon.lived.icon-style-unicode{color:var(--color-lived-primary);text-shadow:0 1px 2px rgba(0,0,0,.1)}.timeline-icon.remaining:not(.icon-style-unicode){background-color:#d1d5db;border:1px solid #9ca3af}.timeline-icon.remaining.icon-style-unicode{color:var(--color-text-secondary)}.timeline-icon.pre-birth:not(.icon-style-unicode){background-color:transparent;border:1px solid var(--color-border);opacity:.5}.timeline-icon.pre-birth.icon-style-unicode{color:var(--color-border);opacity:.6}.timeline-icon.pre-birth:hover{opacity:1;background-color:var(--color-bg-main)}.timeline-icon.current:not(.icon-style-unicode){background-color:var(--color-success)!important;outline:none;z-index:10;animation:pulse 2s ease-in-out infinite}.timeline-icon.current.icon-style-unicode{color:var(--color-success);font-weight:700;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #10b98166}50%{transform:scale(1.1);box-shadow:0 0 0 8px #10b98100}}@media(prefers-reduced-motion:reduce){.timeline-icon.current{animation:none;outline:2px solid var(--color-success)}}.timeline-icon:hover{outline:1px solid rgba(0,0,0,.3);outline-offset:1px;z-index:20}.timeline-icon.current:hover{outline:1px solid rgba(0,0,0,.3);outline-offset:1px}.timeline-icon.lived:hover:not(.icon-style-unicode){background-color:var(--color-lived-secondary)}.timeline-icon.remaining:hover:not(.icon-style-unicode){background-color:var(--color-text-secondary)}.timeline-icon:active{transform:scale(.9)}@media(hover:none)and (pointer:coarse){.timeline-icon:hover{outline:2px solid rgba(0,0,0,.5);outline-offset:2px}}.timeline-legend{display:flex;justify-content:center;gap:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--color-text-secondary)}.legend-icon{width:16px;height:16px;border-radius:2px}.legend-icon.icon-style-circles{border-radius:50%}.legend-icon.icon-style-rounded-rect{border-radius:4px}.legend-lived{background-color:var(--color-lived-primary)}.legend-current{background-color:var(--color-success)}.legend-remaining{background-color:var(--color-border);border:none}@media(max-width:768px){.life-timeline{padding:var(--spacing-lg)}.timeline-title{font-size:1.5rem}.timeline-stats{font-size:1rem}.timeline-controls{flex-direction:column;align-items:stretch}.granularity-switcher,.icon-style-switcher{justify-content:space-between}.settings-modal{width:95%;max-height:90vh}.settings-header,.settings-content{padding:var(--spacing-lg)}.theme-preview{flex-direction:column}.timeline-icon{padding:12px;margin:2px}.timeline-grid-months .icon-style-squares,.timeline-grid-months .icon-style-circles,.timeline-grid-months .icon-style-rounded-rect{width:20px;height:20px}.timeline-grid-weeks .icon-style-squares,.timeline-grid-weeks .icon-style-circles,.timeline-grid-weeks .icon-style-rounded-rect{width:16px;height:16px}.timeline-grid-years .icon-style-squares,.timeline-grid-years .icon-style-circles,.timeline-grid-years .icon-style-rounded-rect{width:20px;height:20px}.timeline-grid-months{gap:6px}.timeline-grid-weeks{gap:4px}.timeline-grid-years{gap:10px}.timeline-legend{flex-direction:column;gap:var(--spacing-sm);align-items:flex-start}}@media(max-width:480px){.timeline-grid{max-height:400px}.timeline-icon{padding:14px;margin:2px}.timeline-grid-months .icon-style-squares,.timeline-grid-months .icon-style-circles,.timeline-grid-months .icon-style-rounded-rect,.timeline-grid-years .icon-style-squares,.timeline-grid-years .icon-style-circles,.timeline-grid-years .icon-style-rounded-rect{width:20px;height:20px}.app-main{padding:var(--spacing-lg) var(--spacing-sm)}.life-timeline{padding:var(--spacing-md)}}
