:root{--background-primary: #fafbfc;--background-secondary: #ffffff;--background-tertiary: #f6f8fa;--background-card: #ffffff;--background-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-muted: #94a3b8;--brand-primary: #6366f1;--brand-primary-hover: #4f46e5;--brand-primary-light: #818cf8;--brand-secondary: #8b5cf6;--brand-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--brand-gradient-hover: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);--accent-primary: #6366f1;--accent-primary-hover: #4f46e5;--accent-success: #059669;--accent-success-light: #10b981;--accent-danger: #dc2626;--accent-danger-light: #ef4444;--accent-warning: #d97706;--accent-warning-light: #f59e0b;--accent-info: #0284c7;--accent-info-light: #06b6d4;--border-light: #e2e8f0;--border-medium: #cbd5e1;--border-strong: #94a3b8;--border-focus: var(--brand-primary);--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .03);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .06), 0 1px 2px 0 rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .03);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 10px 10px -5px rgba(0, 0, 0, .02);--shadow-focus: 0 0 0 3px rgba(99, 102, 241, .1);--shadow-button: 0 2px 4px 0 rgba(0, 0, 0, .06);--shadow-button-hover: 0 4px 8px 0 rgba(0, 0, 0, .12), 0 2px 4px 0 rgba(0, 0, 0, .08);--glass-bg: rgba(255, 255, 255, .1);--glass-bg-strong: rgba(255, 255, 255, .15);--glass-border: rgba(255, 255, 255, .2);--glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, .37);--backdrop-blur: blur(8px);--backdrop-blur-strong: blur(12px);--border-color: var(--border-light);--shadow-color: rgba(0, 0, 0, .05);--heatmap-level-0: #ebedf0;--heatmap-level-1: #9be9a8;--heatmap-level-2: #40c463;--heatmap-level-3: #30a14e;--heatmap-level-4: #216e39;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--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;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px}@media (prefers-color-scheme: dark){:root{--background-primary: #0f172a;--background-secondary: #1e293b;--background-tertiary: #334155;--background-card: #1e293b;--background-hover: #334155;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--text-muted: #64748b;--brand-primary: #818cf8;--brand-primary-hover: #6366f1;--brand-primary-light: #a5b4fc;--brand-secondary: #a78bfa;--brand-gradient: linear-gradient(135deg, #818cf8 0%, #a78bfa 100%);--brand-gradient-hover: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--accent-primary: #818cf8;--accent-primary-hover: #6366f1;--accent-success: #10b981;--accent-success-light: #34d399;--accent-danger: #ef4444;--accent-danger-light: #f87171;--accent-warning: #f59e0b;--accent-warning-light: #fbbf24;--accent-info: #06b6d4;--accent-info-light: #22d3ee;--border-light: #334155;--border-medium: #475569;--border-strong: #64748b;--border-focus: var(--brand-primary);--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .5), 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .4);--shadow-focus: 0 0 0 3px rgba(129, 140, 248, .2);--shadow-button: 0 2px 4px 0 rgba(0, 0, 0, .3);--shadow-button-hover: 0 4px 8px 0 rgba(0, 0, 0, .4), 0 2px 4px 0 rgba(0, 0, 0, .3);--glass-bg: rgba(255, 255, 255, .05);--glass-bg-strong: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .15);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .6);--border-color: var(--border-light);--shadow-color: rgba(0, 0, 0, .3);--heatmap-level-0: #2d333b;--heatmap-level-1: #0e4429;--heatmap-level-2: #006d32;--heatmap-level-3: #26a641;--heatmap-level-4: #39d353}}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Helvetica Neue,sans-serif;background-color:var(--background-primary);color:var(--text-primary);line-height:var(--leading-normal);font-weight:var(--font-weight-normal);font-size:var(--text-base);transition:background-color .3s ease,color .3s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}*:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px;border-radius:2px}button,a,input,select,textarea{transition:all .2s cubic-bezier(.4,0,.2,1)}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}#root{min-height:100%}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--leading-tight);letter-spacing:-.025em;color:var(--text-primary)}h1{font-size:var(--text-4xl);font-weight:var(--font-weight-bold)}h2{font-size:var(--text-3xl);font-weight:var(--font-weight-semibold)}h3{font-size:var(--text-2xl);font-weight:var(--font-weight-semibold)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{line-height:var(--leading-relaxed);color:var(--text-secondary)}small{font-size:var(--text-sm);color:var(--text-tertiary)}.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}.app-container{display:flex;flex-direction:column;gap:1rem;padding:1rem;min-height:100vh}.header{display:flex;flex-direction:column;gap:1rem}.header-top{display:flex;justify-content:space-between;align-items:center;gap:1rem}.header-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.header-title{font-size:1.5rem;font-weight:700}.manage-categories-button,.settings-button,.help-button,.logout-button{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.manage-categories-button:hover,.settings-button:hover,.help-button:hover,.logout-button:hover{background-color:var(--background-primary);border-color:var(--accent-primary);color:var(--accent-primary)}.nav-tabs{display:flex;gap:.5rem;background-color:var(--background-secondary);padding:.5rem;border-radius:12px;border:1px solid var(--border-color);flex-wrap:wrap}.nav-tab{padding:.5rem 1rem;border:none;background-color:transparent;color:var(--text-secondary);font-weight:600;cursor:pointer;border-radius:8px;transition:background-color .2s,color .2s}.nav-tab.active{background-color:var(--accent-primary);color:#fff}.date-navigator{display:flex;justify-content:space-between;align-items:center;background-color:var(--background-secondary);padding:.5rem 1rem;border-radius:12px;border:1px solid var(--border-color);text-align:center}.date-navigator button{background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:0 .5rem}.date-range{font-weight:600;color:var(--text-primary);font-size:.9rem}.date-display{display:flex;flex-direction:column;align-items:center;gap:.25rem}.today-button{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.today-button:hover:not(:disabled){background-color:var(--background-primary);border-color:var(--accent-primary);color:var(--accent-primary)}.today-button:disabled{opacity:.5;cursor:not-allowed}.day-view{padding:0 .5rem}.week-view{display:flex;flex-direction:column;gap:1.5rem}.day-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:0 .5rem}.day-name{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.day-number{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;font-weight:700;background-color:var(--background-secondary);border:1px solid var(--border-color)}.day-header.is-today .day-name{color:var(--accent-primary)}.day-header.is-today .day-number{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.toggle-completed-button{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;margin-left:auto}.toggle-completed-button:hover{background-color:var(--background-primary);border-color:var(--accent-primary);color:var(--accent-primary)}.goals-list-container{padding:.25rem 0 1rem}.week-view .goals-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;padding:0 .5rem}.day-view .goals-list{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.no-goals-text{font-size:.9rem;color:var(--text-secondary);text-align:center;padding:2rem;grid-column:1 / -1;background:var(--background-secondary);border:2px dashed var(--border-color);border-radius:12px}.week-view .no-goals-text{padding:1rem;display:flex;align-items:center;justify-content:center;min-height:140px;grid-column:1 / -1}.goal-card{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:center;background-color:var(--background-secondary);padding:.75rem;border-radius:12px;border:2px solid var(--border-color);box-shadow:0 2px 8px var(--shadow-color);transition:transform .2s,box-shadow .2s,border-color .2s,background-color .2s,color .2s,opacity .2s;cursor:pointer;aspect-ratio:1 / 1;width:100%;flex-shrink:0}.goal-card:hover{transform:translateY(-2px)}.goal-card.attempted{border-color:var(--accent-success);background-color:#f0fff4}.goal-card.fully-completed{border-color:var(--accent-success);background-color:var(--accent-success);color:#fff}.goal-card.fully-completed .goal-category{background-color:#fff3!important;color:#fff!important}.goal-card.fully-completed .edit-button,.goal-card.fully-completed .memo-button{color:#fff}.goal-card.fully-completed .edit-button:hover,.goal-card.fully-completed .memo-button:hover{background-color:#ffffff1a;color:#fff}.goal-card.fully-completed .week-card-progress{color:#fff}.goal-card.fully-completed .goal-subtitle{color:#fff;opacity:.8}.goal-card.event-card{border-style:dashed}.goal-card.event-card.completed{background-color:#f0f8ff;border-color:var(--accent-primary)}.goal-card.revealed{opacity:.8}.goal-card.revealed:hover{opacity:1}@media (prefers-color-scheme: dark){.goal-card.attempted{background-color:#28a74533}.goal-card.fully-completed{background-color:var(--accent-success);color:var(--background-secondary)}.goal-card.event-card.completed{background-color:#0d6efd26}}.goal-card.disabled{opacity:.5;background-color:var(--background-primary);cursor:not-allowed}.goal-card.disabled:hover{transform:none}.goal-info{text-align:center;width:100%;display:flex;flex-direction:column;gap:.1rem}.goal-title{font-weight:600;font-size:.9rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-height:2.6em}.goal-subtitle{font-size:.7rem;color:var(--text-secondary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.goal-category{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:99px;display:inline-block;align-self:center}.edit-button{position:absolute;top:.5rem;right:.5rem;width:1.75rem;height:1.75rem;border-radius:50%;border:none;background-color:transparent;cursor:pointer;display:flex;justify-content:center;align-items:center;color:var(--text-secondary);transition:background-color .2s,color .2s;z-index:2}.edit-button:hover{background-color:var(--background-primary);color:var(--text-primary)}.edit-button svg{width:1rem;height:1rem}.memo-button{position:absolute;bottom:.5rem;right:.5rem;width:1.5rem;height:1.5rem;border:none;background:none;cursor:pointer;color:var(--text-secondary);z-index:2}.memo-button:hover{color:var(--text-primary)}.memo-button.has-memo{color:var(--accent-primary)}.memo-button svg{width:100%;height:100%}.week-card-progress{width:100%;padding:0 .5rem;font-size:.8rem;color:var(--text-secondary)}.week-card-progress span{display:block;text-align:center;margin-bottom:.25rem}.week-card-progress .progress-bar-container{height:6px}.week-card-progress .progress-bar{background-color:var(--accent-success)}.month-view-grid,.year-view-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.month-goal-card,.year-goal-card{display:flex;flex-direction:column;justify-content:space-between;background-color:var(--background-secondary);padding:1rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 2px 8px var(--shadow-color);cursor:pointer;transition:transform .2s,box-shadow .2s;aspect-ratio:1 / 1;text-align:left;font-family:inherit;color:inherit}.month-goal-card.event-card,.year-goal-card.event-card{border-style:dashed}.month-goal-card:hover,.year-goal-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px var(--shadow-color)}.month-goal-card .goal-info,.year-goal-card .goal-info{text-align:left}.month-goal-card .goal-title,.year-goal-card .goal-title{margin-bottom:.25rem;-webkit-line-clamp:2;min-height:2.6em}.month-goal-card .goal-category,.year-goal-card .goal-category{align-self:flex-start}.goal-schedule-days{font-size:.7rem;color:var(--text-secondary);font-weight:500;margin-top:.5rem}.month-card-progress,.year-card-progress{font-size:.8rem;color:var(--text-secondary);margin-top:1rem}.month-card-progress span,.year-card-progress span{display:block;margin-bottom:.25rem}.month-card-progress .progress-bar-container,.year-card-progress .progress-bar-container{height:6px}.month-card-progress .progress-bar,.year-card-progress .progress-bar{background-color:var(--accent-success)}.dashboard-view{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.dashboard-card{background-color:var(--background-secondary);padding:1rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 2px 8px var(--shadow-color)}.dashboard-card h3{font-size:1rem;font-weight:600;margin-bottom:1rem}.stat-card{text-align:center}.stat-title{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.stat-value{font-size:2.5rem;font-weight:700;line-height:1}.stat-unit{font-size:1rem;font-weight:500;margin-left:.25rem;color:var(--text-secondary)}.stats-grid-card{background-color:var(--background-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:.5rem}.stat-box{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);border-radius:var(--radius-lg);padding:1rem;display:flex;align-items:center;gap:.75rem;color:#fff;box-shadow:var(--shadow-md);transition:transform .2s ease,box-shadow .2s ease}.stat-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{font-size:1.5rem;opacity:.9;flex-shrink:0}.stat-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.stat-box .stat-value{font-size:1.5rem;font-weight:700;line-height:1;color:#fff;margin:0}.stat-label{font-size:.75rem;font-weight:500;opacity:.9;line-height:1.2}.stat-details{font-size:.65rem;opacity:.8;line-height:1.2}.memo-stats-compact{display:flex;align-items:center;justify-content:space-around;padding:1rem;background:linear-gradient(135deg,var(--accent-info) 0%,var(--brand-primary) 100%);border-radius:var(--radius-lg);color:#fff;margin-top:.5rem}.memo-stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1}.memo-stat-value{font-size:1.5rem;font-weight:700;line-height:1}.memo-stat-label{font-size:.75rem;font-weight:500;opacity:.9}.memo-stat-divider{width:1px;height:2rem;background:#ffffff4d;margin:0 .5rem}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:.5rem}.stat-box{padding:.75rem;gap:.5rem}.stat-icon,.stat-box .stat-value{font-size:1.25rem}.stat-label{font-size:.7rem}.stat-details{font-size:.6rem}.memo-stats-compact{padding:.75rem}.memo-stat-value{font-size:1.25rem}.header-top{flex-direction:column!important;align-items:stretch!important;gap:1rem!important}.header-title{text-align:center!important;margin-bottom:0!important}.header-actions{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:.25rem!important;flex-wrap:nowrap!important;width:100%!important}.user-welcome{font-size:.8rem!important;text-align:center!important;margin-bottom:.5rem!important;display:block!important;width:100%!important}.manage-categories-button,.settings-button,.help-button,.logout-button{font-size:0!important;padding:.25rem!important;width:35px!important;height:35px!important;display:flex!important;align-items:center!important;justify-content:center!important;margin:0!important;flex-shrink:0!important;border-radius:8px!important}.manage-categories-button:before{content:"📁";font-size:1.2rem}.settings-button:before{content:"⚙️";font-size:1.2rem}.help-button:before{content:"❓";font-size:1.2rem}.logout-button:before{content:"👤";font-size:1.2rem}.button-text{display:none!important}.auth-modal{max-width:350px!important;padding:1rem!important;margin:1rem!important}.auth-modal .modal-header h2{font-size:1.25rem!important}.verification-success .success-icon{font-size:2.5rem!important}.verification-actions{flex-direction:column!important;gap:.5rem!important}.verification-actions button{width:100%!important}}.category-card .category-list{display:flex;flex-direction:column;gap:.75rem}.category-progress .category-info{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.25rem}.category-progress .category-name{font-weight:500;display:flex;align-items:center;gap:.5rem}.category-color-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.category-progress .category-rate{color:var(--text-secondary)}.activity-heatmap{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:3px;aspect-ratio:7 / 2.5}.heatmap-cell{aspect-ratio:1/1;border-radius:3px;background-color:var(--heatmap-level-0)}.heatmap-cell.empty{background-color:transparent}.heatmap-cell.level-1{background-color:var(--heatmap-level-1)}.heatmap-cell.level-2{background-color:var(--heatmap-level-2)}.heatmap-cell.level-3{background-color:var(--heatmap-level-3)}.heatmap-cell.level-4{background-color:var(--heatmap-level-4)}.bar-chart rect{fill:var(--accent-primary);transition:fill .2s}.bar-chart rect:hover{fill:var(--accent-primary-hover)}.bar-chart text{font-size:.7rem;fill:var(--text-secondary)}.category-card,.weekly-chart-card{grid-column:1 / -1}@media (min-width: 600px){.category-card{grid-column:span 1}.weekly-chart-card{grid-column:1 / -1}}@media (min-width: 900px){.weekly-chart-card{grid-column:span 1}}.progress-bar-container{width:100%;height:.75rem;background-color:var(--background-primary);border-radius:.375rem;overflow:hidden;position:relative;border:1px solid var(--border-color)}.category-card .progress-bar-container{height:6px}.progress-bar{height:100%;background-color:var(--accent-primary);border-radius:.375rem;transition:width .5s ease-in-out}.fab{position:fixed;bottom:2rem;right:2rem;width:4rem;height:4rem;border-radius:50%;background-color:var(--accent-primary);color:#fff;border:none;font-size:2rem;display:flex;justify-content:center;align-items:center;box-shadow:0 6px 20px #0003;cursor:pointer;transition:background-color .2s,transform .2s;z-index:100}.fab:hover{background-color:var(--accent-primary-hover);transform:scale(1.05)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal-content{background:var(--background-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:calc(100vh - 2rem);overflow:hidden;position:relative;border:1px solid var(--border-light);display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-light);flex-shrink:0}.modal-header h2{margin:0;font-size:var(--text-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);line-height:var(--leading-tight)}.modal-body{padding:2rem;overflow-y:auto;flex-grow:1}.modal-actions{display:flex;justify-content:flex-end;align-items:center;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--border-light);flex-shrink:0;background-color:var(--background-tertiary)}.close-button{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease}.close-button:hover{background-color:var(--background-hover);color:var(--text-primary)}.auth-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.auth-modal{border:1px solid var(--border-light)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border-light);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-header h2{margin:0;font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.close-button{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all .2s ease}.close-button:hover{color:var(--text-primary);background:var(--background-tertiary)}.modal-body{padding:2rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:var(--text-sm)}.form-group input{padding:.75rem;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-base);background:var(--background-secondary);color:var(--text-primary);transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #667eea1a}.form-help{font-size:var(--text-xs);color:var(--text-secondary)}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:var(--radius-md);font-size:var(--text-sm)}.info-message{background:#f0f9ff;border:1px solid #bae6fd;color:#0369a1;padding:.75rem;border-radius:var(--radius-md);font-size:var(--text-sm)}.auth-switch{text-align:center;margin-top:1rem}.link-button{background:none;border:none;color:var(--brand-primary);text-decoration:underline;cursor:pointer;font-size:inherit}.link-button:hover{color:var(--brand-primary-hover)}.forgot-password-link{text-align:center;margin-top:1rem}.verification-success{text-align:center;padding:2rem 0}.success-icon{font-size:3rem;margin-bottom:1rem}.verification-success h3{margin:0 0 1rem;color:var(--text-primary);font-size:var(--text-lg)}.verification-success p{margin:0 0 2rem;color:var(--text-secondary);line-height:1.6}.verification-actions{display:flex;gap:1rem;justify-content:center}.forgot-password-text{margin:0 0 1.5rem;color:var(--text-secondary);line-height:1.6}@media (prefers-color-scheme: dark){.modal-content{background:var(--background-secondary);border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #000c}.modal-overlay{background-color:#000c}.modal-header{border-bottom-color:#ffffff1a}.error-message{background:#dc26261a;border-color:#dc26264d;color:#fca5a5}.info-message{background:#0369a11a;border-color:#0369a14d;color:#7dd3fc}}.auth-modal{max-width:400px!important;padding:1.5rem!important}.auth-modal .modal-header{margin-bottom:1rem}.auth-modal .modal-header h2{margin-bottom:0;font-size:1.5rem}.auth-modal .modal-body{padding:0}.auth-form,.auth-form .form-group{margin-bottom:1rem}.forgot-password-text{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:1.5rem;text-align:center}.forgot-password-link{text-align:center;margin:1rem 0}.auth-switch{text-align:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-light)}.auth-switch p{margin:0;color:var(--text-secondary);font-size:var(--text-sm)}.verification-success{text-align:center;padding:1rem 0}.verification-success .success-icon{font-size:3rem;margin-bottom:1rem}.verification-success h3{margin-bottom:1rem;color:var(--text-primary)}.verification-success p{color:var(--text-secondary);line-height:1.5;margin-bottom:1.5rem}.verification-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.modal-content h2{margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.form-group .form-hint{font-size:.8rem;color:var(--text-secondary);margin:-.25rem 0 .5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-bottom:.5rem;line-height:var(--leading-tight)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border-light);background-color:var(--background-secondary);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;line-height:var(--leading-normal);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-xs)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--shadow-focus),var(--shadow-xs);background-color:var(--background-secondary)}.form-group input:hover:not(:focus),.form-group select:hover:not(:focus),.form-group textarea:hover:not(:focus){border-color:var(--border-medium)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--background-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.6}.form-help{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:.25rem;line-height:var(--leading-relaxed)}.error-message{background-color:#ef44441a;border:1px solid var(--accent-danger-light);color:var(--accent-danger);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:var(--text-sm);margin:1rem 0;display:flex;align-items:center;gap:.5rem}.info-message{background-color:#06b6d41a;border:1px solid var(--accent-info-light);color:var(--accent-info);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:var(--text-sm);margin:1rem 0}.form-group-row{display:flex;gap:1rem;align-items:flex-end}.form-group-row>.form-group{flex:1}.days-selector{display:flex;gap:.5rem;flex-wrap:wrap}.day-button{flex:1;min-width:40px;padding:.5rem;border-radius:8px;border:1px solid var(--border-color);background-color:var(--background-primary);color:var(--text-secondary);cursor:pointer;text-align:center;font-size:.8rem}.day-button.selected{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.radio-group{display:flex;gap:1rem;background-color:var(--background-primary);padding:.5rem;border-radius:8px;border:1px solid var(--border-color)}.radio-group label{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:0;margin:0;cursor:pointer;color:var(--text-secondary);font-weight:500}.radio-group input[type=radio]{display:none}.radio-group input[type=radio]:checked+span{background-color:var(--accent-primary);color:#fff;box-shadow:0 1px 3px var(--shadow-color)}.radio-group span{display:block;width:100%;text-align:center;padding:.5rem;border-radius:6px;transition:all .2s ease-in-out}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;align-items:center}.modal-actions button{padding:.75rem 1.5rem;border-radius:8px;border:none;font-weight:600;cursor:pointer}.modal-actions .cancel{background-color:var(--background-primary);color:var(--text-primary);border:1px solid var(--border-color)}.modal-actions .submit{background-color:var(--accent-primary);color:#fff}.modal-actions .delete{background-color:transparent;color:var(--accent-danger);padding:.75rem;margin-right:auto}.goal-modal-content{display:flex;flex-direction:column;max-height:85vh}.modal-form-body{overflow-y:auto;flex-grow:1;padding-right:1rem;margin-right:-1rem}.goal-modal-content .modal-actions{margin-top:1.5rem}.memo-modal-date{color:var(--text-secondary);margin-top:-1rem;margin-bottom:1.5rem}.memo-modal-textarea{width:100%;padding:.75rem;border-radius:8px;border:1px solid var(--border-color);background-color:var(--background-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical;min-height:100px}.memo-modal-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #007bff40}.detail-modal-content{display:flex;flex-direction:column;gap:1.5rem;max-height:85vh}.detail-modal-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-shrink:0}.detail-modal-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.detail-modal-content .modal-actions{margin-top:0;flex-shrink:0}.detail-modal-header h2{margin:0;flex-grow:1}.detail-modal-header .edit-button{position:static;color:var(--text-primary)}.stat-section{background-color:var(--background-primary);padding:1rem;border-radius:12px}.stat-section h3{font-size:1rem;font-weight:600;margin-bottom:.25rem}.stat-section p{font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem}.task-checklist-section{background-color:var(--background-primary);padding:1rem;border-radius:12px}.task-checklist-section h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.task-checklist{list-style:none;max-height:150px;overflow-y:auto}.task-checklist li{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-bottom:1px solid var(--border-color)}.task-checklist li:last-child{border-bottom:none}.task-checklist li.completed .task-title-detail{text-decoration:line-through;color:var(--text-secondary)}.task-checklist .checkbox-icon{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border:2px solid var(--border-color);border-radius:50%;font-size:.8rem;color:var(--accent-success);font-weight:700}.task-checklist li.completed .checkbox-icon{border-color:var(--accent-success);background-color:var(--accent-success);color:#fff}.memo-history-section{background-color:var(--background-primary);padding:1rem;border-radius:12px}.memo-history-section h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.memo-history-list{max-height:150px;overflow-y:auto;background-color:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem}.memo-history-item{padding:.75rem;border-bottom:1px solid var(--border-color)}.memo-history-item:last-child{border-bottom:none}.memo-history-date{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.memo-history-content{font-size:.9rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.no-memos-text{text-align:center;padding:1rem;font-size:.9rem;color:var(--text-secondary)}.category-modal-content{max-height:85vh;display:flex;flex-direction:column}.category-modal-content .category-list{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;border:1px solid var(--border-color);border-radius:8px;padding:.5rem;background-color:var(--background-primary)}.category-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background-color:var(--background-secondary);border-radius:6px}.category-item input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:2rem;height:2rem;background-color:transparent;border:none;cursor:pointer;padding:0;border-radius:50%;overflow:hidden;border:1px solid var(--border-color)}.category-item input[type=color]::-webkit-color-swatch{border-radius:50%;border:none}.category-item input[type=color]::-moz-color-swatch{border-radius:50%;border:none}.category-item input[type=text]{flex-grow:1;border:none;background-color:transparent;padding:.5rem;font-size:.9rem}.category-item input[type=text]:focus{outline:none;background-color:var(--background-primary);border-radius:4px}.category-item button{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.5rem}.category-item button:hover:not(:disabled){color:var(--accent-danger)}.category-item button:disabled{color:var(--border-color);cursor:not-allowed}.add-category-form{margin-bottom:1.5rem}.add-category-form h3{margin-bottom:.75rem;font-size:1rem}.add-category-form .form-group-row{align-items:center}.add-category-form input[type=color]{width:2.5rem;height:2.5rem;border-radius:8px;padding:2px}.add-category-form input[type=text]{flex-grow:1}.add-category-form button{padding:.75rem 1.5rem}.goal-card.dragging,.month-goal-card.dragging,.year-goal-card.dragging{opacity:.5;transform:translateY(-2px) scale(.95);box-shadow:0 8px 24px var(--shadow-color);cursor:grabbing}.goal-card[data-drag-over=true],.month-goal-card[data-drag-over=true],.year-goal-card[data-drag-over=true],.goal-card.drag-over,.month-goal-card.drag-over,.year-goal-card.drag-over{border-style:dashed!important;border-color:var(--accent-primary)!important;background-color:var(--background-primary)}.settings-section,.help-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-light)}.settings-section:last-child,.help-section:last-child{border-bottom:none;margin-bottom:0}.settings-section h3,.help-section h3{margin-bottom:.5rem;color:var(--text-primary);font-size:1.1rem}.settings-section p,.help-section p{margin-bottom:.5rem;color:var(--text-secondary);line-height:1.5}.help-section ul{margin-left:1rem;color:var(--text-secondary)}.help-section li{margin-bottom:.25rem;line-height:1.4}.help-section strong{color:var(--text-primary)}.touch-device{cursor:grab;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.touch-device:active{cursor:grabbing}.goal-card,.month-goal-card,.year-goal-card{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}@media (hover: none) and (pointer: coarse){.goal-card,.month-goal-card,.year-goal-card{touch-action:none;-webkit-user-drag:none}}@media (hover: none) and (pointer: coarse){.goal-card.dragging,.month-goal-card.dragging,.year-goal-card.dragging{opacity:.8;transform:scale(.95);z-index:1000;box-shadow:0 12px 32px #00000026}}@media (min-width: 600px){.day-view .goals-list{grid-template-columns:repeat(5,1fr)}}@media (min-width: 768px){#root{max-width:900px;margin:0 auto;padding:1.5rem}.app-container{padding:0}.date-range{font-size:1rem}}@media (min-width: 1024px){#root{max-width:1200px}.day-view .goals-list{grid-template-columns:repeat(8,1fr)}}.api-integration-status{padding:2rem;max-width:1000px;margin:0 auto;text-align:center}.api-integration-status h2{color:var(--accent-color);margin-bottom:2rem;font-size:2rem}.data-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);transition:transform .2s ease,box-shadow .2s ease}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001f}.summary-card h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.2rem}.summary-card .count{display:block;font-size:2.5rem;font-weight:700;color:var(--accent-color);margin-bottom:1rem}.summary-card .preview{display:flex;flex-direction:column;gap:.5rem;align-items:center}.category-tag{display:inline-block;padding:.3rem .8rem;border-radius:20px;color:#fff;font-size:.8rem;font-weight:500;margin:.2rem}.goal-preview{font-size:.9rem;color:var(--text-secondary);padding:.2rem 0}.next-steps{background:var(--card-bg);border-radius:12px;padding:2rem;box-shadow:var(--card-shadow);margin-top:2rem}.next-steps h3{color:var(--text-primary);margin-bottom:1rem}.next-steps p{color:var(--text-secondary);margin-bottom:.5rem;line-height:1.6}.loading-spinner{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.2rem;color:var(--text-secondary)}.error-message{display:flex;flex-direction:column;justify-content:center;align-items:center;height:50vh;text-align:center}.error-message p{color:var(--error-color);margin-bottom:1rem;font-size:1.1rem}.error-message button{background:var(--accent-color);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:background-color .2s ease}.error-message button:hover{background:var(--accent-hover)}[data-theme=dark] .summary-card{background:var(--card-bg-dark);box-shadow:0 4px 12px #ffffff0d}[data-theme=dark] .summary-card:hover{box-shadow:0 8px 25px #ffffff14}[data-theme=dark] .next-steps{background:var(--card-bg-dark);box-shadow:0 4px 12px #ffffff0d}.go-to-today{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:.75rem}.go-to-today:hover{background:#fff3;border-color:#ffffff4d}.score-breakdown{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2)}.score-breakdown small{font-size:.7rem;opacity:.8}.top-performer{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--background-primary);border-radius:8px;margin-bottom:.5rem;border:1px solid var(--border-color)}.goal-info{display:flex;align-items:center;gap:.75rem;flex:1}.goal-category-badge{font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:12px;color:#fff;white-space:nowrap}.performance-score{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.performance-score span{font-weight:600;font-size:.9rem}.performance-score small{font-size:.7rem;color:var(--text-secondary)}.category-performance{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--background-primary);border-radius:8px;margin-bottom:.5rem;border:1px solid var(--border-color)}.category-info{display:flex;align-items:center;gap:.75rem}.category-badge{font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:12px;color:#fff}.performance-rate{font-weight:600;font-size:.9rem}.performance-details{margin-top:.25rem}.performance-details small{font-size:.7rem;color:var(--text-secondary)}.no-data{text-align:center;padding:1rem;color:var(--text-secondary);font-size:.9rem;font-style:italic}.upcoming-goals{display:flex;flex-direction:column;gap:1rem}.upcoming-day{padding:1rem;background:var(--background-primary);border-radius:8px;border:1px solid var(--border-color)}.day-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.day-date{font-weight:600;font-size:.9rem}.day-count{font-size:.8rem;color:var(--text-secondary);background:var(--background-secondary);padding:.2rem .5rem;border-radius:12px}.day-goals{display:flex;flex-direction:column;gap:.5rem}.upcoming-goal{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--background-secondary);border-radius:6px;border-left:3px solid #ccc}.goal-type{font-size:.7rem;color:var(--text-secondary);background:var(--background-primary);padding:.1rem .4rem;border-radius:8px}.more-goals{font-size:.8rem;color:var(--text-secondary);text-align:center;padding:.5rem;font-style:italic}.no-upcoming{text-align:center;padding:2rem}.no-upcoming p{color:var(--text-secondary);font-size:.9rem;font-style:italic}.landing-page{min-height:100vh;background-color:var(--background-primary)}.nav-header{position:sticky;top:0;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);z-index:100;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:all .3s ease}@media (prefers-color-scheme: dark){.nav-header{background:#0f0f23fa;border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 2px 8px #0000004d}.btn-link:hover{background:#818cf826}}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.brand-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.brand-icon{font-size:1.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.brand-name{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.025em}.auth-buttons{display:flex;align-items:center;gap:1rem}.nav-header .btn-link{background:none;border:none;color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-weight-medium);padding:.5rem 1rem;cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease;text-decoration:none}.nav-header .btn-link:hover{color:var(--text-primary);background-color:var(--background-hover)}.nav-header .btn-primary{font-size:var(--text-base);padding:.625rem 1.25rem;box-shadow:var(--shadow-button)}.brand-logo{display:flex;align-items:center;gap:.75rem}.brand-icon{font-size:1.8rem}.brand-name{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.auth-buttons{display:flex;gap:1rem;align-items:center}.btn-link{background:none;border:none;color:var(--text-primary);padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s ease}.btn-link:hover{color:var(--brand-primary);background:#667eea1a}.btn-primary{background:var(--brand-gradient);border:none;color:#fff;padding:.75rem 1.5rem;font-size:var(--text-base);font-weight:var(--font-weight-semibold);cursor:pointer;border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-button);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-align:center;text-decoration:none;position:relative;overflow:hidden;white-space:nowrap;min-height:2.75rem;line-height:1}.btn-primary:hover{background:var(--brand-gradient-hover);transform:translateY(-1px);box-shadow:var(--shadow-button-hover)}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-primary:focus{outline:none;box-shadow:var(--shadow-focus),var(--shadow-button)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}.btn-large{padding:1rem 2rem;font-size:var(--text-lg);min-height:3.25rem}.btn-full{width:100%}.btn-secondary{background:var(--background-secondary);border:1px solid var(--border-medium);color:var(--text-primary);padding:.75rem 1.5rem;font-size:var(--text-base);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-xs);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-align:center;text-decoration:none;min-height:2.75rem;line-height:1}.btn-secondary:hover{background:var(--background-hover);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-secondary:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.btn-secondary:focus{outline:none;box-shadow:var(--shadow-focus),var(--shadow-xs);border-color:var(--border-focus)}.btn-link{background:none;border:none;color:var(--accent-primary);padding:.5rem;font-size:var(--text-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:all .2s ease}.btn-link:hover{color:var(--accent-primary-hover);text-decoration:none}.link-button{background:none;border:none;color:var(--accent-primary);font-size:inherit;font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0;transition:color .2s ease}.link-button:hover{color:var(--accent-primary-hover)}.btn-arrow{transition:transform .2s ease}.btn-primary:hover .btn-arrow{transform:translate(2px)}.hero-modern{padding:8rem 0 10rem;background:linear-gradient(135deg,var(--background-primary) 0%,var(--background-tertiary) 100%);position:relative;overflow:hidden}.hero-modern:before{content:"";position:absolute;top:0;right:0;width:50%;height:100%;background:linear-gradient(45deg,transparent 0%,rgba(102,126,234,.05) 100%);pointer-events:none}.hero-container{max-width:1200px;margin:0 auto;padding:0 2rem}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;min-height:70vh}.hero-left{z-index:2}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:50px;color:var(--brand-primary);font-size:.875rem;font-weight:500;margin-bottom:2rem}.badge-icon{font-size:1rem}.hero-title{font-size:var(--text-5xl);font-weight:var(--font-weight-extrabold);line-height:var(--leading-tight);color:var(--text-primary);margin-bottom:1.5rem;letter-spacing:-.025em}.text-accent{background:var(--brand-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:var(--text-xl);line-height:var(--leading-relaxed);color:var(--text-secondary);margin-bottom:2rem;max-width:32rem}.hero-features{display:flex;flex-direction:column;gap:1rem;margin-bottom:2.5rem}.feature-point{display:flex;align-items:center;gap:.75rem;color:var(--text-primary);font-weight:500}.feature-icon{font-size:1.2rem;opacity:.8}.cta-section{margin-top:2rem}.cta-note{margin-top:1rem;font-size:.9rem;color:var(--text-tertiary)}.hero-right{position:relative;z-index:1}.hero-visual{position:relative;height:500px}.dashboard-preview{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;overflow:hidden;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:350px;height:400px;z-index:2}.preview-header{background:#f8fafc;padding:1rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid #e2e8f0}.preview-dots{display:flex;gap:.5rem}.preview-dots span{width:12px;height:12px;border-radius:50%;background:#cbd5e1}.preview-dots span:first-child{background:#ef4444}.preview-dots span:nth-child(2){background:#f59e0b}.preview-dots span:nth-child(3){background:#10b981}.preview-title{font-size:.875rem;font-weight:600;color:#1f2937}.preview-content{padding:1.5rem}.preview-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-item{flex:1;text-align:center;padding:1rem;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);border-radius:12px;color:#fff}.stat-number{font-size:1.5rem;font-weight:700;margin-bottom:.25rem;color:#1f2937}.stat-label{font-size:.75rem;color:#4b5563;opacity:1}.preview-goals{display:flex;flex-direction:column;gap:.75rem}.goal-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8fafc;border-radius:8px}.goal-item.completed{background:#f0fdf4}.goal-check{width:20px;height:20px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff}.goal-item.completed .goal-check{background:#10b981}.goal-text{font-size:.875rem;color:#1f2937;font-weight:500}.floating-cards{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.floating-card{position:absolute;background:#fff;border-radius:12px;padding:1rem;box-shadow:0 8px 24px #0000001a;border:1px solid var(--border-light);width:180px}.card-1{top:20%;left:-10%;animation:float 6s ease-in-out infinite}.card-2{top:60%;right:-10%;animation:float 6s ease-in-out infinite 2s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.card-icon{font-size:1.5rem;margin-bottom:.5rem}.card-text{font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.75rem}.card-progress{height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.card-progress .progress-bar{height:100%;background:var(--brand-gradient);border-radius:2px;transition:width .5s ease}.features-modern{padding:8rem 0;background:#fff}.features-container{max-width:1200px;margin:0 auto;padding:0 2rem}.features-header{text-align:center;margin-bottom:4rem}.features-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:50px;color:var(--brand-primary);font-size:.875rem;font-weight:500;margin-bottom:1.5rem}.features-title{font-size:3rem;font-weight:700;color:#1a1a1a;margin-bottom:1.5rem;line-height:1.2}.features-subtitle{font-size:1.2rem;color:#374151;line-height:1.6;max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem}.feature-card{background:var(--background-secondary);border:1px solid var(--border-light);border-radius:16px;padding:2rem;transition:all .3s ease;position:relative}.feature-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 32px #667eea33,0 12px 24px #00000026;border-color:var(--brand-primary)}.feature-card:hover .feature-icon{transform:scale(1.1);filter:brightness(1.1)}.feature-card.featured{grid-row:span 2;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);color:#fff;border:none}.feature-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.feature-icon{font-size:2rem;margin-bottom:1rem;display:block}.feature-icon.large{font-size:3rem}.feature-badge{background:#fff3;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}.feature-card h3{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:inherit}.feature-card p{color:inherit;opacity:.8;line-height:1.6;margin-bottom:1rem}.feature-list{list-style:none;padding:0;margin:0}.feature-list li{padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.2);font-size:.9rem;opacity:.9}.feature-list li:last-child{border-bottom:none}.footer-simple{background:#1e293b;color:#fff;padding:3rem 0 2rem}.footer-container{max-width:1100px;margin:0 auto;padding:0 2rem;text-align:center}.footer-main{margin-bottom:2rem}.footer-brand{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1rem}.footer-brand .brand-icon{font-size:1.5rem}.footer-brand .brand-name{font-size:1.25rem;font-weight:700;color:#fff}.footer-description{color:#94a3b8;font-size:1rem;line-height:1.6}.footer-links{margin-top:1.5rem}.footer-contact-link{display:inline-flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;background:#ffffff1a;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.2);transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.footer-contact-link:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.footer-contact-link:active{transform:translateY(0)}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem}.footer-bottom p{color:#94a3b8;font-size:.875rem;margin:0}@media (max-width: 768px){.nav-container{padding:1rem}.auth-buttons{gap:.5rem}.btn-primary,.btn-link{padding:.5rem 1rem;font-size:.9rem}.hero-modern{padding:4rem 0 6rem}.hero-content{grid-template-columns:1fr;gap:3rem;text-align:center}.hero-title{font-size:var(--text-4xl)}.hero-description{font-size:1.1rem}.hero-features{justify-content:center}.hero-visual{height:400px}.dashboard-preview{width:300px;height:350px}.floating-cards{display:none}.features-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card.featured{grid-row:span 1}.features-title{font-size:2rem}.features-subtitle{font-size:1rem}}@media (max-width: 480px){.nav-container{flex-direction:column;gap:1rem}.hero-title{font-size:var(--text-3xl)}.hero-description{font-size:1rem}.dashboard-preview{width:250px;height:300px}.preview-content{padding:1rem}.preview-stats{flex-direction:column;gap:.5rem}.features-header{margin-bottom:2rem}.features-title{font-size:1.75rem}.feature-card{padding:1.5rem}}.admin-dashboard-dark{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif}.admin-header-dark{position:relative;background:linear-gradient(135deg,#1e293b,#334155);border-bottom:1px solid rgba(148,163,184,.2);overflow:hidden}.admin-header-dark:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 0%,rgba(102,126,234,.1) 100%);pointer-events:none}.admin-logo{display:flex;align-items:center;gap:1rem}.logo-icon{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #667eea4d}.admin-title{font-size:1.5rem;font-weight:700;color:#f8fafc;margin:0;line-height:1.2}.admin-subtitle{font-size:.875rem;color:#94a3b8;margin:0}.admin-status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:50px;font-size:.75rem;font-weight:600;color:#fecaca}.status-dot{width:8px;height:8px;background:#ef4444;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-stats-mini{display:flex;gap:2rem}.mini-stat{text-align:center}.mini-stat-value{display:block;font-size:1.5rem;font-weight:700;color:#f8fafc;line-height:1}.mini-stat-label{display:block;font-size:.75rem;color:#94a3b8;margin-top:.25rem}.user-greeting-header{display:flex;align-items:center;gap:.75rem}.user-avatar-mini{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem;box-shadow:0 2px 8px #0003}.user-details{display:flex;flex-direction:column}.user-name-header{font-size:.875rem;font-weight:600;color:#f8fafc;line-height:1}.user-role-header{font-size:.75rem;color:#94a3b8;margin-top:.125rem}.logout-btn-header{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fecaca;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s ease;cursor:pointer}.logout-btn-header:hover{background:#ef44444d;transform:translateY(-1px)}.admin-nav-dark{background:#1e293bcc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid rgba(148,163,184,.2)}.nav-tabs-dark{display:flex;gap:0}.nav-tab-dark{position:relative;display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:none;border:none;color:#94a3b8;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:0;overflow:hidden}.nav-tab-dark:hover{background:#667eea1a;color:#f8fafc}.nav-tab-dark.active{color:#667eea;background:#667eea26}.tab-icon{font-size:1.125rem}.tab-content{display:flex;flex-direction:column;align-items:flex-start}.tab-label{font-weight:600;line-height:1}.tab-desc{font-size:.75rem;color:#64748b;margin-top:.125rem}.nav-tab-dark.active .tab-desc{color:#a5b4fc}.active-indicator{position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px 3px 0 0}.admin-main-dark{min-height:calc(100vh - 140px);background:linear-gradient(135deg,#0f172a,#1e293b)}.dashboard-content-dark{animation:fadeInUp .6s ease forwards}.dashboard-header-dark{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;background:#1e293b99;border-radius:16px;border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dashboard-title-dark{font-size:2rem;font-weight:700;color:#f8fafc;margin:0}.dashboard-subtitle-dark{font-size:1rem;color:#94a3b8;margin:.5rem 0 0}.last-updated{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem}.stat-card-dark{background:#1e293b99;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:1.5rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s ease;animation:fadeInUp .6s ease forwards;opacity:0;transform:translateY(20px)}.stat-card-dark:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000004d;border-color:#667eea66}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.stat-card-header-dark{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.stat-icon-dark{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-icon-dark.users{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.stat-icon-dark.goals{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon-dark.completions,.stat-icon-dark.reports-ok{background:linear-gradient(135deg,#10b981,#047857)}.stat-icon-dark.reports-warning{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-value-dark{font-size:2rem;font-weight:700;color:#f8fafc;line-height:1}.stat-card-body-dark{margin-bottom:1rem}.stat-label-dark{font-size:.875rem;font-weight:600;color:#94a3b8;margin-bottom:.5rem}.stat-trend-dark{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500}.stat-trend-dark.positive{color:#34d399}.stat-trend-dark.negative{color:#f87171}.trend-icon-dark{font-size:.875rem}.stat-card-footer-dark{border-top:1px solid rgba(148,163,184,.2);padding-top:1rem}.progress-dark{height:6px;background:#94a3b833;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-bar-dark{height:100%;border-radius:3px;transition:width .8s ease}.progress-bar-dark:not(.goals):not(.completions):not(.reports-warning):not(.reports-ok){background:linear-gradient(90deg,#3b82f6,#1d4ed8)}.progress-bar-dark.goals{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-bar-dark.completions,.progress-bar-dark.reports-ok{background:linear-gradient(90deg,#10b981,#047857)}.progress-bar-dark.reports-warning{background:linear-gradient(90deg,#ef4444,#dc2626)}.progress-labels-dark{display:flex;justify-content:space-between;font-size:.75rem;color:#64748b}.users-content-dark{animation:fadeInUp .6s ease forwards}.users-header-dark{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:1.5rem;background:#1e293b99;border-radius:16px;border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.users-title-dark{font-size:1.75rem;font-weight:700;color:#f8fafc;margin:0}.users-subtitle-dark{font-size:1rem;color:#94a3b8;margin:.5rem 0 0}.users-count{color:#667eea;font-weight:600}.search-container-dark{display:flex;align-items:center;gap:1rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#64748b;font-size:1rem;z-index:1}.search-input-dark{width:280px;padding:.75rem 1rem .75rem 2.5rem;background:#0f172acc;border:1px solid rgba(148,163,184,.3);border-radius:12px;color:#f8fafc;font-size:.875rem;transition:all .2s ease}.search-input-dark:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-input-dark::placeholder{color:#64748b}.clear-search-btn{position:absolute;right:8px;width:20px;height:20px;background:#94a3b833;border:none;border-radius:50%;color:#94a3b8;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-search-btn:hover{background:#ef444433;color:#f87171}.users-card-dark{background:#1e293b99;border:1px solid rgba(148,163,184,.2);border-radius:16px;padding:1.5rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.user-row-dark{padding:1.5rem;border-bottom:1px solid rgba(148,163,184,.2);transition:all .2s ease;animation:fadeInUp .6s ease forwards;opacity:0;transform:translateY(10px)}.user-row-dark:last-child{border-bottom:none}.user-row-dark:hover{background:#667eea0d;border-radius:12px}.user-content-dark{display:flex;justify-content:space-between;align-items:center}.user-profile-dark{display:flex;align-items:center;gap:1rem;flex:1}.user-avatar-dark{position:relative}.avatar-container-dark{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003}.avatar-text-dark{color:#fff;font-weight:700;font-size:1.25rem}.admin-crown{position:absolute;top:-4px;right:-4px;font-size:1rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.user-details-dark{flex:1}.user-name-section{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.user-name-dark{font-size:1.125rem;font-weight:600;color:#f8fafc;margin:0}.admin-tag-dark{padding:.25rem .5rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.625rem;font-weight:700;border-radius:6px;letter-spacing:.025em}.user-email-dark{color:#94a3b8;font-size:.875rem;margin:0 0 .75rem}.user-metrics-dark{display:flex;align-items:center;gap:.75rem}.metric-item{display:flex;align-items:center;gap:.25rem}.metric-icon{font-size:.875rem}.metric-value{font-weight:600;color:#f8fafc;font-size:.875rem}.metric-label{color:#64748b;font-size:.75rem}.metric-separator{color:#475569;font-size:.75rem}.user-actions-dark{display:flex;align-items:center}.action-group-dark{display:flex;gap:.5rem}.action-btn-dark{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid transparent;border-radius:8px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.action-btn-dark.success{background:#10b9811a;border-color:#10b9814d;color:#34d399}.action-btn-dark.success:hover{background:#10b98133;transform:translateY(-1px)}.action-btn-dark.warning{background:#f59e0b1a;border-color:#f59e0b4d;color:#fbbf24}.action-btn-dark.warning:hover{background:#f59e0b33;transform:translateY(-1px)}.action-btn-dark.danger{background:#ef44441a;border-color:#ef44444d;color:#f87171}.action-btn-dark.danger:hover{background:#ef444433;transform:translateY(-1px)}.btn-icon-dark{font-size:.875rem}.admin-indicator-dark{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px;color:#34d399;font-size:.75rem;font-weight:500}.error-alert-dark{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;margin-bottom:2rem}.error-icon{font-size:1.25rem;color:#f87171;margin-top:.125rem}.error-title{font-size:.875rem;font-weight:600;color:#f87171;margin:0 0 .25rem}.error-message{font-size:.875rem;color:#fca5a5;margin:0;line-height:1.4}@media (max-width: 1024px){.admin-stats-mini{gap:1rem}.dashboard-header-dark,.users-header-dark{flex-direction:column;align-items:flex-start;gap:1rem}.search-input-dark{width:240px}}@media (max-width: 768px){.nav-tabs-dark{flex-wrap:wrap}.nav-tab-dark{flex:1;min-width:120px;justify-content:center}.user-content-dark{flex-direction:column;align-items:flex-start;gap:1rem}.user-actions-dark{width:100%;justify-content:flex-end}.action-group-dark{flex-wrap:wrap}.search-input-dark{width:200px}.admin-stats-mini{flex-direction:column;gap:.5rem}.user-greeting-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 640px){.dashboard-header-dark,.users-header-dark{padding:1rem}.dashboard-title-dark,.users-title-dark{font-size:1.5rem}.stat-card-dark{padding:1rem}.stat-value-dark{font-size:1.5rem}.user-row-dark{padding:1rem}.search-input-dark{width:100%;max-width:280px}}
