:root{--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-card: #161616;--bg-card-hover: #1a1a1a;--bg-input: #1e1e1e;--bg-elevated: #1c1c1c;--border-subtle: #222222;--border-medium: #2a2a2a;--text-primary: #e8e8e8;--text-secondary: #888888;--text-tertiary: #555555;--text-inverse: #0a0a0a;--accent: #6b7b8d;--accent-hover: #7d8e9f;--accent-subtle: rgba(107, 123, 141, .15);--success: #5a7d6e;--success-subtle: rgba(90, 125, 110, .15);--warning: #8d7b5a;--warning-subtle: rgba(141, 123, 90, .15);--danger: #8d5a5a;--danger-subtle: rgba(141, 90, 90, .15);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: .7rem;--font-sm: .8rem;--font-base: .9rem;--font-md: 1rem;--font-lg: 1.2rem;--font-xl: 1.5rem;--font-2xl: 2rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 50%;--max-width: 600px;--nav-height: 60px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);outline:none;transition:border-color var(--transition-fast)}input:focus,select:focus,textarea:focus{border-color:var(--accent)}#app{min-height:100dvh;display:flex;flex-direction:column}.page{flex:1;padding:var(--space-lg);padding-bottom:calc(var(--nav-height) + var(--space-xl));max-width:var(--max-width);width:100%;margin:0 auto}.page-header{margin-bottom:var(--space-xl)}.page-title{font-size:var(--font-xl);font-weight:600;letter-spacing:-.02em}.page-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:var(--bg-secondary);border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:var(--font-xs);color:var(--text-tertiary);min-width:60px}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--text-primary)}.nav-item .nav-icon{font-size:1.3rem;line-height:1}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);transition:background var(--transition-fast)}.card:hover{background:var(--bg-card-hover)}.card+.card{margin-top:var(--space-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-input);color:var(--text-primary)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-subtle)}.btn-full{width:100%;padding:var(--space-md)}.btn-sm{font-size:var(--font-xs);padding:var(--space-xs) var(--space-sm)}.category-section{margin-bottom:var(--space-xl)}.category-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle)}.category-icon{font-size:var(--font-lg)}.category-name{font-size:var(--font-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.goal-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.goal-item:hover{background:var(--bg-input)}.goal-item+.goal-item{border-top:1px solid var(--border-subtle)}.goal-checkbox{width:22px;height:22px;border-radius:var(--radius-sm);border:2px solid var(--border-medium);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all var(--transition-fast)}.goal-checkbox.checked{background:var(--success);border-color:var(--success)}.goal-checkbox.checked:after{content:"✓";font-size:13px;color:#fff;font-weight:700}.goal-info{flex:1;min-width:0}.goal-name{font-size:var(--font-base);font-weight:500}.goal-name.completed{color:var(--text-tertiary);text-decoration:line-through}.goal-target{font-size:var(--font-xs);color:var(--text-tertiary)}.goal-numeric{display:flex;align-items:center;gap:var(--space-sm)}.goal-numeric input{width:70px;text-align:center;padding:var(--space-xs) var(--space-sm);font-size:var(--font-sm);font-weight:600;border-radius:var(--radius-sm)}.goal-numeric .unit{font-size:var(--font-xs);color:var(--text-tertiary)}.progress-bar{height:4px;background:var(--bg-input);border-radius:2px;margin-top:var(--space-xs);overflow:hidden}.progress-fill{height:100%;border-radius:2px;transition:width var(--transition-base);background:var(--accent)}.progress-fill.complete{background:var(--success)}.streak-badge{display:inline-flex;align-items:center;gap:3px;font-size:var(--font-xs);color:var(--warning);font-weight:600}.stat-card{text-align:center;padding:var(--space-lg)}.stat-value{font-size:var(--font-2xl);font-weight:700;letter-spacing:-.03em}.stat-label{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-xs)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm);margin-bottom:var(--space-xl)}.heatmap{margin-bottom:var(--space-xl)}.heatmap-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.heatmap-cell{aspect-ratio:1;border-radius:3px;background:var(--bg-input);position:relative;transition:transform var(--transition-fast)}.heatmap-cell:hover{transform:scale(1.3);z-index:1}.heatmap-cell.level-0{background:var(--bg-input)}.heatmap-cell.level-1{background:#5a7d6e40}.heatmap-cell.level-2{background:#5a7d6e73}.heatmap-cell.level-3{background:#5a7d6ea6}.heatmap-cell.level-4{background:#5a7d6ee6}.heatmap-cell.today{outline:2px solid var(--accent);outline-offset:1px}.heatmap-labels{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:var(--space-xs)}.heatmap-labels span{text-align:center;font-size:var(--font-xs);color:var(--text-tertiary)}.heatmap-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--font-xs);white-space:nowrap;pointer-events:none;z-index:10;display:none}.heatmap-cell:hover .heatmap-tooltip{display:block}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-xl)}.auth-logo{font-size:var(--font-2xl);font-weight:700;letter-spacing:-.03em;margin-bottom:var(--space-xs)}.auth-tagline{color:var(--text-tertiary);font-size:var(--font-sm);margin-bottom:var(--space-2xl)}.auth-form{width:100%;max-width:360px}.auth-form .form-group{margin-bottom:var(--space-md)}.auth-form label{display:block;font-size:var(--font-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.auth-form input{width:100%}.auth-form .btn{margin-top:var(--space-md)}.auth-switch{text-align:center;margin-top:var(--space-lg);font-size:var(--font-sm);color:var(--text-tertiary)}.auth-switch a{color:var(--accent);cursor:pointer}.auth-switch a:hover{color:var(--accent-hover)}.error-msg{background:var(--danger-subtle);color:var(--danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-sm);margin-bottom:var(--space-md)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:200;animation:fadeIn var(--transition-fast) ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-xl);width:100%;max-width:var(--max-width);max-height:85dvh;overflow-y:auto;animation:slideUp var(--transition-base) ease}@media (min-width: 640px){.modal-overlay{align-items:center}.modal{border-radius:var(--radius-lg);max-height:80vh}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-title{font-size:var(--font-md);font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:var(--font-lg);color:var(--text-tertiary);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-input);color:var(--text-primary)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:var(--font-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.form-group input,.form-group select{width:100%}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.date-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-xl)}.date-nav button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:var(--font-lg);color:var(--text-secondary);transition:all var(--transition-fast)}.date-nav button:hover{background:var(--bg-input);color:var(--text-primary)}.date-display{font-size:var(--font-base);font-weight:500;min-width:160px;text-align:center}.date-today{font-size:var(--font-xs);color:var(--accent);cursor:pointer}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-tertiary)}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:var(--space-md);opacity:.5}.empty-state .empty-text{font-size:var(--font-sm);margin-bottom:var(--space-lg)}.goal-manage-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-radius:var(--radius-sm)}.goal-manage-item:hover{background:var(--bg-input)}.goal-manage-info{display:flex;align-items:center;gap:var(--space-sm)}.goal-type-badge{font-size:var(--font-xs);padding:2px 6px;border-radius:3px;background:var(--accent-subtle);color:var(--accent)}.goal-manage-actions{display:flex;gap:var(--space-xs)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-title{font-size:var(--font-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.chart-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-xl)}.chart-container canvas{width:100%!important;max-height:250px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-tertiary);animation:pulse 1.5s ease infinite}.month-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-lg)}.month-nav button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-fast)}.month-nav button:hover{background:var(--bg-input);color:var(--text-primary)}.month-label{font-size:var(--font-base);font-weight:500;min-width:140px;text-align:center}.completion-list{list-style:none}.completion-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-subtle)}.completion-item:last-child{border-bottom:none}.completion-name{font-size:var(--font-sm)}.completion-rate{font-size:var(--font-sm);font-weight:600}.save-bar{position:fixed;bottom:var(--nav-height);left:0;right:0;padding:var(--space-md);background:var(--bg-secondary);border-top:1px solid var(--border-subtle);display:flex;justify-content:center;z-index:50;animation:slideUp var(--transition-fast) ease}.save-bar .btn{max-width:var(--max-width);width:100%}.toast{position:fixed;top:var(--space-lg);left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-lg);font-size:var(--font-sm);z-index:300;animation:slideDown var(--transition-base) ease}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.toast.success{border-color:var(--success);color:var(--success)}.toast.error{border-color:var(--danger);color:var(--danger)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}@media (min-width: 640px){.page{padding:var(--space-xl) var(--space-2xl);padding-bottom:calc(var(--nav-height) + var(--space-xl))}}
