*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{color:#1e293b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5}#root{min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button,input,textarea,select{font-family:inherit}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:240px;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;padding:20px 24px;display:flex}.logo-icon{color:#6366f1}.logo-text{color:#1e293b;font-size:18px;font-weight:600}.sidebar-nav{flex-direction:column;gap:4px;padding:16px 12px;display:flex}.nav-item{color:#64748b;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#1e293b;background:#f1f5f9}.nav-item.active{color:#6366f1;background:#eef2ff}@media (width<=768px){.sidebar{border-top:1px solid #e2e8f0;border-right:none;flex-direction:row;width:100%;height:auto;position:fixed;top:auto;bottom:0}.sidebar-header{display:none}.sidebar-nav{flex-direction:row;justify-content:space-around;width:100%;padding:8px}.nav-item{flex-direction:column;gap:4px;padding:8px 12px;font-size:11px}}.header{background:#fff;border-bottom:1px solid #e2e8f0;padding:24px 32px}.header-title{color:#1e293b;margin:0;font-size:24px;font-weight:600}.card{text-align:left;background:#fff;border:none;border-radius:12px;width:100%;padding:20px;font-family:inherit;transition:all .2s;box-shadow:0 1px 3px #0000001a}button.card{cursor:pointer}.card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.card.clickable{cursor:pointer}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:12px}.btn-md{padding:10px 16px;font-size:14px}.btn-lg{padding:12px 24px;font-size:16px}.btn-primary{color:#fff;background:#6366f1}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-secondary{color:#1e293b;background:#f1f5f9}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-danger{color:#dc2626;background:#fee2e2}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-ghost{color:#64748b;background:0 0}.btn-ghost:hover:not(:disabled){background:#f1f5f9}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:auto}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{color:#1e293b;margin:0;font-size:18px;font-weight:600}.modal-close{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:4px;padding:4px}.modal-close:hover{background:#f1f5f9}.modal-body{padding:24px}.goal-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-row{gap:16px;display:flex}.form-row .form-group{flex:1}.form-label{color:#374151;font-size:14px;font-weight:500}.form-input,.form-textarea,.form-select{color:#1e293b;border:1px solid #e2e8f0;border-radius:8px;padding:10px 14px;font-size:14px;transition:border-color .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:#6366f1;outline:none}.form-textarea{resize:vertical;min-height:80px}.form-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.progress-bar{align-items:center;gap:12px;display:flex}.progress-track{background:#e2e8f0;border-radius:4px;flex:1;height:8px;overflow:hidden}.progress-fill{background:#6366f1;border-radius:4px;height:100%;transition:width .3s}.progress-label{color:#64748b;text-align:right;min-width:40px;font-size:13px;font-weight:500}.stats-cards{grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border-radius:12px;align-items:center;gap:12px;padding:16px 20px;display:flex;box-shadow:0 1px 3px #0000000d}.stat-card-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-card-content{flex-direction:column;min-width:0;display:flex}.stat-card-value{color:#1e293b;font-size:22px;font-weight:700;line-height:1.2}.stat-card-label{color:#64748b;margin-top:2px;font-size:12px}@media (width<=1200px){.stats-cards{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.stats-cards{grid-template-columns:repeat(2,1fr)}.stat-card{padding:14px 16px}.stat-card-value{font-size:20px}}@media (width<=480px){.stats-cards{grid-template-columns:1fr}}.global-heatmap{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 3px #0000000d}.global-heatmap-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.global-heatmap-title{color:#1e293b;font-size:15px;font-weight:600}.global-heatmap-range{color:#94a3b8;font-size:12px}.global-heatmap-content{flex-direction:column;display:flex}.global-heatmap-months{height:18px;margin-bottom:8px;position:relative;overflow:hidden}.global-heatmap-month{color:#64748b;font-size:10px;position:absolute}.global-heatmap-grid{flex-wrap:nowrap;display:flex}.global-heatmap-week{flex-direction:column;display:flex}.global-heatmap-day{background:#e2e8f0;border-radius:3px}.global-heatmap-day.padding{background:0 0}.global-heatmap-day.level-1{background:#c7d2fe}.global-heatmap-day.level-2{background:#a5b4fc}.global-heatmap-day.level-3{background:#818cf8}.global-heatmap-day.level-4{background:#6366f1}.global-heatmap-day.today{outline-offset:1px;outline:2px solid #6366f1}.global-heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:12px;display:flex}.global-heatmap-legend .legend-label{color:#94a3b8;font-size:10px}.global-heatmap-legend .global-heatmap-day{width:12px;height:12px}.heatmap-tooltip{color:#fff;pointer-events:none;z-index:100;white-space:nowrap;background:#1e293b;border-radius:6px;padding:6px 10px;font-size:12px;position:fixed;transform:translate(-50%,-100%);box-shadow:0 2px 8px #0003}.heatmap-tooltip:after{content:"";border:5px solid #0000;border-top-color:#1e293b;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tooltip-date{margin-bottom:2px;font-weight:600}.tooltip-count{color:#94a3b8}.page{background:#f1f5f9;min-height:100vh}.page-content{max-width:1200px;margin:0 auto;padding:24px 32px}.dashboard-overview{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;display:grid}.overview-card{background:#fff;border-radius:16px;align-items:center;gap:16px;padding:20px 24px;display:flex;box-shadow:0 1px 3px #0000000d}.overview-icon{color:#64748b;background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.overview-card.active .overview-icon{color:#6366f1;background:#eef2ff}.overview-card.completed .overview-icon{color:#22c55e;background:#dcfce7}.overview-card.paused .overview-icon{color:#f59e0b;background:#fef3c7}.overview-content{flex-direction:column;display:flex}.overview-value{color:#1e293b;font-size:28px;font-weight:700;line-height:1.2}.overview-label{color:#64748b;font-size:13px}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dashboard-header h2{color:#1e293b;margin:0;font-size:18px;font-weight:600}.dashboard-header-actions{gap:8px;display:flex}.empty-card{text-align:center;color:#64748b;padding:48px}.goals-list{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.goal-overview-card{cursor:pointer;transition:all .2s}.goal-overview-card.variant-indigo{background:linear-gradient(135deg,#eef2ff 0%,#e0e7ff 100%)}.goal-overview-card.variant-green{background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%)}.goal-overview-card.variant-amber{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%)}.goal-overview-card.variant-pink{background:linear-gradient(135deg,#fce7f3 0%,#fbcfe8 100%)}.goal-overview-card.variant-sky{background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 100%)}.goal-overview-card.variant-purple{background:linear-gradient(135deg,#f3e8ff 0%,#e9d5ff 100%)}.goal-overview-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.goal-overview-card.variant-indigo .goal-overview-title,.goal-overview-card.variant-green .goal-overview-title,.goal-overview-card.variant-amber .goal-overview-title,.goal-overview-card.variant-pink .goal-overview-title,.goal-overview-card.variant-sky .goal-overview-title,.goal-overview-card.variant-purple .goal-overview-title{color:#1e293b}.goal-overview-card.variant-indigo .goal-dates,.goal-overview-card.variant-green .goal-dates,.goal-overview-card.variant-amber .goal-dates,.goal-overview-card.variant-pink .goal-dates,.goal-overview-card.variant-sky .goal-dates,.goal-overview-card.variant-purple .goal-dates{color:#64748b}.goal-overview-card.variant-indigo .goal-overview-footer,.goal-overview-card.variant-green .goal-overview-footer,.goal-overview-card.variant-amber .goal-overview-footer,.goal-overview-card.variant-pink .goal-overview-footer,.goal-overview-card.variant-sky .goal-overview-footer,.goal-overview-card.variant-purple .goal-overview-footer{color:#64748b;border-top-color:#00000014}.goal-overview-card.variant-indigo .goal-progress-header span:first-child,.goal-overview-card.variant-green .goal-progress-header span:first-child,.goal-overview-card.variant-amber .goal-progress-header span:first-child,.goal-overview-card.variant-pink .goal-progress-header span:first-child,.goal-overview-card.variant-sky .goal-progress-header span:first-child,.goal-overview-card.variant-purple .goal-progress-header span:first-child{color:#64748b}.goal-overview-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.status-badge{color:#fff;text-transform:uppercase;letter-spacing:.3px;border-radius:12px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.goal-dates{color:#94a3b8;font-size:12px}.goal-overview-title{color:#1e293b;margin:0 0 16px;font-size:18px;font-weight:600}.goal-overview-stats{gap:32px;margin-bottom:12px;display:flex}.goal-stat{flex-direction:column;display:flex}.goal-stat-value{color:#1e293b;font-size:20px;font-weight:600}.goal-stat-label{color:#64748b;font-size:12px}.goal-progress-bar{margin-bottom:12px}.goal-overview-footer{color:#94a3b8;border-top:1px solid #f1f5f9;align-items:center;gap:6px;padding-top:12px;font-size:12px;display:flex}.loading-text{text-align:center;color:#64748b;padding:48px}@media (width<=1024px){.dashboard-overview,.goals-list{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.page-content{padding:16px}.dashboard-overview{grid-template-columns:1fr;gap:12px}.overview-card{padding:16px}.overview-value{font-size:24px}.goals-list{grid-template-columns:1fr}.goal-overview-stats{gap:20px}.goal-stat-value{font-size:18px}}.dashboard-activity-section{margin-bottom:32px}.milestone-list{flex-direction:column;gap:12px;display:flex}.milestone-header{justify-content:space-between;align-items:center;display:flex}.milestone-header h3{color:#374151;margin:0;font-size:14px;font-weight:600}.milestone-add{align-items:center;gap:8px;display:flex}.milestone-input{border:1px solid #e2e8f0;border-radius:8px;flex:1;padding:10px 14px;font-size:14px}.milestone-input:focus{border-color:#6366f1;outline:none}.milestone-items{flex-direction:column;gap:8px;display:flex}.milestone-empty{text-align:center;color:#64748b;background:#f8fafc;border-radius:12px;padding:40px 20px;font-size:13px}.milestone-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:12px;padding:14px 16px;transition:border-color .2s;display:flex}.milestone-item:hover{border-color:#cbd5e1}.milestone-check{cursor:pointer;background:#fff;border:2px solid #cbd5e1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .2s;display:flex}.milestone-check.checked{color:#fff;background:#22c55e;border-color:#22c55e}.milestone-title{color:#1e293b;flex:1;font-size:14px;line-height:1.4}.milestone-title.completed{color:#94a3b8;text-decoration:line-through}.milestone-delete{cursor:pointer;color:#94a3b8;opacity:0;background:0 0;border:none;padding:4px;transition:opacity .2s}.milestone-item:hover .milestone-delete{opacity:1}.milestone-delete:hover{color:#dc2626}.heatmap{flex-direction:column;gap:8px;width:100%;padding-bottom:8px;display:flex;position:relative}.heatmap-months{flex-wrap:wrap;gap:8px 24px;min-height:20px;padding-left:2px;display:flex}.heatmap-month{color:#64748b;white-space:nowrap;font-size:12px}.heatmap-grid-wrapper{flex-direction:column;gap:8px;width:100%;padding-bottom:4px;display:flex}.heatmap-grid{gap:4px;width:100%;display:flex}.heatmap-week{flex-direction:column;display:flex}.heatmap-day{background:#e2e8f0;border-radius:4px;flex-shrink:0}.heatmap-day.has-log{background:#6366f1}.heatmap-day.padding{background:0 0}.heatmap-day.today{outline-offset:1px;outline:2px solid #6366f1}.heatmap-legend{justify-content:flex-end;align-items:center;gap:8px;margin-top:4px;display:flex}.legend-label{color:#94a3b8;font-size:11px}.progress-slider{align-items:center;gap:16px;padding:12px 0;display:flex}.progress-slider-label{color:#64748b;min-width:70px;font-size:13px}.progress-slider-track{cursor:pointer;background:#e2e8f0;border-radius:4px;flex:1;height:8px;position:relative}.progress-slider-fill{background:#6366f1;border-radius:4px;height:100%;transition:width .1s}.progress-slider-thumb{cursor:grab;background:#fff;border:2px solid #6366f1;border-radius:50%;width:18px;height:18px;transition:transform .1s,box-shadow .1s;position:absolute;top:50%;transform:translate(-50%,-50%)}.progress-slider-thumb:hover{transform:translate(-50%,-50%)scale(1.1);box-shadow:0 2px 8px #6366f14d}.progress-slider-thumb:active{cursor:grabbing;transform:translate(-50%,-50%)scale(1.15)}.progress-slider-value{color:#6366f1;text-align:right;min-width:45px;font-size:14px;font-weight:600}.quote-list{margin-top:16px}.quote-list-empty{background:#f8fafc;border-radius:8px;margin-top:16px;padding:16px}.quote-list-input-row{gap:8px;margin-bottom:12px;display:flex}.quote-list-input-row input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;padding:10px 12px;font-size:14px}.quote-list-input-row input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.quote-add-btn{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px 12px;transition:background .15s;display:flex}.quote-add-btn:hover:not(:disabled){background:#5558e3}.quote-add-btn:disabled{cursor:not-allowed;background:#cbd5e1}.quote-list-hint{color:#94a3b8;margin:0;font-size:13px}.quote-items{flex-direction:column;gap:8px;display:flex}.quote-item{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#818cf8 100%);border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.quote-item-content{flex:1;align-items:center;gap:10px;font-size:14px;display:flex}.quote-sparkle{opacity:.9;flex-shrink:0}.quote-item-actions{opacity:.7;gap:4px;display:flex}.quote-action-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;transition:all .15s;display:flex}.quote-action-btn:hover{background:#fff3}.quote-action-btn.danger:hover{background:#ef44444d}.quote-edit-row{flex:1;align-items:center;gap:8px;display:flex}.quote-edit-row input{color:#1e293b;background:#fffffff2;border:1px solid #ffffff80;border-radius:6px;flex:1;padding:6px 10px;font-size:14px}.quote-edit-row input:focus{border-color:#fff;outline:none}.quote-edit-actions{gap:4px;display:flex}.quote-edit-actions .quote-action-btn{padding:4px 8px}.quote-edit-actions .quote-action-btn.save{color:#22c55e}.quote-edit-actions .quote-action-btn.cancel{color:#ef4444}.goal-detail-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.goal-detail-actions{gap:8px;display:flex}.goal-overview{margin-bottom:24px}.overview-header{margin-bottom:20px}.overview-info .status-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;margin-bottom:8px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-block;box-shadow:0 2px 4px #0000001a}.goal-title{color:#1e293b;margin:0 0 8px;font-size:24px;font-weight:700}.goal-desc{color:#64748b;margin:0;font-size:15px;line-height:1.6}.overview-stats{border-top:1px solid #e2e8f0;grid-template-columns:repeat(3,1fr);gap:16px;padding-top:20px;display:grid}.stat-card{align-items:flex-start;gap:12px;display:flex}.stat-icon{color:#6366f1;background:#f1f5f9;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-content{flex:1}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.stat-progress{margin-top:6px}.stat-value{color:#1e293b;font-size:20px;font-weight:600}.detail-sections{flex-direction:column;gap:24px;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h2{color:#1e293b;margin:0;font-size:16px;font-weight:600}.pagination{border-top:1px solid #e2e8f0;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding-top:16px;display:flex}.page-info{color:#64748b;font-size:13px}.log-form{margin-bottom:20px}.log-form-row{gap:16px;margin-bottom:12px;display:flex}.log-form-field{flex-direction:column;flex:1;gap:4px;display:flex}.log-form-field label{color:#64748b;font-size:12px}.log-form-field input[type=date]{border:1px solid #e2e8f0;border-radius:6px;padding:8px 12px;font-size:14px}.log-form-field input[type=range]{width:100%}.log-form-field textarea{resize:vertical;border:1px solid #e2e8f0;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px}.log-form-field textarea:focus,.log-form-field input:focus{border-color:#6366f1;outline:none}.log-form-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.empty-logs{text-align:center;color:#64748b;background:#f8fafc;border-radius:10px;padding:40px 20px}.logs-timeline{flex-direction:column;gap:10px;display:flex}.log-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;transition:border-color .2s;position:relative}.log-item:hover{border-color:#cbd5e1}.log-item-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.log-date{color:#1e293b;font-size:14px;font-weight:600}.log-progress{align-items:center;gap:8px;width:120px;display:flex}.log-progress-value{color:#6366f1;text-align:right;min-width:36px;font-size:13px;font-weight:600}.log-item-content{flex-direction:column;gap:8px;display:flex}.log-field{gap:8px;font-size:14px;line-height:1.5;display:flex}.log-label{color:#64748b;min-width:42px;font-weight:500}.log-value{color:#1e293b}.log-delete{color:#94a3b8;cursor:pointer;opacity:0;background:0 0;border:none;font-size:12px;transition:opacity .2s;position:absolute;top:12px;right:12px}.log-item:hover .log-delete{opacity:1}.log-delete:hover{color:#dc2626}.heatmap-card{margin-bottom:24px}.heatmap-header-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.heatmap-title{color:#374151;margin:0;font-size:14px;font-weight:600}.heatmap-range{color:#64748b;font-size:12px}.milestones-card{padding:16px}.quotes-card{margin-bottom:24px}.quotes-card .section-header h2{align-items:center;gap:8px;display:flex}.quotes-card .section-header h2 svg{color:#6366f1}@media (width<=1024px){.overview-stats{grid-template-columns:1fr;gap:12px}.detail-sections{grid-template-columns:1fr}.section-milestones{order:-1}}@media (width<=768px){.goal-detail-header{flex-direction:column;align-items:stretch;gap:16px}.goal-detail-actions{justify-content:flex-end}.log-form-row{flex-direction:column}}.goal-card{cursor:pointer;flex-direction:column;gap:12px;display:flex}.goal-card-header{justify-content:flex-start;display:flex}.goal-status-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-block;box-shadow:0 2px 4px #0000001a}.goal-card-title{color:#1e293b;margin:0;font-size:16px;font-weight:600}.goal-card-desc{color:#64748b;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:14px;display:-webkit-box;overflow:hidden}.goal-card-progress{flex-direction:column;gap:6px;display:flex}.goal-card-progress-header{color:#64748b;align-items:center;gap:6px;font-size:12px;display:flex}.goal-card-footer{color:#94a3b8;border-top:1px solid #f1f5f9;align-items:center;gap:6px;margin-top:auto;padding-top:8px;font-size:12px;display:flex}.main-content{flex:1;min-height:100vh;margin-left:240px}@media (width<=768px){.main-content{margin-bottom:80px;margin-left:0}}
