:root{--bg-primary: #fef9ef;--bg-secondary: #f5eee1;--bg-card: #ffffff;--bg-card-hover: #fffdfb;--bg-glass: rgba(245, 238, 225, .5);--bg-input: #f5eee1;--border-subtle: rgba(209, 201, 191, .4);--border-default: #d1c9bf;--border-accent: rgba(176, 90, 54, .3);--text-primary: #2a2b2f;--text-secondary: #515151;--text-muted: #737373;--text-accent: #b05a36;--accent-primary: #b05a36;--accent-hover: #9a4e2e;--accent-light: rgba(176, 90, 54, .1);--accent-soft: rgba(176, 90, 54, .06);--success: #5a9a6b;--success-bg: rgba(90, 154, 107, .1);--warning: #c78c3c;--warning-bg: rgba(199, 140, 60, .1);--danger: #c45454;--danger-bg: rgba(196, 84, 84, .1);--info: #5481b0;--info-bg: rgba(84, 129, 176, .1);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--font-heading: "Playfair Display", "Georgia", "Times New Roman", serif;--font-family: "Inter", system-ui, -apple-system, sans-serif;--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;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 24px;--radius-pill: 40px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(42, 43, 47, .04), 0 1px 2px rgba(42, 43, 47, .02);--shadow-md: 0 4px 12px rgba(42, 43, 47, .06), 0 2px 4px rgba(42, 43, 47, .04);--shadow-lg: 0 8px 24px rgba(42, 43, 47, .08), 0 4px 8px rgba(42, 43, 47, .04);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px;--mobile-nav-height: 64px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{position:relative;z-index:1;min-height:100vh}a{color:var(--text-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}img{max-width:100%;display:block}input,select,textarea,button{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b0a898}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-slow)}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid var(--border-subtle)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md)}.sidebar-logo-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--accent-primary);display:flex;align-items:center;justify-content:center;color:#fef9ef;font-weight:800;font-size:var(--text-lg)}.sidebar-logo-text{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.sidebar-nav{flex:1;padding:var(--space-md);overflow-y:auto}.sidebar-nav-group{margin-bottom:var(--space-lg)}.sidebar-nav-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs)}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;background:none;width:100%;text-align:left}.sidebar-nav-item:hover{background:#b05a360f;color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-light);color:var(--accent-primary);font-weight:600}.sidebar-nav-item svg{width:18px;height:18px;flex-shrink:0}.sidebar-user{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:var(--space-md)}.sidebar-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--accent-primary);display:flex;align-items:center;justify-content:center;color:#fef9ef;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:color var(--transition-fast)}.sidebar-logout-btn:hover{color:var(--danger)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.page-container{padding:var(--space-xl) var(--space-2xl);max-width:1200px;margin:0 auto}.page-header{margin-bottom:var(--space-xl)}.page-title{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:600;letter-spacing:-.02em;margin-bottom:var(--space-xs);color:var(--text-primary)}.page-title-gradient{color:var(--accent-primary);font-style:italic}.page-subtitle{font-size:var(--text-base);color:var(--text-secondary)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-default)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.card-title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.card-value{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.card-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-primary);opacity:0;transition:opacity var(--transition-base)}.stat-card:hover:before{opacity:1}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.stat-icon.emerald{background:#5a9a6b1a;color:var(--success)}.stat-icon.blue{background:#5481b01a;color:var(--info)}.stat-icon.amber{background:#c78c3c1a;color:var(--warning)}.stat-icon.rose{background:#c454541a;color:var(--danger)}.stat-icon.purple{background:#8b5ca51a;color:#8b5ca5}.stat-icon.cyan{background:#4c94a51a;color:#4c94a5}.stat-trend{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-top:var(--space-sm)}.stat-trend.up{background:var(--success-bg);color:var(--success)}.stat-trend.down{background:var(--danger-bg);color:var(--danger)}.stat-trend.neutral{background:#7373731a;color:var(--text-secondary)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-md);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-base);transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #b05a361a;background:#fff}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{min-height:100px;resize:vertical}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-xs)}.slider-container{display:flex;align-items:center;gap:var(--space-md)}.slider-value{font-size:var(--text-2xl);font-weight:700;min-width:40px;text-align:center;color:var(--accent-primary)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;background:var(--bg-input);border-radius:var(--radius-full);outline:none;border:1px solid var(--border-subtle)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent-primary);cursor:pointer;box-shadow:0 2px 6px #b05a3640;transition:transform var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.toggle-container{display:flex;gap:var(--space-sm)}.toggle-btn{padding:var(--space-sm) var(--space-lg);border:1px solid var(--border-default);border-radius:var(--radius-pill);background:transparent;color:var(--text-secondary);cursor:pointer;font-weight:500;transition:all var(--transition-fast)}.toggle-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.toggle-btn.active{background:var(--accent-primary);color:#fef9ef;border-color:var(--accent-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:600;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fef9ef;box-shadow:0 2px 8px #b05a3633}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #b05a364d}.btn-secondary{background:transparent;color:var(--accent-primary);border:1px solid var(--accent-primary)}.btn-secondary:hover:not(:disabled){background:var(--accent-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:var(--accent-soft)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(196,84,84,.2)}.btn-danger:hover:not(:disabled){background:#c4545426}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--text-base)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs)}.btn-full{width:100%}.chart-container{width:100%;height:300px}.chart-container .recharts-cartesian-grid-horizontal line,.chart-container .recharts-cartesian-grid-vertical line{stroke:var(--border-subtle)}.chart-container .recharts-text{fill:var(--text-muted);font-size:12px}.progress-bar{width:100%;height:8px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);background:var(--accent-primary);transition:width var(--transition-slow)}.progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm);font-size:var(--text-sm)}.progress-label-value{font-weight:600;color:var(--accent-primary)}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:var(--space-md);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-default)}.data-table td{padding:var(--space-md);font-size:var(--text-sm);border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.data-table tr:hover td{background:var(--accent-soft);color:var(--text-primary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg);background:var(--bg-secondary)}.login-card{width:100%;max-width:420px;padding:var(--space-2xl)}.login-logo{text-align:center;margin-bottom:var(--space-xl)}.login-logo-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--accent-primary);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md);font-size:var(--text-2xl);font-weight:900;color:#fef9ef}.login-title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-xs);color:var(--text-primary)}.login-subtitle{color:var(--text-secondary);font-size:var(--text-sm)}.login-error{padding:var(--space-md);background:var(--danger-bg);border:1px solid rgba(196,84,84,.2);border-radius:var(--radius-md);color:var(--danger);font-size:var(--text-sm);margin-bottom:var(--space-md)}.login-footer{text-align:center;margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--text-secondary)}.login-footer button{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-weight:600}.login-footer button:hover{text-decoration:underline}.stepper{margin-bottom:var(--space-xl)}.stepper-progress{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-md)}.stepper-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-input);border:1px solid var(--border-default);transition:all var(--transition-fast)}.stepper-dot.active{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 8px #b05a364d}.stepper-dot.completed{background:var(--accent-primary);border-color:var(--accent-primary)}.stepper-info{font-size:var(--text-sm);color:var(--text-muted)}.step-question{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-lg);line-height:1.4;color:var(--text-primary)}.stepper-nav{display:flex;justify-content:space-between;margin-top:var(--space-xl)}.meal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-sm);overflow-x:auto}.meal-day{min-width:140px}.meal-day-header{font-size:var(--text-sm);font-weight:600;padding:var(--space-sm);text-align:center;background:var(--accent-light);color:var(--accent-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;border:1px solid var(--border-accent)}.meal-slot{padding:var(--space-sm);border:1px solid var(--border-subtle);border-top:none;min-height:60px;font-size:var(--text-xs);cursor:pointer;transition:background var(--transition-fast);background:var(--bg-card)}.meal-slot:last-child{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.meal-slot:hover{background:var(--accent-soft)}.meal-slot-label{font-weight:600;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;font-size:10px;letter-spacing:.05em}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl)}.empty-state-icon{width:64px;height:64px;border-radius:var(--radius-full);background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);color:var(--accent-primary)}.empty-state-title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.empty-state-text{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-lg)}.tabs{display:flex;gap:var(--space-xs);background:var(--bg-secondary);border-radius:var(--radius-md);padding:4px;margin-bottom:var(--space-lg);overflow-x:auto;border:1px solid var(--border-subtle)}.tab-btn{padding:var(--space-sm) var(--space-md);border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background:var(--bg-card);color:var(--accent-primary);box-shadow:var(--shadow-sm);font-weight:600}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-in{animation:fadeIn .4s ease forwards}.animate-slide-up{animation:slideUp .5s ease forwards}.mobile-header,.mobile-nav{display:none}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0;padding-bottom:calc(var(--mobile-nav-height) + var(--space-lg))}.page-container{padding:var(--space-md)}.page-title{font-size:var(--text-2xl)}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:50}.mobile-header-logo{display:flex;align-items:center;gap:var(--space-sm)}.mobile-header-logo-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--accent-primary);display:flex;align-items:center;justify-content:center;color:#fef9ef;font-weight:800;font-size:var(--text-sm)}.mobile-header-logo-text{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-height);background:var(--bg-secondary);border-top:1px solid var(--border-subtle);z-index:100;justify-content:space-around;align-items:center;padding:0 var(--space-sm)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) var(--space-sm);border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:10px;font-weight:500;transition:color var(--transition-fast);border-radius:var(--radius-sm)}.mobile-nav-item.active{color:var(--accent-primary)}.mobile-nav-item svg{width:22px;height:22px}.stat-grid{grid-template-columns:repeat(2,1fr)}.two-col,.three-col{grid-template-columns:1fr}.meal-grid{grid-template-columns:repeat(3,1fr)}.chart-container{height:220px}.stepper-progress{flex-wrap:wrap}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr}.meal-grid{grid-template-columns:repeat(2,1fr)}}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.w-full{width:100%}
