*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4A6B5C;--primary-light: #6B8E7E;--primary-dark: #3E5A4D;--primary-bg: #EAEFEB;--bg: #FAF7F2;--card: #FFFFFF;--text: #1A1A1A;--text-muted: #6B6B66;--border: #D4CFC4;--color-success: #4A6B5C;--color-warning: #C49A3A;--color-orange: #C47A3A;--color-danger: #B4533F;--color-muted: #C0BAAD;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--nav-height: 64px;--radius: 12px;--radius-sm: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(26, 26, 26, .04);--shadow-md: 0 2px 8px rgba(26, 26, 26, .06)}:root[data-theme=dark]{--primary: #6B8E7E;--primary-light: #6B8E7E;--primary-dark: #7FA192;--primary-bg: #26302B;--bg: #1C1A17;--card: #232019;--text: #FAF7F2;--text-muted: #A8A39A;--border: #3A3833;--color-success: #6B8E7E;--color-warning: #D6B25C;--color-orange: #D69A5C;--color-danger: #D17A66;--color-muted: #3A3833;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4)}:root[data-theme=dark] .adherence-green{background:#26302b}:root[data-theme=dark] .adherence-yellow{background:#2e2a1c}:root[data-theme=dark] .adherence-orange{background:#2e251c}:root[data-theme=dark] .adherence-red{background:#2e1f1c}:root[data-theme=dark] .adherence-green .adherence-score{color:#6b8e7e}:root[data-theme=dark] .adherence-yellow .adherence-score{color:#d6b25c}:root[data-theme=dark] .adherence-orange .adherence-score{color:#d69a5c}:root[data-theme=dark] .adherence-red .adherence-score{color:#d17a66}:root[data-theme=dark] .error-alert{background:#2e1f1c;color:#d17a66}:root[data-theme=dark] .meal-action-btn.delete:hover,:root[data-theme=dark] .frequent-meal-delete:hover{background:#2e1f1c}:root[data-theme=dark] .form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23A8A39A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}html{-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:16px;line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased}#root{max-width:480px;margin:0 auto;min-height:100vh;position:relative}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom,0px) + 8px);overflow-y:auto}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:calc(var(--nav-height) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--card);border-top:.5px solid var(--border);display:flex;align-items:stretch;z-index:100;box-shadow:0 -1px 4px #1a1a1a0d}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--text-muted);padding:6px 4px;transition:color .15s;cursor:pointer;border:none;background:none}.nav-item.active{color:var(--primary)}.nav-icon{font-size:20px;line-height:1}.nav-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.nav-label{font-size:10px;font-weight:500}.page{padding:16px;display:flex;flex-direction:column;gap:12px;min-height:calc(100vh - var(--nav-height))}.page-header{padding-top:8px}.page-title{font-size:22px;font-weight:500;letter-spacing:-.015em;color:var(--text);line-height:1.2}.page-subtitle{font-size:14px;color:var(--text-muted);margin-top:2px;text-transform:capitalize}.card{background:var(--card);border-radius:var(--radius);padding:16px;border:.5px solid var(--border);box-shadow:var(--shadow-sm)}.card-title{font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:12px}.adherence-badge{border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px}.adherence-green{background:#dcfce7}.adherence-yellow{background:#fef9c3}.adherence-orange{background:#ffedd5}.adherence-red{background:#fee2e2}.adherence-score{font-size:30px;font-weight:500;letter-spacing:-.02em;line-height:1}.adherence-green .adherence-score{color:#15803d}.adherence-yellow .adherence-score{color:#854d0e}.adherence-orange .adherence-score{color:#9a3412}.adherence-red .adherence-score{color:#b91c1c}.adherence-info{display:flex;flex-direction:column;gap:2px}.adherence-level{font-size:15px;font-weight:700;color:var(--text)}.adherence-label{font-size:13px;color:var(--text-muted)}.adherence-message{font-size:13px;color:var(--text-muted);font-style:italic}.macro-bars{display:flex;flex-direction:column;gap:12px}.macro-bar{display:flex;flex-direction:column;gap:5px}.macro-bar-header{display:flex;justify-content:space-between;align-items:baseline}.macro-bar-label{font-size:14px;font-weight:600;color:var(--text)}.macro-bar-values{font-size:13px;color:var(--text-muted)}.macro-bar-values strong{color:var(--text);font-weight:600}.progress-track{height:9px;background:var(--border);border-radius:5px;overflow:hidden}.progress-fill{height:100%;border-radius:5px;transition:width .4s cubic-bezier(.4,0,.2,1)}.macro-bar-pct{font-size:12px;color:var(--text-muted);text-align:right}.weight-display{display:flex;align-items:baseline;gap:6px}.weight-value{font-size:36px;font-weight:500;letter-spacing:-.025em;color:var(--text);line-height:1}.weight-unit{font-size:16px;color:var(--text-muted);font-weight:500}.weight-meta{margin-top:6px;display:flex;flex-direction:column;gap:3px}.weight-distance{font-size:14px;color:var(--text-muted)}.weight-distance strong{color:var(--primary)}.weight-change{font-size:14px;font-weight:600}.weight-change.negative{color:var(--color-success)}.weight-change.positive{color:var(--color-danger)}.btn{display:block;width:100%;padding:14px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:16px;font-weight:500;text-align:center;text-decoration:none;transition:opacity .15s,transform .1s,background .15s;line-height:1}.btn:active{transform:scale(.97);opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-ghost{background:var(--bg);color:var(--text-muted);border:1.5px solid var(--border)}.btn-danger{background:var(--color-danger);color:#fff}.btn-sm{padding:8px 14px;font-size:14px;width:auto;display:inline-block;border-radius:var(--radius-sm)}.btn-lg{padding:16px;font-size:17px}.btn-icon{display:flex;align-items:center;justify-content:center;gap:8px}.form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:14px;font-weight:600;color:var(--text-muted)}.form-input,.form-select,.form-textarea{padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:16px;color:var(--text);background:var(--card);width:100%;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11f}.form-textarea{resize:vertical;min-height:80px}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-hint{font-size:12px;color:var(--text-muted)}.form-error{font-size:13px;color:var(--color-danger)}.macros-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.meal-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.meal-type-option{padding:10px 6px;border:2px solid var(--border);border-radius:10px;background:var(--card);cursor:pointer;text-align:center;font-size:12px;font-weight:600;color:var(--text-muted);transition:all .15s;-webkit-user-select:none;user-select:none}.meal-type-option.selected{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.tabs{display:flex;background:var(--border);border-radius:10px;padding:3px;gap:2px}.tab{flex:1;padding:9px;border:none;background:transparent;border-radius:7px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}.tab.active{background:var(--card);color:var(--primary);box-shadow:var(--shadow-sm)}.frequent-meal-card{display:flex;align-items:stretch;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.frequent-meal-main{flex:1;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s,transform .1s;min-width:0}.frequent-meal-main:hover{background:var(--primary-bg)}.frequent-meal-main:active{transform:scale(.99)}.frequent-meal-main:disabled{opacity:.5;cursor:not-allowed}.frequent-meal-info{display:flex;flex-direction:column;gap:6px;min-width:0}.frequent-meal-name{font-size:15px;font-weight:600;color:var(--text)}.frequent-meal-add{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;flex-shrink:0}.frequent-meal-delete{border:none;border-left:1px solid var(--border);background:none;cursor:pointer;color:var(--text-muted);padding:0 16px;font-size:14px;transition:background .15s,color .15s}.frequent-meal-delete:hover{background:#fee2e2;color:var(--color-danger)}.db-list{display:flex;flex-direction:column;gap:8px}.db-back{align-self:flex-start;background:none;border:none;color:var(--primary);font-size:14px;font-weight:500;cursor:pointer;padding:4px 0}.db-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;cursor:pointer;background:var(--card);border:.5px solid var(--border);border-radius:var(--radius);padding:14px;color:var(--text);transition:background .15s,transform .1s}.db-row:hover{background:var(--primary-bg)}.db-row:active{transform:scale(.99)}.db-row-main{display:flex;flex-direction:column;gap:3px;min-width:0}.db-row-name{font-size:15px;font-weight:500;color:var(--text)}.db-row-meta{font-size:13px;color:var(--text-muted)}.db-chevron{font-size:20px;color:var(--text-muted);flex-shrink:0;line-height:1}.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text)}.form-checkbox input{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.meals-list{display:flex;flex-direction:column;gap:8px}.meal-card{background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}.meal-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}.meal-type-badge{font-size:11px;font-weight:500;padding:3px 9px;border-radius:20px;background:var(--primary-bg);color:var(--primary);white-space:nowrap}.meal-actions{display:flex;gap:4px}.meal-action-btn{background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-muted);padding:4px 8px;border-radius:6px;transition:background .15s,color .15s;font-weight:500}.meal-action-btn:hover{background:var(--border)}.meal-action-btn.delete:hover{background:#fee2e2;color:var(--color-danger)}.meal-description{font-size:15px;font-weight:500;color:var(--text);margin-bottom:6px}.meal-macros{display:flex;gap:12px;flex-wrap:wrap}.meal-macro{font-size:13px;color:var(--text-muted)}.meal-macro strong{color:var(--text);font-weight:600}.meal-notes{font-size:13px;color:var(--text-muted);font-style:italic;margin-top:4px}.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.auth-brand{text-align:center;margin-bottom:28px}.auth-logo{font-size:30px}.wordmark{display:inline-flex;flex-direction:column;align-items:center;line-height:1}.wordmark-name{font-weight:500;letter-spacing:-.04em;color:var(--text)}.wordmark-dot{color:var(--primary);font-weight:400}.wordmark-rule{width:100%;border-top:.5px solid var(--border);margin:.16em 0 .13em}.wordmark-descriptor{font-size:.34em;font-weight:500;letter-spacing:.38em;text-indent:.38em;text-transform:uppercase;color:var(--text-muted)}.logomark{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#faf7f2;border-radius:var(--radius-sm);font-weight:500;line-height:1}.auth-tagline{font-size:14px;color:var(--text-muted);margin-top:4px}.auth-card{background:var(--card);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:400px;box-shadow:var(--shadow-md)}.auth-card-title{font-size:20px;font-weight:500;letter-spacing:-.015em;color:var(--text);margin-bottom:20px}.auth-switch{text-align:center;margin-top:20px;font-size:14px;color:var(--text-muted)}.auth-switch a{color:var(--primary);font-weight:600;text-decoration:none}.error-alert{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;text-align:center}.success-alert{background:var(--primary-bg);color:var(--primary);padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;text-align:center}.onboarding-page{min-height:100vh;padding:24px;background:var(--bg);display:flex;flex-direction:column;gap:20px}.onboarding-header{text-align:center;padding-top:16px}.onboarding-logo{font-size:26px;margin-bottom:16px}.step-indicators{display:flex;justify-content:center;gap:6px;margin-bottom:8px}.step-dot{height:8px;border-radius:4px;background:var(--border);transition:all .3s;width:8px}.step-dot.active{background:var(--primary);width:24px}.step-dot.done{background:var(--primary-light)}.onboarding-step-title{font-size:20px;font-weight:500;letter-spacing:-.015em;color:var(--text)}.onboarding-step-desc{font-size:14px;color:var(--text-muted);margin-top:4px}.onboarding-card{background:var(--card);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.onboarding-nav{display:flex;gap:10px}.onboarding-nav .btn{flex:1}.section{display:flex;flex-direction:column;gap:8px}.section-header{display:flex;justify-content:space-between;align-items:center}.section-title{font-size:16px;font-weight:500;color:var(--text)}.empty-state{text-align:center;padding:32px 16px;display:flex;flex-direction:column;gap:12px;align-items:center;color:var(--text-muted)}.empty-icon{font-size:40px;opacity:.4}.empty-title{font-size:16px;font-weight:600;color:var(--text)}.empty-text{font-size:14px}.range-selector{display:flex;background:var(--border);border-radius:10px;padding:3px;gap:2px}.range-btn{flex:1;padding:8px;border:none;background:transparent;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-muted);transition:all .15s}.range-btn.active{background:var(--card);color:var(--primary);box-shadow:var(--shadow-sm)}.chart-wrapper{margin-top:4px}.chart-title{font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:8px}.date-nav{display:flex;align-items:center;gap:8px}.date-nav-btn{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--text-muted);transition:all .15s;flex-shrink:0}.date-nav-btn:hover{border-color:var(--primary);color:var(--primary)}.date-nav-input{flex:1;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-weight:600;color:var(--text);background:var(--card);text-align:center;cursor:pointer}.date-nav-input:focus{outline:none;border-color:var(--primary)}.profile-header{display:flex;align-items:center;gap:14px}.profile-avatar{width:56px;height:56px;background:var(--primary-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--primary);flex-shrink:0}.profile-name{font-size:18px;font-weight:700;color:var(--text)}.profile-email{font-size:13px;color:var(--text-muted)}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat-item{text-align:center;padding:10px 8px;background:var(--bg);border-radius:var(--radius-sm)}.stat-value{font-size:18px;font-weight:700;color:var(--text)}.stat-label{font-size:11px;color:var(--text-muted);margin-top:2px}.divider{height:1px;background:var(--border)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-small{font-size:13px}.fw-bold{font-weight:700}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.flex-row{display:flex;align-items:center;gap:8px}.flex-between{display:flex;justify-content:space-between;align-items:center}@media (min-width: 480px){#root{box-shadow:0 0 40px #0000001a}.bottom-nav{border-radius:0}}
