:root{--app-font: "Bricolage Grotesque", sans-serif;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;font-family:var(--app-font)}.recipe-title{font-family:Bricolage Grotesque,sans-serif;font-weight:600;letter-spacing:-.02em}.modal-meta .pill{font-family:Bricolage Grotesque,sans-serif;font-weight:500}.chip-tag{font-family:Bricolage Grotesque,sans-serif;font-weight:400}a{color:inherit;text-decoration:none}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-main);background-color:var(--page-bg);--page-bg: #f4f4f5;--app-bg: #f4f4f5;--card-soft: #ffece2;--card-softer: var(--zdk-bg-soft);--card-white: #ffffff;--accent-main: var(--zdk-dark);--accent-main-hover: var(--zdk-dark-hover);--accent-main-active: var(--zdk-dark-active);--accent-peach: var(--zdk-peach);--accent-peach-hover: var(--zdk-peach-hover);--accent-peach-active: var(--zdk-peach-active);--text-on-peach: var(--zdk-text-on-peach);--text-main: var(--zdk-dark);--text-muted: #6b7280;--text-subtle: #9ca3af;--border-soft: var(--zdk-border-soft);--status-ok-bg: #ecfdf3;--status-ok-text: #166534;--status-warn-bg: #fef3c7;--status-warn-text: #92400e;--status-critical-bg: #fee2e2;--status-critical-text: #b91c1c;--ui-bg: #f7f6f4;--ui-surface: #ffffff;--ui-text: #1f1f1f;--ui-text-muted: #6b7280;--ui-border: #e6e2dc;--ui-primary: #bf570f;--ui-primary-hover: #a64a0c;--ui-primary-pressed: #8f3f0a;--ui-text-on-primary: #ffffff;--ui-ghost: #f1efec;--ui-ghost-hover: #ebe7e2;--ui-ghost-pressed: #e1dbd3;--bottom-nav-height: 0px}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--ui-bg)}.app-root{min-height:100vh;padding:16px 0 32px;background:var(--app-bg);color:var(--text-main)}.page{max-width:1120px;margin:0 auto;padding:16px 0}.content{width:100%;margin:0 auto 32px}.pageHeader{display:flex;flex-direction:column;gap:12px;padding:32px 0 16px;margin-bottom:-20px}.pageHeaderTop{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.pageHeaderActions{display:inline-flex;gap:8px;align-items:center;margin-left:auto}.plan-mobile-header-actions{display:inline-flex;gap:10px}.header-icon-btn{width:40px;height:40px!important;min-height:40px;padding:0!important;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;position:relative;box-shadow:0 8px 18px #00000014!important;border:1px solid var(--ui-border)!important;background:var(--ui-surface)!important;color:var(--ui-text)!important;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease}.header-icon-btn:hover{background:var(--ui-ghost)!important;border-color:var(--ui-border)!important;box-shadow:0 10px 22px #0000001f!important}.header-icon-btn:active{background:var(--ui-ghost-pressed)!important;box-shadow:0 6px 14px #00000014!important}.header-icon-badge{position:absolute;top:-4px;right:-4px;background:var(--accent-main);color:var(--text-on-peach);border-radius:999px;padding:2px 6px;font-size:11px;font-weight:700;line-height:1;box-shadow:0 4px 10px #0f172a2e}.pageHeaderTitle{margin:0 0 -10px;font-size:clamp(26px,4vw,30px);line-height:1.2;font-weight:700;color:var(--text-main)}.pageHeaderDescription{margin:0;font-size:16px;line-height:1.6;color:var(--text-muted)}@media(max-width:720px){.pageHeaderTop{flex-direction:row;align-items:center;gap:12px}}.plan-layout,.db-layout,.shop-layout{width:100%;display:flex;flex-direction:column}.shop-layout{margin-top:0}.brand-wrap{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:8px;gap:12px;flex-wrap:wrap}.brand-title{display:inline-flex;align-items:center;font-size:20px;font-weight:600;color:var(--text-main);margin:0}.brand-actions{margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.brand-logo{height:48px;width:auto}.logo-wrapper{width:36px;height:36px;border-radius:50%;overflow:hidden;box-shadow:0 4px 12px #0000001f;display:flex;align-items:center;justify-content:center}.logo-img{width:100%;height:100%;object-fit:cover;display:block}.app-header{display:flex;align-items:center;padding:16px 0;gap:24px;flex-wrap:wrap}.app-header-left{display:flex;align-items:center;gap:12px;min-width:0}.share-cta{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.share-btn{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:16px;border:1px solid var(--zdk-border-soft);background:linear-gradient(135deg,#fff3e6,#ffe1cd);color:var(--text-main);font-weight:700;cursor:pointer;box-shadow:0 8px 18px #00000014;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.share-btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0000001f;background:linear-gradient(135deg,#ffe8d8,#ffd8be)}.share-btn:active{transform:translateY(0);background:linear-gradient(135deg,#ffe0ca,#ffd0b3)}.share-btn:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:0 6px 12px #00000014}.share-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:12px;background:#fff6ed;box-shadow:inset 0 1px #fffc;font-size:16px}.share-body{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.share-title{font-size:14px;line-height:1.2}.share-subtitle{font-size:12px;color:var(--text-muted)}.share-feedback{margin:0;font-size:12px;color:var(--text-muted);text-align:right}.share-feedback-error{color:var(--status-critical-text)}@media(max-width:720px){.share-cta{width:100%;align-items:stretch}.share-btn{width:100%;justify-content:center}.share-feedback{text-align:left}}.user-menu{position:relative}.user-trigger{width:44px;height:44px;border-radius:50%;border:none;background:#fff;box-shadow:0 4px 12px #00000014;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .16s ease,box-shadow .16s ease}.user-trigger:hover{transform:translateY(-1px);box-shadow:0 8px 18px #0000001f}.user-trigger:focus-visible{outline:3px solid rgba(201,109,45,.35);outline-offset:2px}.user-trigger-icon{font-size:18px}.user-dropdown{position:absolute;right:0;top:calc(100% + 10px);min-width:220px;background:#fff;border-radius:16px;padding:16px;box-shadow:0 18px 30px #0000001f;z-index:10}.user-menu-list{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:6px}.user-menu-item{width:100%;border:none;border-radius:14px;padding:10px 12px;background:var(--card-softer);display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .16s ease,transform .16s ease;font:inherit;text-align:left}.user-menu-item:disabled{cursor:not-allowed;opacity:.5}.user-menu-item:not(:disabled):hover{background:#f6ede3;transform:translateY(-1px)}.user-menu-item-icon{display:inline-flex;width:32px;height:32px;border-radius:12px;align-items:center;justify-content:center;font-size:16px;background:#fff4ed}.user-menu-item-body{display:flex;flex-direction:column;gap:2px}.user-menu-item-label{font-weight:600;font-size:14px;color:var(--text-main)}.user-menu-item-desc{font-size:12px;color:var(--text-muted)}.user-menu-divider{width:100%;height:1px;background:#0000000f;margin:10px 0 14px}.user-email{font-size:13px;color:#8d7a69;margin-bottom:10px;word-break:break-word}.user-error{font-size:13px;color:#c62828;margin-bottom:10px}.user-dropdown-btn{width:100%;border:none;border-radius:12px;padding:10px 16px;background:#c96d2d;color:#fff;font-weight:600;cursor:pointer}.user-dropdown-btn:disabled{opacity:.65;cursor:not-allowed}.user-settings-modal-overlay{position:fixed;inset:0;background:#140c0673;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.user-settings-modal{background:#fff;border-radius:16px;width:min(420px,90vw);box-shadow:0 18px 36px #0000002e;padding:18px 18px 16px}.user-settings-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.user-settings-modal-icon{width:40px;height:40px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:#fff4ed;font-size:18px}.user-settings-modal-titles{flex:1;display:flex;flex-direction:column;gap:4px}.user-settings-modal-title{font-weight:700;font-size:16px;color:var(--text-main)}.user-settings-modal-subtitle{font-size:13px;color:var(--text-muted)}.user-settings-modal-close{border:none;background:transparent;font-size:20px;cursor:pointer;color:var(--text-muted);padding:4px 8px;line-height:1}.user-settings-modal-body{display:flex;flex-direction:column;gap:14px}.user-settings-list{display:flex;flex-direction:column;gap:10px}.user-settings-card{padding:14px;border-radius:12px;background:var(--card-softer);display:flex;flex-direction:column;gap:10px;box-shadow:inset 0 1px #ffffffa6}.user-settings-card-body{display:flex;flex-direction:column;gap:4px}.user-settings-card-title{font-weight:700;font-size:14px;color:var(--text-main)}.user-settings-card-desc{font-size:13px;color:var(--text-muted)}.user-settings-modal-action{align-self:flex-start;border:none;border-radius:10px;padding:10px 14px;background:#c96d2d;color:#fff;font-weight:700;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.user-settings-modal-action:hover{transform:translateY(-1px);box-shadow:0 8px 18px #c96d2d47}.user-settings-modal-action:active{transform:translateY(0);background:#b55f24;box-shadow:none}.upgrade-modal-overlay{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:980;animation:upgradeOverlayIn .18s ease-out}.upgrade-modal{position:relative;width:min(560px,96vw);background:radial-gradient(120% 120% at 10% 0%,rgba(56,189,248,.18),transparent 45%),radial-gradient(140% 140% at 100% 20%,rgba(251,191,36,.18),transparent 45%),linear-gradient(135deg,#0f172a,#1f2937,#2f3e55);color:#f8fafc;border-radius:24px;padding:26px;box-shadow:0 30px 60px #0f172a66;border:1px solid rgba(255,255,255,.08);overflow:hidden;animation:upgradeModalIn .22s ease-out}.upgrade-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff14;color:#f8fafc;font-size:18px;cursor:pointer;transition:transform .16s ease,background .16s ease,border-color .16s ease}.upgrade-modal-close:hover{transform:translateY(-1px);background:#ffffff29;border-color:#ffffff40}.upgrade-modal-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:14px;background:#ffffff1f;color:#fcd34d;font-weight:700;letter-spacing:.02em;font-size:12px;text-transform:uppercase;margin-bottom:12px}.upgrade-modal-title{margin:0 0 8px;font-size:26px;line-height:1.25;color:#f8fafc;letter-spacing:-.01em}.upgrade-modal-text{margin:0 0 12px;color:#e2e8f0;font-size:15px;line-height:1.55}.upgrade-modal-list{margin:0 0 16px 16px;padding:0 0 0 12px;color:#dbeafe;line-height:1.55}.upgrade-modal-list li+li{margin-top:6px}.upgrade-modal-pricing{margin:0 0 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.upgrade-modal-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;color:#e2e8f0}.upgrade-modal-row.total{font-weight:700;color:#f8fafc}.upgrade-modal-row-label{max-width:60%}.upgrade-modal-free-months{display:inline-flex;align-items:center;margin-left:6px;padding:3px 8px;border-radius:999px;background:#fcd34d2e;border:1px solid rgba(252,211,77,.35);color:#fde68a;font-size:11px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}.upgrade-modal-row-value{display:inline-flex;align-items:baseline;gap:8px;font-weight:700;color:#f8fafc}.upgrade-modal-old-price{color:#94a3b8;font-weight:600;font-size:13px}.upgrade-modal-old-price del{text-decoration-thickness:2px;text-decoration-color:#94a3b8b3}.upgrade-modal-row-value.credit{color:#86efac}.upgrade-modal-error{background:#f871711f;color:#fecdd3;border:1px solid rgba(248,113,113,.35);padding:10px 12px;border-radius:12px;font-size:14px;margin-bottom:10px}.upgrade-modal-btn{width:100%;justify-content:center;padding:12px 16px;font-size:16px;border-radius:14px;margin-bottom:10px;transition:transform .16s ease,box-shadow .16s ease}.upgrade-modal-btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px #3b82f659}.upgrade-modal-note{margin:0;color:#cbd5e1;font-size:14px;line-height:1.5}@keyframes upgradeModalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes upgradeOverlayIn{0%{opacity:0}to{opacity:1}}@media(max-width:520px){.upgrade-modal{padding:20px}.upgrade-modal-title{font-size:22px}.upgrade-modal-row-label{max-width:64%;display:flex;flex-direction:column;align-items:flex-start;gap:6px}.upgrade-modal-free-months{margin-left:0}}.main-tabs-wrap{display:flex;justify-content:center;align-items:center;width:100%;margin:-60px auto 4px}.main-tabs{display:inline-flex;padding:6px 10px;border-radius:40px;background:var(--card-white);box-shadow:0 10px 24px #0000000f;gap:4px}.main-tab-btn{border:none;padding:9px 26px;border-radius:999px;background:transparent;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;position:relative;display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px;font-size:14px;font-weight:500;line-height:1.2;color:var(--text-muted);cursor:pointer;text-align:center;transition:all .18s ease}.main-tab-btn.has-tag{padding-top:18px}.main-tab-btn.active{background:var(--zdk-dark);color:#fff;box-shadow:0 4px 10px #0f172a33}.main-tab-btn.active:hover{background:var(--zdk-dark-hover)}.main-tab-btn.active:active{background:var(--zdk-dark-active)}.main-tab-btn:hover:not(.active){background:var(--card-softer)}.main-tab-btn[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:50%;top:calc(100% + 10px);transform:translate(-50%);width:max-content;max-width:220px;padding:8px 12px;border-radius:12px;background:#141414eb;color:#fff;font-size:12px;font-weight:600;line-height:1.2;box-shadow:0 10px 26px #00000038;opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:10}.main-tab-btn[data-tooltip]:hover:after,.main-tab-btn[data-tooltip]:focus-visible:after{opacity:1}.main-tab-btn:disabled,.main-tab-btn.is-disabled{cursor:not-allowed;opacity:.65}.main-tab-btn:disabled:hover{background:transparent}.main-tab-tag{position:absolute;top:-12px;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;padding:3px 14px;border-radius:999px;background:linear-gradient(120deg,#ffe6c4,#ffc590);color:#844c11;border:1px solid rgba(132,76,17,.25);white-space:nowrap;box-shadow:0 6px 14px #ff964659,0 2px 6px #fff9;text-transform:uppercase;letter-spacing:.02em}.main-tab-btn-label{display:block;width:100%}.main-tab-btn-icon{display:none;line-height:1}.top-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:16px;margin:20px 0}.meals-per-day-select{border-radius:1000px}.group-block{min-height:100%}.day-kpi-value{font-weight:700;color:var(--text-main)}.day-kpi-value.kpi-ok{color:var(--status-ok-text)}.day-kpi-value.kpi-low{color:var(--accent-main)}.day-kpi-value.kpi-high{color:var(--status-critical-text)}.day-kpi.kpi-ok{background:var(--status-ok-bg)}.day-kpi.kpi-warning{background:var(--status-warn-bg)}.day-kpi.kpi-critical{background:var(--status-critical-bg)}.day-kpi.kpi-ok .day-kpi-value{color:var(--status-ok-text)}.day-kpi.kpi-warning .day-kpi-value{color:var(--status-warn-text)}.day-kpi.kpi-critical .day-kpi-value{color:var(--status-critical-text)}.week-bar-wrapper{display:flex;align-items:center;justify-content:space-between;margin:16px 0}.list-header{margin:6px 0 10px;display:flex;align-items:center;justify-content:space-between}.list-header .section-title{margin:0;font-size:20px;line-height:1.2;display:inline-flex;align-items:center}.list-header-mobile{display:flex;flex-direction:column;align-items:stretch;gap:8px;padding:0 16px;margin:6px 0 10px}.list-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.list-header-mobile .section-title{margin:0;font-size:20px;line-height:1.2;display:none}.list-header-mobile .info-hint{min-width:44px;min-height:44px}.list-header-mobile .info-hint-button{width:36px;height:36px;border-radius:999px;border:1px solid var(--ui-border);background:var(--ui-surface);color:var(--ui-text-muted);box-shadow:none}.list-header-mobile .info-hint-button:hover{background:var(--ui-ghost)}.list-header-days .week-bar-wrapper{margin:0;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.list-header-days .week-bar{flex-wrap:nowrap;gap:6px}.list-header-days .day-btn{position:relative;height:38px;padding:0 12px;font-size:12px;white-space:nowrap;border:1px solid var(--ui-border);box-shadow:none}.list-header-days .day-btn:before{content:"";position:absolute;inset:-4px 0}@media(max-width:900px){.top-grid{grid-template-columns:1fr}}.group-block{display:flex;flex-direction:column;gap:6px;padding:14px 18px 10px;max-width:540px;border-radius:32px;background:#fff;box-shadow:0 6px 18px #0000000a}.group-block-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.group-block-heading{margin:0 0 6px;font-size:18px;font-weight:600;color:var(--text-main)}.custom-targets-toggle-btn{border:1px dashed var(--ui-border);background:#f6f1eb;color:var(--text-main);border-radius:999px;padding:4px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease}.custom-targets-toggle-btn:hover{background:#efe7df}.custom-targets-toggle-btn.active{background:var(--accent-peach);border-color:transparent;color:var(--text-on-peach);box-shadow:0 3px 8px #0000000f}.group-selector,.group-tabs{display:flex;gap:8px;flex-wrap:wrap}.group-btn{display:inline-flex!important;align-items:center;justify-content:center;border:0px solid var(--border-soft)!important;padding:4px 10px;border-radius:999px;font-size:14px;cursor:pointer;background:#f4efe9!important;color:var(--text-main)!important;white-space:nowrap;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease}.group-btn:hover{background:#ece5dd!important;color:var(--text-main)!important}.group-btn:active{background:#e3d9cf!important;color:var(--text-main)!important}.group-btn.selected,.group-btn-active,.group-btn.active{background:var(--accent-peach)!important;border-color:transparent!important;color:var(--text-on-peach)!important;font-weight:600;box-shadow:0 3px 8px #0000000f}.group-btn.selected:hover,.group-btn-active:hover,.group-btn.active:hover{background:var(--accent-peach)!important;color:var(--text-on-peach)!important}.group-btn.selected:active,.group-btn-active:active,.group-btn.active:active{background:var(--accent-peach-active)!important;color:var(--text-on-peach)!important}.group-desc{font-size:13px;padding:2px 2px 0;color:var(--text-subtle)}.target-source-label{font-size:12px;color:var(--text-subtle);padding:0 2px 2px}.custom-targets{margin-top:10px;padding-top:10px;border-top:1px dashed var(--ui-border);display:flex;flex-direction:column;gap:10px}.custom-targets-header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.custom-targets-toggle{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--text-main)}.custom-targets-confirm{margin-left:auto}.custom-targets-toggle input{width:18px;height:18px}.custom-targets-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.custom-targets-field{display:flex;flex-direction:column;gap:6px}.custom-targets-label{font-size:12px;color:var(--text-subtle)}.custom-targets-inputs{display:grid;grid-template-columns:1fr auto 1fr auto;gap:6px;align-items:center}.custom-targets-input{width:100%;border:1px solid var(--ui-border);border-radius:10px;padding:6px 8px;font-size:13px;background:#fff}.custom-targets-input:disabled{background:#f5f1ec;color:var(--text-subtle)}.custom-targets-input--error{border-color:var(--status-critical-text)}.custom-targets-sep,.custom-targets-unit{font-size:12px;color:var(--text-subtle)}.custom-targets-error{font-size:12px;color:var(--status-critical-text)}.custom-targets-error--summary{margin-top:-2px}.custom-targets-mobile{padding-top:4px}@media(max-width:640px){.custom-targets-grid{grid-template-columns:1fr}}.day-summary{flex:1;max-width:760px;padding:18px 24px 14px;border-radius:32px;background:#fff;box-shadow:0 10px 26px #0000000a;display:flex;flex-direction:column;gap:8px}.day-summary-header{display:flex;align-items:center;gap:16px}.meals-per-day{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}.meals-per-day-label{display:inline-flex;align-items:center;gap:6px}.meals-per-day .info-hint{margin-left:0}.meals-per-day-select-wrap{position:relative;height:40px;border-radius:999px}.meals-per-day-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:0 34px 0 16px;min-width:64px;height:40px;border-radius:999px;border:1px solid var(--border-soft);background:var(--card-softer);font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;line-height:40px;text-align:center;text-align-last:center;transition:all .16s ease}.meals-per-day-select-wrap:after{content:"▾";position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-muted);pointer-events:none}.meals-per-day-select:hover{background:var(--accent-peach)}.meals-per-day-select:focus{outline:none;box-shadow:0 0 0 2px #0f172a1f}.day-summary-title{font-size:17px;font-weight:600;color:var(--text-main);display:inline-flex;align-items:center}.day-kpi-row{display:flex;gap:10px;margin-top:2px;flex-wrap:wrap}.day-kpi{flex:1;padding:10px 12px;border-radius:18px;background:var(--status-warn-bg);font-size:13px;display:flex;flex-direction:column;gap:2px;box-shadow:0 2px 6px #00000005}.day-kpi-label{font-size:10px;color:var(--text-muted)}.day-summary-sub{font-size:12px;color:var(--text-subtle)}.day-warnings{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px;min-height:28px}.day-warnings--empty{visibility:hidden;pointer-events:none;min-height:28px;margin-top:8px}.day-summary.day-summary-mobile{padding:7px 10px;border-radius:20px;background:#fff;box-shadow:0 10px 26px #0000000a;border:1px solid rgba(15,23,42,.04);display:flex;flex-direction:column;align-items:stretch;gap:6px;flex-wrap:nowrap}.day-summary-mobile .day-summary-title{font-size:14px;font-weight:700;margin:0;color:var(--text-main)}.day-summary-mobile .day-summary-row{display:flex;align-items:center;width:100%}.day-summary-mobile .day-summary-row--top{justify-content:space-between;gap:8px}.day-summary-mobile .day-summary-row--bottom{justify-content:flex-start}.day-summary-mobile .day-kcal-plain{font-size:13px;font-weight:600;color:var(--text-main);white-space:nowrap}.day-summary-mobile .day-kcal-progress{height:4px;border-radius:999px;background:#0f172a14;overflow:hidden}.day-summary-mobile .day-kcal-progress-fill{display:block;height:100%;background:var(--status-ok-bg);border-radius:999px}.day-summary-mobile .day-kcal-progress.kpi-low .day-kcal-progress-fill{background:var(--accent-main)}.day-summary-mobile .day-kcal-progress.kpi-high .day-kcal-progress-fill{background:var(--status-critical-bg)}.day-summary-mobile .day-macro-value.kpi-ok{color:var(--status-ok-text)}.day-summary-mobile .day-macro-value.kpi-low,.day-summary-mobile .day-macro-value.kpi-high{color:var(--status-critical-text)}.day-summary-mobile .day-macro-inline{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);white-space:nowrap}.day-summary-mobile .day-macro-item{display:inline-flex;align-items:baseline;gap:4px;padding:4px 8px;border-radius:999px;background:#0f172a0f}.day-summary-mobile .day-macro-label{font-weight:400;color:var(--text-muted)}.day-summary-mobile .day-macro-value{font-weight:600;color:var(--text-main)}.day-summary-mobile .day-macro-sep{color:transparent;width:0}.day-summary-mobile .day-macro-item.kpi-ok{background:var(--status-ok-bg)}.day-summary-mobile .day-macro-item.kpi-low,.day-summary-mobile .day-macro-item.kpi-high{background:var(--status-critical-bg)}.day-summary-mobile .day-kpi-row{display:flex;flex-wrap:nowrap;gap:6px;margin-top:0;flex:1 1 auto;justify-content:flex-end}.day-summary-mobile .day-kpi{border-radius:999px;border:none;background:var(--status-warn-bg);box-shadow:0 4px 12px #0f172a12;padding:6px 10px;flex-direction:row;align-items:center;justify-content:center;gap:6px;text-align:center;flex:0 0 auto;min-width:0}.day-summary-mobile .day-kpi.day-kpi--kcal{justify-content:center}.day-summary-mobile .day-kpi.kpi-ok{background:var(--status-ok-bg)}.day-summary-mobile .day-kpi.kpi-warning{background:var(--status-warn-bg)}.day-summary-mobile .day-kpi.kpi-critical{background:var(--status-critical-bg)}.day-summary-mobile .day-kpi-label{font-size:11px}.day-summary-mobile .day-kpi-value{font-size:13px;font-weight:700}.day-inline-kcal{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;margin-left:8px;border-radius:999px;background:var(--status-warn-bg);font-size:12px;font-weight:700;box-shadow:0 2px 8px #0f172a1f}.day-inline-kcal.kpi-ok{background:var(--status-ok-bg)}.day-inline-kcal.kpi-warning{background:var(--status-warn-bg)}.day-inline-kcal.kpi-critical{background:var(--status-critical-bg)}.day-inline-kcal-label{font-weight:600;color:var(--text-muted);font-size:11px}.day-inline-kcal-value{font-weight:700;color:var(--text-main)}.day-summary-mobile .day-summary-sub,.day-summary-mobile .day-warnings{display:none}.day-warning{font-size:12px;padding:4px 10px;border-radius:999px;font-weight:500}.day-warning-critical{background:var(--status-critical-bg);color:var(--status-critical-text)}.day-warning-warning,.day-warning-info{background:var(--status-warn-bg);color:var(--status-warn-text)}.filter-panel{margin-top:0;margin-bottom:10px;padding:10px 18px 12px;background:#fff;border-radius:26px;box-shadow:0 6px 18px #0000000a}.db-layout .filter-panel{margin-top:20px}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.filter-title{font-size:15px;font-weight:600;color:var(--text-main)}.filter-active{font-size:11px;color:var(--text-subtle)}.filter-row{display:flex;flex-wrap:nowrap;gap:8px;margin-top:4px;overflow-x:auto}.filter-pill{padding:6px 12px;border-radius:999px;border:1px solid var(--border-soft);background:var(--zdk-bg-soft);font-size:12px;color:var(--text-main);cursor:pointer;white-space:nowrap;box-shadow:0 2px 5px #00000005;transition:all .18s ease}.filter-pill:hover:not(.active){background:var(--accent-peach);border-color:var(--zdk-border-soft);transform:translateY(-1px);box-shadow:0 3px 8px #0f172a1f;color:var(--text-on-peach)}.filter-pill.active{background:var(--accent-peach);border-color:var(--zdk-border-soft);color:var(--text-on-peach);font-weight:600;box-shadow:0 3px 8px #3a3a3a2e}.filter-pill.active:hover{background:var(--accent-peach-hover);box-shadow:0 3px 10px #3a3a3a38;transform:translateY(-1px);color:var(--text-on-peach)}.filter-pill.active:active{background:var(--accent-peach-active)}.db-filter-panel{margin:8px 0 16px;padding:20px 24px 24px;border-radius:22px;background:#fff;border:1px solid rgba(58,58,58,.06);box-shadow:0 20px 35px #0f172a14}.db-filter-panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.db-filter-panel-title{font-size:14px;font-weight:600;color:var(--text-main);letter-spacing:.2px}.db-filter-panel-body{display:flex;flex-direction:column;gap:18px;margin-top:12px}.dbAdvancedPanel{margin:0;overflow:hidden;max-height:0;opacity:0;transform:translateY(-4px);transition:max-height .22s ease,opacity .18s ease,transform .22s ease;pointer-events:none}.dbAdvancedPanel.open{margin:8px 0 16px;max-height:1200px;opacity:1;transform:translateY(0);pointer-events:auto}.dbAdvancedPanel .db-filter-panel{margin:0}.db-advanced-panel-actions{display:flex;justify-content:flex-end;margin-bottom:16px}.db-advanced-reset-btn{font-size:12px;padding:6px 16px;border-radius:999px;background:var(--accent-peach);color:var(--text-on-peach);box-shadow:0 6px 14px #e2956e66}.db-advanced-reset-btn:hover{background:var(--accent-peach-hover)}.db-advanced-reset-btn:active{background:var(--accent-peach-active)}.ingredient-exclude{margin:8px 0 18px;display:flex;flex-direction:column;gap:6px}.ingredient-exclude-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.ingredient-exclude label{font-weight:600;font-size:14px;color:var(--text-main)}.ingredient-exclude input,.db-filter-text-input{border:1px solid var(--border-soft);border-radius:12px;padding:10px 12px;font-size:14px;background:#fff;color:var(--text-main)}.db-filter-text-input{width:100%}.input-invalid{border-color:#d92d20!important;background:#fff6f5}.input-invalid:focus{outline:2px solid #d92d20}.error-hint{color:#d92d20;font-weight:600}.field-hint{margin:0;font-size:12px;color:var(--text-muted)}.text-link{background:none;border:none;padding:0;color:var(--accent-main);font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline}.text-link:hover{color:var(--accent-main-hover)}.ingredient-exclude-toggle-row{display:flex;align-items:center;gap:10px;margin:6px 0}.muted-chip{background:#f1f1f2;border-radius:999px;padding:4px 10px;font-size:12px;color:var(--text-muted);border:1px solid var(--border-soft)}.filter-extra{margin-top:6px}.filter-extra-row{display:flex;align-items:center;gap:10px}.chip-count{margin-left:6px;background:#fff;color:var(--text-main);border-radius:999px;padding:2px 8px;font-size:12px;border:1px solid var(--border-soft)}.db-filter-group{display:flex;flex-direction:column;gap:10px}.db-filter-group-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.db-filter-group-title{font-size:13px;font-weight:600;color:var(--text-main)}.db-filter-group-value{font-size:12px;color:var(--text-muted)}.db-filter-chip-row{display:flex;flex-wrap:wrap;gap:8px}.db-filter-panel input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:10px;border-radius:999px;background:#efe8e2;outline:none;transition:box-shadow .2s ease;box-shadow:inset 0 2px 4px #0f172a14}.db-filter-panel input[type=range]:focus-visible{box-shadow:inset 0 2px 4px #0f172a14,0 0 0 3px #fad6c6b3}.db-filter-panel input[type=range]::-webkit-slider-runnable-track{height:10px;border-radius:999px;background:#efe8e2}.db-filter-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;height:20px;width:20px;border-radius:50%;background:#fff;box-shadow:0 4px 10px #0f172a2e;border:3px solid #fad6c6;margin-top:-5px}.db-filter-panel input[type=range]::-moz-range-track{height:10px;border-radius:999px;background:#efe8e2}.db-filter-panel input[type=range]::-moz-range-thumb{height:20px;width:20px;border-radius:50%;background:#fff;box-shadow:0 4px 10px #0f172a2e;border:3px solid #fad6c6}.db-filter-panel input[type=range]::-ms-track{height:10px;border-radius:999px;background:transparent;border-color:transparent;color:transparent}.db-filter-panel input[type=range]::-ms-fill-lower,.db-filter-panel input[type=range]::-ms-fill-upper{background:#efe8e2;border-radius:999px}.db-filter-panel input[type=range]::-ms-thumb{height:20px;width:20px;border-radius:50%;background:#fff;box-shadow:0 4px 10px #0f172a2e;border:3px solid #fad6c6}.db-filter-panel input[type=range]{background:linear-gradient(to right,#fad6c6,#fad6c6) no-repeat,#efe8e2;background-size:100% 10px}.db-kcal-sliders{position:relative;height:38px;display:flex;align-items:center}.db-kcal-sliders input{position:absolute;inset:0;margin:0;pointer-events:none}.db-kcal-sliders input:first-of-type{z-index:2}.db-kcal-sliders input::-webkit-slider-thumb{pointer-events:all}.db-kcal-sliders input::-moz-range-thumb{pointer-events:all}.db-filter-scale{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}#db-advanced-filters .db-filter-chip-row .chip-btn{background:#f5efe8!important;color:var(--text-main)!important;border:none!important;font-weight:600}#db-advanced-filters .db-filter-chip-row .chip-btn.chip-btn-active{background:var(--accent-peach)!important;color:var(--text-on-peach)!important}.db-filter-reset-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.db-actions-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:space-between}.db-segmented-row{justify-content:flex-start;margin:8px 0 6px}.db-segmented-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-left:auto}.db-actions-row .search-bar{flex:1;margin:4px 0 14px}.db-mobile-header{display:flex;flex-direction:column;gap:10px;margin:6px 0 12px}.db-mobile-top-row{display:flex;align-items:center;gap:10px}.db-mobile-top-row .shopping-segmented{flex:0 0 auto;width:fit-content}.db-mobile-filter-btn{width:38px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px}.db-mobile-search-row .search-bar{margin:0}.db-mobile-filters-summary{display:flex;align-items:center;gap:10px}.db-mobile-filter-chips{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;flex:1;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.db-mobile-filter-chip{padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;color:var(--text-muted);background:#f1f1f2;border:1px solid var(--border-soft);white-space:nowrap}.db-mobile-clear-btn{border:none;background:none;color:var(--accent-main);font-size:12px;font-weight:700;cursor:pointer;padding:0 4px;white-space:nowrap}.db-mobile-actions{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 12px}.search-bar{margin:4px 0 14px}.search-bar input{width:100%;padding:12px 18px;border-radius:999px;border:0 px solid var(--border-soft);background:#fff;color:var(--text-main);font-size:15px;transition:box-shadow .18s ease,border-color .18s ease}.search-bar input::placeholder{color:var(--text-subtle)}.search-bar input:focus{outline:none;box-shadow:0 0 0 3px #0f172a1a}.search-mode-note{font-size:13px;color:var(--text-muted);margin:0 0 16px}.db-header{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:14px;padding:0;border-radius:0;background:transparent;box-shadow:none}.db-header:after{content:none}.db-header .section-title{font-size:20px;font-weight:700;color:var(--text-main);letter-spacing:.4px}.db-sub{font-size:14px;color:var(--text-muted);max-width:480px;line-height:1.4}.replace-modal-backdrop{position:fixed;inset:0;background:#0000003d;display:flex;justify-content:center;align-items:flex-start;padding:60px 16px;z-index:1000}.replace-modal{width:min(780px,100%);background:var(--card-softer);border-radius:28px;padding:24px 24px 28px;box-shadow:0 20px 40px #0000002e;max-height:88vh;overflow-y:auto}.replace-modal-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.replace-modal-header-actions{display:flex;align-items:center;gap:8px}.replace-modal-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.replace-modal-actions-right{display:flex;gap:8px}.replace-modal-title{margin:0;font-size:20px;font-weight:600;color:var(--text-main)}.replace-modal-help{border:none;background:var(--card-white);color:var(--text-main);border-radius:999px;width:30px;height:30px;font-size:16px;cursor:pointer;border:1px solid rgba(0,0,0,.08)}.replace-modal-help:hover{background:var(--card-soft)}.replace-modal-close{border:none;background:var(--accent-peach);color:var(--text-on-peach);border-radius:999px;width:30px;height:30px;font-size:16px;cursor:pointer}.replace-modal-close:hover{background:var(--accent-peach-hover)}.replace-modal-close:active{background:var(--accent-peach-active)}.replace-modal-search{margin-bottom:18px}.replace-modal-search input{width:100%;padding:12px 18px;border-radius:999px;border:2px solid var(--border-soft);background:var(--card-softer);color:var(--text-main);font-size:15px;transition:box-shadow .18s ease,border-color .18s ease}.replace-modal-search input::placeholder{color:var(--text-subtle)}.replace-modal-search input:focus{outline:none;box-shadow:0 0 0 3px #0f172a1a}.replace-modal-filters{display:flex;align-items:center;gap:12px;margin-bottom:18px}.modal-filter-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;flex:1}.modal-filter-row::-webkit-scrollbar{display:none}.modal-filter-info{flex-shrink:0;font-size:12px;color:var(--text-subtle);white-space:nowrap}.modal-filter-info button{border:none;background:transparent;color:var(--text-muted);cursor:pointer;padding:0;font:inherit;text-decoration:underline}.replace-modal-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.replace-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:10px;border-radius:22px;border:1px solid var(--border-soft);background:var(--card-white);color:var(--text-main);text-align:left;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;position:relative}.replace-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px #0f172a26;border-color:var(--accent-main)}.replace-card-image-wrapper{width:100%;height:130px;border-radius:16px;overflow:hidden;background:var(--card-softer)}.replace-card-image{width:100%;height:100%;object-fit:cover;display:block}.replace-card-content{display:flex;flex-direction:column;gap:4px;width:100%}.replace-card-title{font-size:15px;font-weight:600}.replace-card-kcal{font-size:13px;color:var(--accent-main)}.replace-card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-subtle)}.replace-modal-empty{grid-column:1 / -1;padding:20px;text-align:center;font-size:14px;color:var(--text-muted);background:var(--card-soft);border-radius:18px}.custom-modal-backdrop{position:fixed;inset:0;background:#00000052;display:flex;justify-content:center;align-items:flex-start;padding:50px 16px;z-index:1050}.custom-modal{width:min(860px,100%);background:var(--card-white);border-radius:28px;box-shadow:0 24px 50px #0f172a2e;padding:24px 24px 20px;overflow:hidden;max-height:92vh;overflow-y:auto}.custom-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.custom-modal-title{margin:0;font-size:22px;color:var(--text-main)}.custom-modal-kicker{text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--text-subtle);margin:0 0 4px}.custom-modal-actions{display:flex;align-items:center;gap:10px}.custom-modal-close{border:none;background:var(--card-soft);width:34px;height:34px;border-radius:999px;font-size:18px;cursor:pointer}.custom-modal-error{background:#fff1f0;color:#9f1d1d;padding:10px 14px;border-radius:12px;border:1px solid #f5c2c0;margin-bottom:12px;font-size:14px}.custom-modal-body{display:flex;flex-direction:column;gap:16px}.macro-preview{border:1px solid var(--border-soft);border-radius:14px;padding:12px 14px;background:var(--card-softer);display:flex;flex-direction:column;gap:10px}.macro-preview-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.macro-preview-left{display:flex;align-items:center;gap:10px;min-width:0}.macro-preview-left strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.food-thumb{width:52px;height:52px;border-radius:12px;object-fit:cover;background:var(--card-softer);border:1px solid var(--border-soft);flex-shrink:0}.macro-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;font-size:14px;color:var(--text-main)}.custom-section{padding:16px;border:1px solid var(--border-soft);border-radius:18px;background:var(--card-softer)}.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.section-heading h3{margin:0;font-size:18px}.section-kicker{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--text-subtle)}.section-hint{font-size:13px;color:var(--text-muted);max-width:260px}.field-grid{display:grid;gap:12px}.field-grid.two-col{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.field-grid.four-col{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.advanced-grid{display:grid;gap:12px}.field{display:flex;flex-direction:column;gap:6px;font-size:14px}.field span{color:var(--text-main);font-weight:600}.field input,.field textarea,.field select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border-soft);background:#fff;font-size:14px;color:var(--text-main)}.field textarea{resize:vertical}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}.custom-modal .chip-btn-ghost{background:#fff;color:var(--text-main);border-color:#dcd6cf;box-shadow:0 2px 6px #1e1a1514}.custom-modal .chip-btn-ghost:hover{background:#f7f3ee;border-color:#d0c8bf;color:var(--text-main);box-shadow:0 3px 10px #1e1a1524}.custom-modal .chip-btn-ghost.chip-btn-active{background:var(--accent-peach);color:var(--text-on-peach);border-color:var(--accent-peach-active);box-shadow:0 4px 12px #ffa1804d}.chip-row-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin-right:8px}.field-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.shopping-editor{display:flex;flex-direction:column;gap:8px}.shopping-row{display:grid;grid-template-columns:1.4fr .8fr .6fr 1fr auto;gap:8px;align-items:center}.shopping-row input,.shopping-row select{width:100%}.icon-btn{border:none;background:var(--card-soft);width:32px;height:32px;border-radius:10px;cursor:pointer}.checkbox-field{flex-direction:row;align-items:center;gap:8px}.batch-inline-input{max-width:220px}.custom-modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.favorites-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;justify-content:center;align-items:flex-start;padding:40px 16px;overflow-y:auto;z-index:900}.favorites-panel{width:min(1100px,100%);background:#fffaf5;border-radius:28px;padding:32px;box-shadow:0 30px 60px #0f172a33}.favorites-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.favorites-heading h2{margin:4px 0 0;font-size:26px}.favorites-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:12px;margin:0;color:var(--text-subtle)}.favorites-subtitle{margin:6px 0 0;font-size:14px;color:var(--text-muted)}.favorites-close{border:none;background:var(--card-white);border-radius:999px;width:40px;height:40px;font-size:18px;cursor:pointer;box-shadow:0 6px 20px #0000001f}.favorites-grid{margin-top:24px}.favorites-empty{margin-top:28px;background:var(--card-softer);border-radius:24px;padding:32px;text-align:center;color:var(--text-muted);font-size:15px}.trial-footer{position:relative;width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#1f2a3c,#2f3e55);color:#f9f7f4;border-radius:14px;border:1px solid rgba(255,255,255,.06);box-shadow:0 12px 28px #0f172a40;margin:18px 0 6px}.trial-footer__text{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:14px;line-height:1.4}.trial-footer__label{display:inline-flex;align-items:center;padding:4px 10px;border-radius:10px;background:#ffffff1f;color:#ffe3c7;font-weight:700;text-transform:uppercase;letter-spacing:.03em;font-size:11px}.trial-footer__countdown{font-weight:600}.trial-footer__btn{min-width:0;max-width:300px;padding:10px 16px;font-size:14px;border-radius:12px}.trial-subscribe-overlay{position:fixed;inset:0;background:#0f172a80;display:flex;justify-content:center;align-items:flex-start;padding:32px 16px;overflow-y:auto;z-index:950}.trial-subscribe-card{background:#fff;border-radius:28px;box-shadow:0 30px 60px #0f172a33;overflow:hidden;position:relative;border:1px solid rgba(31,41,55,.08)}.trial-subscribe-close-row{display:flex;justify-content:flex-end;padding:12px 16px 0}.trial-subscribe-close{border:none;background:#fff;width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;box-shadow:0 4px 12px #0f172a2e;transition:transform .18s ease,box-shadow .18s ease}.trial-subscribe-close:hover{transform:translateY(-1px);box-shadow:0 8px 18px #0f172a38}@media(max-width:640px){.favorites-panel{padding:24px;border-radius:22px}.favorites-close{width:36px;height:36px}}.onboarding-v2-overlay{position:fixed;inset:0;background:#0f172a47;display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:none;z-index:80}.onboarding-v2-modal{width:min(980px,94vw);max-height:92vh;background:var(--card-white);border-radius:26px;border:1px solid rgba(15,23,42,.08);box-shadow:0 24px 60px #0f172a2e;padding:28px;overflow:auto;pointer-events:auto}.onboarding-v2-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.onboarding-v2-kicker{text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--text-muted);margin:0 0 6px}.onboarding-v2-header h2{margin:0;font-size:24px}.onboarding-v2-close{border:none;background:transparent;font-size:20px;cursor:pointer;color:var(--text-muted)}.onboarding-v2-progress{margin:18px 0 22px}.onboarding-v2-progress-text{font-size:13px;color:var(--text-muted);margin-bottom:8px}.onboarding-v2-progress-bar{height:8px;border-radius:999px;background:#0f172a0f;overflow:hidden}.onboarding-v2-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,#f97316,#facc15)}.onboarding-v2-layout{display:grid;grid-template-columns:minmax(220px,1fr) minmax(260px,1.1fr);gap:20px}.onboarding-v2-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.onboarding-v2-step{display:grid;grid-template-columns:32px 1fr;gap:12px;padding:12px 14px;border-radius:16px;border:1px solid rgba(15,23,42,.06);background:#ffffffbf}.onboarding-v2-step.is-active{border-color:#f9731673;background:#f973160f}.onboarding-v2-step.is-done{opacity:.7}.onboarding-v2-step-index{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-weight:700;background:#0f172a0d;color:var(--text-main)}.onboarding-v2-step-title{font-weight:700;margin-bottom:4px}.onboarding-v2-step-subtitle{font-size:13px;color:var(--text-muted)}.onboarding-v2-current{border-radius:20px;border:1px solid rgba(15,23,42,.08);padding:18px;background:#fffffff5}.onboarding-v2-current h3{margin:0 0 6px;font-size:20px}.onboarding-v2-current p{margin:0 0 16px;color:var(--text-muted)}.onboarding-flow-blocked-hint{margin:-6px 0 14px;font-size:13px;color:var(--text-muted)}.onboarding-flow-blocked-hint p{margin:0 0 6px}.onboarding-flow-blocked-hint p:last-child{margin-bottom:0}.onboarding-highlight{position:fixed;border-radius:16px;box-shadow:0 0 0 9999px #0f172a24;z-index:2000;pointer-events:none;transition:transform .18s ease,width .18s ease,height .18s ease,top .18s ease,left .18s ease}.onboarding-highlight.has-border{border:2px solid rgba(249,115,22,.85)}.onboarding-highlight.borderless{border:none}.onboarding-v2-actions{display:flex;flex-wrap:wrap;gap:10px}.onboarding-v2-tabs{margin-top:20px;padding:16px;border-radius:18px;background:#0f172a06}.onboarding-v2-tabs h4{margin:0 0 8px}.onboarding-v2-tabs ul{margin:0;padding-left:18px;color:var(--text-muted)}.onboarding-v2-floating{position:fixed;right:24px;bottom:24px;z-index:70;width:min(360px,calc(100vw - 32px));pointer-events:auto}.onboarding-v2-chip{position:relative;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:var(--card-white);box-shadow:0 20px 50px #0f172a29;padding:16px}.onboarding-v2-chip-close{position:absolute;top:8px;right:10px;border:none;background:transparent;font-size:16px;cursor:pointer;color:var(--text-muted)}.onboarding-v2-chip-kicker{margin:0 0 6px;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted)}.onboarding-v2-chip-title{font-weight:700;font-size:15px;margin-bottom:12px}.onboarding-v2-chip-progress{display:grid;gap:6px;margin-bottom:12px}.onboarding-v2-chip-progress-text{font-size:12px;color:var(--text-muted)}.onboarding-v2-chip-progress-bar{height:6px;border-radius:999px;background:#0f172a0f;overflow:hidden}.onboarding-v2-chip-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,#f97316,#facc15)}.onboarding-v2-chip-actions{display:flex;justify-content:flex-end}.onboarding-flow-highlight-chips .weekly-group-chip{box-shadow:0 0 0 2px #f9731673,0 10px 28px #f973162e;background:#fff;border-color:#f9731673;color:#5b4637}.onboarding-flow-highlight-chips .weekly-group-chip--active{color:#5b4637}.onboarding-flow-highlight-chips .weekly-group-chips{position:relative;z-index:3201}.onboarding-flow-highlight-edit [data-testid=plan-edit-button]{position:relative;z-index:3201;box-shadow:0 0 0 3px #f9731673,0 12px 30px #f9731638}.coach-overlay-panel{position:fixed;bottom:24px;left:50%;transform:translate(-50%);width:min(360px,90vw);z-index:3201}@media(max-width:900px){.onboarding-v2-layout{grid-template-columns:1fr}}@media(max-width:720px){.onboarding-v2-floating{left:50%;right:auto;transform:translate(-50%);bottom:14px;width:min(360px,calc(100vw - 24px))}}.week-bar-wrapper{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.week-bar-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:8px}.week-bar{display:inline-flex;flex-wrap:wrap;gap:6px}.week-bar-row .week-bar-wrapper{flex:1 1 auto;margin-bottom:0}.week-bar-toggle{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.week-bar-toggle .info-hint{margin-left:0}.prep-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px;min-height:36px;border-radius:999px;background:var(--ui-surface);border:1px solid var(--ui-border);box-shadow:0 6px 14px #0000000f}.prep-toggle-btn{border:none;background:transparent;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--ui-text-muted);cursor:pointer;transition:color .16s ease,background .16s ease,box-shadow .16s ease}.prep-toggle-btn.active{background:var(--ui-ghost);color:var(--ui-text);box-shadow:inset 0 0 0 1px var(--ui-border)}.prep-toggle-btn:not(.active):hover{color:var(--ui-text);background:var(--ui-ghost)}.pair-sync-warning{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:16px;background:var(--card-softer);color:var(--text-main);font-size:13px;margin:-4px 0 8px;border:1px solid var(--border-soft)}.pair-sync-warning .chip-btn{flex-shrink:0;background:#fff;color:var(--text-main);border:1px solid var(--border-soft);box-shadow:none}.pair-sync-warning .chip-btn:hover{background:var(--card-softer);border-color:#0f172a33}.pair-sync-warning .chip-btn:active{background:var(--accent-peach);border-color:transparent}.week-bar .day-btn{padding:8px 18px;border-radius:999px;background:var(--card-white);color:var(--text-muted);font-size:13.5px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 6px #0f172a14}.week-bar .day-btn.active{background:var(--zdk-dark);color:#fff;border-color:var(--accent-main);font-weight:700;box-shadow:0 4px 10px #0f172a2e}.week-bar .day-btn.active:hover{background:var(--zdk-dark-hover)}.week-bar .day-btn.active:active{background:var(--zdk-dark-active)}.week-bar .day-btn:hover:not(.active){background:var(--card-softer);color:var(--text-main);transform:translateY(-1px)}.plan-week-overview{margin:8px 0 16px;padding:16px;border-radius:16px;background:var(--card-white);border:1px solid rgba(15,23,42,.06);box-shadow:0 10px 30px #0000000a}.plan-week-overview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.plan-week-overview-kicker{margin:0 0 6px;text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--text-subtle)}.plan-week-overview-title{margin:0;font-size:18px;line-height:1.3;color:var(--text-main)}.plan-week-overview-sub{margin:6px 0 0;font-size:14px;color:var(--text-muted)}.plan-week-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.plan-week-day{border:1px solid var(--border-soft);background:#fff;border-radius:12px;padding:12px;text-align:left;display:flex;flex-direction:column;gap:10px;cursor:pointer;width:100%;color:inherit;text-decoration:none;outline:none;transition:border-color .15s ease,box-shadow .2s ease,transform .1s ease}.plan-week-day:hover{border-color:var(--accent-main);box-shadow:0 10px 25px #00000014;transform:translateY(-1px)}.plan-week-day:focus-visible{border-color:var(--accent-main);box-shadow:0 0 0 2px #e2705040,0 12px 28px #00000014}.plan-week-day:active{transform:translateY(0)}.plan-week-day-active{border-color:var(--accent-main);background:#fff8f3;box-shadow:0 12px 28px #00000014}.plan-week-day-empty{background:linear-gradient(180deg,#fff,#f7f7f8)}.plan-week-day-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.plan-week-day-name{font-weight:700;font-size:14px;color:var(--text-main)}.plan-week-day-kcal{font-weight:600;font-size:13px;color:var(--accent-main)}.plan-week-macros{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.plan-week-meals{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.plan-week-meal{border:1px dashed rgba(15,23,42,.08);border-radius:10px;padding:8px;background:#fffc}.plan-week-meal-header{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-subtle)}.plan-week-meal-name{margin-top:4px;font-size:14px;color:var(--text-main);font-weight:600;line-height:1.3}.plan-week-meal-servings{font-size:12px;color:var(--text-muted)}.plan-week-meal-label{font-weight:700}.plan-week-empty{border:1px dashed rgba(15,23,42,.12);border-radius:10px;padding:10px;color:var(--text-muted);font-size:13px;background:#ffffffb3}.week-overview-v2 .plan-week-day{position:relative;background:#fffdfb;border-color:#0f172a14;transition:border-color .18s ease,box-shadow .2s ease,transform .1s ease,background .2s ease}.week-overview-v2 .plan-week-day:hover{border-color:#e2705059;box-shadow:0 12px 28px #00000014}.week-overview-v2 .plan-week-day:focus-visible{border-color:var(--accent-main);box-shadow:0 0 0 2px #e2705040,0 12px 28px #00000014}.week-overview-v2 .plan-week-day-active{background:linear-gradient(180deg,#fff6ef,#fff 60%);border-color:#e2705080;box-shadow:0 14px 32px #e2705029}.week-overview-v2 .plan-week-day-head{background:linear-gradient(90deg,#fff1e8e6,#fff);margin:-12px -12px 10px;padding:10px 12px 8px;border-radius:10px 10px 8px 8px;border-bottom:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:8px}.week-overview-v2 .plan-week-day-head-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.week-overview-v2 .plan-week-day-name{font-size:15px}.week-overview-v2 .plan-week-day-kcal{background:#e270501f;padding:4px 8px;border-radius:999px;font-size:12px;color:var(--accent-main);box-shadow:inset 0 0 0 1px #e2705024}.week-overview-v2 .plan-week-macros--chips{gap:6px}.week-overview-v2 .plan-week-macro-chip{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#f1f3f6;color:var(--text-main);font-weight:600;font-size:12px;box-shadow:inset 0 0 0 1px #0f172a0a}.week-overview-v2 .plan-week-day-hint{font-size:11px;color:var(--text-muted);opacity:0;transition:opacity .15s ease}.week-overview-v2 .plan-week-day:hover .plan-week-day-hint,.week-overview-v2 .plan-week-day:focus-visible .plan-week-day-hint{opacity:1}.week-overview-v2 .plan-week-meals{gap:6px}.week-overview-v2 .plan-week-meal-section{list-style:none}.week-overview-v2 .plan-week-meal-section+.plan-week-meal-section{border-top:1px solid rgba(15,23,42,.08);padding-top:6px}.week-overview-v2 .plan-week-meal-heading{margin:0 0 4px;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-subtle)}.week-overview-v2 .plan-week-meal-row{display:grid;grid-template-columns:1fr auto;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:10px;border:1px solid transparent;background:transparent;transition:border-color .15s ease,box-shadow .15s ease,transform .1s ease}.week-overview-v2 .plan-week-meal-row:hover{border-color:#0f172a1f;box-shadow:0 8px 18px #0000000f;transform:translateY(-1px)}.week-overview-v2 .plan-week-meal-main{display:flex;flex-direction:column;gap:0}.week-overview-v2 .plan-week-meal-name{margin:0;font-size:14px;font-weight:700;color:var(--text-main)}.week-overview-v2 .plan-week-meal-label{font-size:12px;color:var(--text-muted)}.week-overview-v2 .plan-week-meal-servings-badge{font-size:12px;font-weight:700;color:var(--text-main);padding:4px 8px;border-radius:999px;background:#f5f6f8;border:1px solid rgba(15,23,42,.06);align-self:flex-start}.week-overview-btn{margin-left:4px}.week-overview-btn,.week-overview-btn:focus-visible{background:#f4f5f7;color:var(--text-main);border-color:var(--zdk-border-soft)}.week-overview-btn:hover{background:#eceff3;color:var(--text-main);border-color:#0f172a24}.week-overview-btn.chip-btn-active{background:#eef1f5;color:var(--text-main);border-color:var(--zdk-border-soft);box-shadow:none}.week-overview-btn.chip-btn-active:hover{background:#e6eaef;border-color:#0f172a2e}.section-title{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text-main)}.meals{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.meals-toolbar{display:flex;justify-content:flex-end;align-items:center;margin:6px 4px 8px}.meals-dropdown-wrap{display:flex;align-items:center;gap:6px}.meals-dropdown-label{font-size:13px;color:var(--text-muted);font-weight:500}.meals-dropdown{border:1px solid var(--border-soft);background:var(--card-softer);color:var(--text-main);font-size:13px;border-radius:999px;padding:4px 10px;cursor:pointer;transition:.2s}.meals-dropdown:hover{background:var(--accent-peach)}.card{background:var(--card-white);border-radius:20px;box-shadow:0 4px 10px #0000000f;overflow:hidden;display:flex;flex-direction:column;position:relative;height:100%}.card.recipe-card{overflow:visible}.recipe-card{position:relative}.card-media{position:relative;width:100%;height:150px;border-radius:20px 20px 18px 18px;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;display:block}.card-image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--accent-peach),var(--card-soft));display:flex;align-items:center;justify-content:center;font-size:32px}.card-media-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:space-between;padding:10px 12px;background:linear-gradient(180deg,#0000,#00000059);color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.card-detail-btn{position:absolute;top:8px;right:8px;border:none;border-radius:999px;padding:8px 16px;background:#ffffffeb;color:var(--text-main);font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 6px 14px #0f172a29}.card-detail-btn:hover{background:#fff}.card-overlay-label,.card-overlay-kcal{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#0000008c;color:#fff;font-weight:600;line-height:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.card-overlay-label{font-size:10px}.card-overlay-kcal{font-size:12px}.card-tags-row{display:none}.recipe-card__tags{font-size:12px;color:var(--text-muted);font-weight:400}.chip-btn{--btn-bg: var(--ui-primary);--btn-bg-hover: var(--ui-primary-hover);--btn-bg-pressed: var(--ui-primary-pressed);--btn-text: var(--ui-text-on-primary);--btn-border: var(--ui-primary);--btn-shadow: 0 6px 14px rgba(0, 0, 0, .12);padding:6px 12px;border-radius:999px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-text);font-size:12px;font-weight:600;cursor:pointer;transition:background .16s ease,color .16s ease,box-shadow .16s ease,border-color .16s ease,transform .16s ease;box-shadow:var(--btn-shadow)}.chip-btn:hover{background:var(--btn-bg-hover);border-color:var(--btn-bg-hover);color:var(--btn-text);box-shadow:0 8px 18px #0000001f}.chip-btn:active{background:var(--btn-bg-pressed);border-color:var(--btn-bg-pressed);color:var(--btn-text);transform:translateY(0)}.chip-btn:disabled,.chip-btn[aria-disabled=true]{cursor:not-allowed;color:var(--ui-text-muted);background:var(--ui-ghost);border-color:var(--ui-border);box-shadow:none}.custom-modal .chip-btn-ghost:not(.chip-btn-active):hover,.custom-modal .chip-btn-ghost:not(.chip-btn-active):active,.custom-modal .chip-btn.chip-btn-ghost:not(.chip-btn-active):hover,.custom-modal .chip-btn.chip-btn-ghost:not(.chip-btn-active):active{background:#f2ebe3!important;color:var(--text-main)!important;border-color:#d0c8bf!important;box-shadow:0 3px 10px #1e1a1524!important}.chip-btn.secondary{--btn-bg: var(--ui-surface);--btn-bg-hover: var(--ui-ghost);--btn-bg-pressed: var(--ui-ghost-pressed);--btn-text: var(--ui-text);--btn-border: var(--ui-border);--btn-shadow: 0 3px 10px rgba(0, 0, 0, .08)}.chip-btn.tertiary{--btn-bg: var(--ui-surface);--btn-bg-hover: var(--ui-ghost);--btn-bg-pressed: var(--ui-ghost-pressed);--btn-text: var(--ui-text);--btn-border: var(--ui-border);--btn-shadow: none}.chip-btn-ghost{--btn-bg: transparent;--btn-bg-hover: var(--ui-ghost);--btn-bg-pressed: var(--ui-ghost-pressed);--btn-text: var(--ui-text);--btn-border: var(--ui-border);--btn-shadow: none;background:var(--btn-bg);color:var(--btn-text);border:1px solid var(--btn-border);box-shadow:none}.chip-btn-ghost:hover{background:var(--btn-bg-hover);color:var(--btn-text)}.chip-btn-ghost.chip-btn-active{--btn-bg: var(--ui-primary);--btn-text: var(--ui-text-on-primary);--btn-border: var(--ui-primary);background:var(--btn-bg);color:var(--btn-text);border-color:var(--btn-border)}.chip-btn.danger{background:var(--status-critical-bg);color:var(--status-critical-text)}.chip-btn.danger:hover{background:var(--status-critical-bg);box-shadow:0 4px 10px #3a3a3a1f}.card-content{padding:14px 14px 16px;display:flex;flex-direction:column;gap:16px;flex:1}.recipe-card__body{display:flex;flex-direction:column}.card-middle{display:flex;flex-direction:column;gap:6px}.card-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.recipe-source-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#e9f2ff;color:#0c3c74;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.recipe-card__badge{display:inline-flex;align-items:center;align-self:flex-start;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600px;color:var(--text-main);background:#f1f0ef;white-space:nowrap}.recipe-card__badges{display:inline-flex;flex-wrap:wrap;gap:6px;align-items:center}.recipe-batch-pill{display:inline-flex;align-items:center;gap:0}.recipe-card__servings .recipe-card__badge{align-self:center}.card-title{font-size:16px;font-weight:600;line-height:1.25;margin-left:-20}.card-macros{font-size:12px;color:var(--text-muted)}.card-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.recipe-card__actions{margin-top:auto}.card-bottom-locked{justify-content:flex-end}.card-servings{display:flex;flex-direction:column;gap:4px;min-width:150px}.recipe-card__servings{display:flex;align-items:center;gap:8px;padding-top:4px;padding-bottom:4px;flex-wrap:wrap}.recipe-card__servings select{font-size:13px;padding:4px 28px 4px 10px;height:28px;border-radius:8px;border:1px solid var(--border-soft);color:var(--text-main);appearance:none;background-color:var(--card-white);background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B7280' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:10px 6px}.servings-label{font-size:14px;font-weight:500;color:var(--text-main)}.card-servings-static{font-size:14px;font-weight:600;color:var(--text-main)}.card-portion-block{display:flex;flex-direction:row;align-items:center;gap:10px;min-width:0;margin-left:auto;padding-right:8px}.portion-batch-chip{display:inline-flex;align-items:center;gap:6px;background:var(--card-soft);border:1px solid var(--border-soft);border-radius:999px;padding:4px 8px;font-size:12px;font-weight:600;color:var(--text-main);white-space:nowrap}.portion-header{display:flex;align-items:center;gap:8px;width:auto}.portion-label{font-size:12px;color:var(--text-muted);font-weight:700}.portion-help-btn{border:none;background:var(--card-white);color:var(--text-main);border-radius:999px;width:20px;height:20px;font-size:12px;cursor:pointer;border:1px solid rgba(0,0,0,.08)}.portion-help-btn:hover{background:var(--card-soft)}.portion-kcal{font-size:13px;font-weight:700;color:var(--text-main)}.portion-stepper-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;width:auto}.portion-subtext{font-size:12px;color:var(--text-muted);white-space:nowrap}.portion-inline-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}@media(max-width:768px){.db-layout .portion-inline-row{justify-content:flex-start;gap:8px}.db-layout .card-macros-inline{margin-left:0;font-size:14px;color:var(--text-muted);white-space:nowrap}}.portion-info-below{display:inline-flex;align-items:center;margin-top:2px}.portion-stepper{display:inline-flex;align-items:center;gap:8px;padding:2px 4px;border:1px solid var(--border-soft);border-radius:8px;background:var(--card-white);box-shadow:0 4px 12px #0f172a14}.portion-stepper__btn{width:26px;height:26px;border:none;border-radius:6px;background:var(--card-soft);color:var(--text-main);font-size:15px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .16s ease,transform .16s ease,color .16s ease}.portion-stepper__btn:hover:not(:disabled){background:var(--accent-peach);color:var(--accent-main);transform:translateY(-1px)}.portion-stepper__btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.portion-stepper__value{min-width:36px;text-align:center;font-weight:700;font-size:14px;color:var(--text-main)}.card-bottom-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.card-refresh-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--card-soft);color:var(--accent-main);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 3px 8px #0f172a2e;transition:background .18s ease,transform .18s ease}.card-refresh-btn:hover{background:var(--accent-peach);transform:translateY(-1px)}.card-refresh-btn:disabled,.card-refresh-btn:disabled:hover{opacity:.6;cursor:not-allowed;background:var(--card-soft);transform:none;box-shadow:none}.card-refresh-btn svg{width:16px;height:16px}.card-lock-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-soft);background:var(--card-white);color:var(--text-main);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s ease,transform .18s ease,border-color .18s ease}.card-lock-btn:hover{background:var(--accent-soft);border-color:var(--accent-main);transform:translateY(-1px)}.card-lock-btn.is-locked{background:var(--card-soft);border-color:var(--border-strong)}.card-lock-btn.is-locked:hover{background:var(--card-soft);transform:translateY(-1px)}.card-remove-btn{position:absolute;top:10px;right:10px;border:none;background:#ffffffd9;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 3px 8px #0f172a2e;transition:background .2s ease,transform .2s ease;z-index:20;color:var(--accent-main)}.card-remove-icon{width:16px;height:16px;stroke:currentColor}.card-remove-btn:hover{background:var(--accent-peach);transform:translateY(-1px)}.favorite-toggle{position:absolute;top:12px;left:12px;width:34px;height:34px;border-radius:50%;border:none;background:#ffffffeb;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 3px 8px #0f172a2e;transition:background .18s ease,transform .18s ease,color .18s ease;z-index:15}.favorite-toggle svg{width:18px;height:18px;pointer-events:none}.favorite-toggle:hover{transform:translateY(-1px)}.favorite-toggle.favorite-active{background:#ffe5eb;color:#c5395d}.favorite-toggle.favorite-active path{fill:currentColor;stroke:currentColor}.favorite-toggle--hero.favorite-toggle--right{right:auto;left:12px}.favorite-toggle--right{left:auto;right:12px}.favorite-toggle--card{top:14px}.favorite-toggle--hero{top:18px;background:#f7e8d8e6}.favorite-toggle--small{width:30px;height:30px}.shopping-settings-card{margin:16px 0;padding:16px 20px;border-radius:24px;background:var(--card-white);box-shadow:0 6px 18px #0000000f;display:flex;flex-direction:column;gap:16px}.shopping-desktop-bar{margin:14px 0 12px;display:grid;grid-template-columns:.8fr .8fr 1.4fr;gap:12px}.shopping-desktop-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:12px 14px;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:#fff;box-shadow:0 4px 12px #0f172a0f}.shopping-desktop-card--source{gap:10px}.shopping-desktop-card--people{justify-content:flex-start}.shopping-desktop-card--people .people-stepper{width:100%}.shopping-desktop-card--people .people-stepper-label{font-size:12px}.shopping-days-inline{width:100%}.shopping-days-inline .shopping-day-toolbar{border:none;padding:0;background:transparent}.shopping-days-inline .day-checkbox-grid{flex-wrap:wrap;gap:6px}.shopping-days-inline .day-checkbox{margin:0}.shopping-days-inline .shopping-prep-option{padding:6px 0 0}.shopping-desktop-card--warning{border-color:#d96c428c;background:#fff4ec;box-shadow:0 6px 16px #d96c4224}.shopping-desktop-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);font-weight:600}.shopping-desktop-value{font-size:13px;font-weight:600;color:var(--text-main);line-height:1.3}.shopping-desktop-sub{font-size:11px;color:var(--text-muted)}.shopping-desktop-card .shopping-segmented,.shopping-desktop-select{width:100%}.shopping-desktop-select .shopping-weekly-select{width:100%;min-width:0;margin-top:0}.shopping-desktop-info{margin:0 0 16px}.shopping-mobile-bar{display:none;position:sticky;top:0;z-index:40;margin:0 0 12px;padding:10px 12px;border-radius:18px;background:#fffffff5;box-shadow:0 6px 18px #0f172a14;border:1px solid rgba(15,23,42,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-direction:column;gap:10px}.shopping-mobile-row{display:flex;align-items:stretch;gap:8px;flex-wrap:wrap}.shopping-mobile-row--inline{justify-content:space-between}.shopping-mobile-label{font-size:12px;font-weight:600;color:var(--text-main);white-space:nowrap}.shopping-mobile-trigger{flex:1 1 140px;min-width:120px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:8px 10px;border-radius:14px;border:1px solid rgba(15,23,42,.08);background:#fff;font:inherit;cursor:pointer;box-shadow:0 4px 12px #0f172a0f;text-align:left}.shopping-mobile-trigger:active{background:#f2f2f2}.shopping-mobile-trigger-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);font-weight:600}.shopping-mobile-trigger-value{font-size:13px;font-weight:600;color:var(--text-main);white-space:normal;line-height:1.25}.shopping-mobile-trigger-subtitle{font-size:11px;color:var(--text-muted)}.shopping-mobile-trigger--export{border-style:dashed;background:#fffaf6}.shopping-mobile-trigger--warning{border-color:#d96c428c;background:#fff4ec;box-shadow:0 6px 16px #d96c4224}.shopping-mobile-select{min-width:0;flex:1 1 auto;margin-top:0;height:32px}.shopping-mobile-info{display:flex;align-items:center;gap:8px;border-radius:12px;padding:6px 10px;background:#fff8f1;color:#7a6757;border:1px solid #f3e2d2;font-size:12px}.day-checkbox-grid--mobile{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}.day-checkbox-grid--mobile .day-checkbox{flex:0 0 auto}.day-checkbox-grid--sheet{gap:8px}.shopping-sheet-section{display:flex;flex-direction:column;gap:10px}.shopping-sheet-label{font-size:13px;font-weight:600;color:var(--text-main)}.shopping-sheet-presets{display:flex;flex-wrap:wrap;gap:8px}.shopping-sheet-filters{margin-bottom:6px}.shopping-group-filter{display:flex;flex-direction:column;gap:8px}.shopping-group-trigger{align-self:flex-start;border:1px solid var(--border-soft);background:#fff;color:var(--text-main);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.shopping-sheet-chip{border:1px solid var(--border-soft);background:#fff;color:var(--text-main);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.shopping-sheet-chip--active{background:#fff1e7;border-color:#d6805299;color:#5c3b29;box-shadow:0 4px 10px #d6805229}.shopping-sheet-chip:active{background:#f3f1ee}.shopping-sheet-center{align-items:center;justify-content:center;padding:12px 0}.people-stepper--sheet{padding:8px 14px}.shopping-people-hint{margin-top:8px;font-size:12px;color:var(--text-muted)}.shopping-days-footer{display:flex;gap:10px}.shopping-days-reset,.shopping-days-apply{flex:1 1 0;height:46px;border-radius:14px;font-size:14px;font-weight:600;cursor:pointer}.shopping-days-reset{border:1px solid var(--border-soft);background:#f3f1ee;color:var(--text-main)}.shopping-days-apply{border:none;background:var(--zdk-dark);color:#fff;box-shadow:0 8px 20px #0f172a33}.shopping-plan-list{display:flex;flex-direction:column;gap:8px;max-height:45vh;overflow-y:auto;padding-right:4px}.shopping-plan-item{border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:14px;padding:10px 12px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;font:inherit;cursor:pointer}.shopping-plan-item--active{border-color:#d6805299;background:#fff6ef;box-shadow:0 6px 14px #d680522e}.shopping-plan-title{font-size:14px;font-weight:600;color:var(--text-main)}.shopping-plan-sub{font-size:12px;color:var(--text-muted)}.shopping-plan-empty{font-size:13px;color:var(--text-muted);padding:6px 2px}.people-stepper--compact{padding:4px 8px}.people-stepper--compact .people-stepper-controls{gap:6px}.people-stepper--compact .people-stepper-btn{width:24px;height:24px;font-size:14px}.people-stepper--compact .people-stepper-value{min-width:28px;font-size:13px}.shopping-mobile-prep{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-main)}.shopping-source-main{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.shopping-source-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.shopping-label-with-info{display:inline-flex;align-items:center;gap:6px}.shopping-source-info .info-hint-button{width:18px;height:18px}.shopping-settings-label{font-size:14px;font-weight:600;color:#3b322c;margin:0}.shopping-source-right{display:flex;flex-direction:column;gap:4px;min-width:260px;flex:1 1 260px}.shopping-source-right-label{font-size:13px;font-weight:500;color:#6b6259;display:block;margin:4px 0 2px}.shopping-source-right-row{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap}.shopping-weekly-date-field{display:flex;align-items:center;gap:8px;min-width:200px;flex-wrap:wrap}.shopping-weekly-select,.shopping-weekly-date{height:36px;padding:0 12px;border-radius:999px;border:1px solid #e3ded8;background:#fff;font-size:13px;color:#3b322c;margin-top:5px;font-family:inherit;line-height:1}.shopping-weekly-select{min-width:200px}.shopping-weekly-date{min-width:170px}.shopping-weekly-dropdown{position:relative;width:100%}.shopping-weekly-trigger{width:100%;height:36px;padding:0 12px;border-radius:999px;border:1px solid #e3ded8;background:#fff;font-size:13px;color:#3b322c;font-family:inherit;line-height:1;display:inline-flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}.shopping-weekly-trigger:disabled{cursor:not-allowed;opacity:.6}.shopping-weekly-trigger-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shopping-weekly-trigger-icon{font-size:12px;color:#6b6259}.shopping-weekly-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;padding:6px;border-radius:14px;border:1px solid rgba(15,23,42,.12);background:#fff;box-shadow:0 12px 24px #0f172a29;max-height:300px;overflow-y:auto}.shopping-weekly-option{width:100%;border:none;background:transparent;padding:8px 10px;text-align:left;font-size:13px;line-height:1.35;color:#2f2a26;border-radius:10px;cursor:pointer}.shopping-weekly-option:hover,.shopping-weekly-option:focus-visible{background:#f3f1ee}.shopping-weekly-option--active{background:#3b322c;color:#fff}.shopping-weekly-option--active:hover,.shopping-weekly-option--active:focus-visible{background:#2f2924}.shopping-weekly-select option{color:#2f2a26;background-color:#fff}.shopping-weekly-select option:checked,.shopping-weekly-select option:hover,.shopping-weekly-select option:focus{color:#fff;background-color:#3b322c}.shopping-weekly-select option:disabled{color:#9a8f85;background-color:#f7f4f1}.shopping-weekly-select:focus,.shopping-weekly-date:focus{outline:none;border-color:var(--zdk-dark);box-shadow:0 0 0 2px #db69262e}.shopping-field{display:flex;flex-direction:column;gap:6px}.shopping-field-label{font-size:12px;font-weight:600;color:var(--text-main)}.shopping-segmented{display:inline-flex;flex-wrap:wrap;align-items:center;gap:4px;padding:4px 6px;border-radius:999px;background:var(--card-soft);border:1px solid var(--border-soft);flex:0 0 auto;max-width:100%}.shopping-segmented-btn{border:none;background:transparent;padding:6px 14px;min-height:32px;border-radius:999px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.shopping-segmented-btn:hover{color:var(--text-main)}.shopping-segmented-btn-active{background:#fff;color:var(--text-main);font-weight:600;box-shadow:0 3px 8px #0f172a1f}.shopping-field-control{display:inline-flex}.shopping-field-control select,.shopping-field input[type=date],.shopping-source-date input[type=date]{border-radius:18px;border:1px solid var(--border-soft);padding:8px 12px;font-size:13px;background:#fff;color:var(--text-main);min-width:180px}.shopping-field-hint{font-size:12px;color:var(--text-subtle)}.shopping-info-box{display:flex;align-items:center;gap:8px;border-radius:18px;padding:10px 14px;background:#fff8f1;color:#7a6757;border:1px solid #f3e2d2;font-size:12px;box-shadow:0 4px 12px #0000000a}.shopping-info-icon{font-size:14px}.shopping-days-card{margin:0 0 16px;padding:14px 20px 12px;border-radius:24px;background:var(--card-white);box-shadow:0 4px 14px #0000000d;display:flex;flex-direction:column;gap:10px}.shopping-days-label{font-size:13px;font-weight:600;color:var(--text-main)}.shopping-days-title{display:none}.shopping-day-toolbar{border:1px solid var(--border-soft);border-radius:18px;padding:8px 10px;background:#fff}.shopping-prep-option{display:flex;align-items:center;gap:10px;padding:2px 2px 0;font-size:13px;color:var(--text-main);flex-wrap:wrap}.shopping-prep-checkbox{display:flex;align-items:center;gap:10px}.shopping-prep-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-peach)}.shopping-prep-checkbox span{font-weight:600}.shopping-export-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.shopping-export-action{width:100%;height:44px;border-radius:14px;border:1px solid var(--border-soft);background:#fff;font-size:14px;font-weight:600;color:var(--text-main);cursor:pointer;box-shadow:0 6px 16px #0f172a14}.shopping-export-action:disabled{background:#f1f1f1;color:#9a9a9a;cursor:not-allowed;box-shadow:none}.shopping-export-button{padding:6px 14px;border-radius:999px;border:1px solid #d4d4d4;background:#f3f3f3;color:#555;font-size:13px;font-weight:500;cursor:pointer}.shopping-export-button:hover{background:#e8e8e8}.shopping-export-button[data-tooltip]{position:relative}.shopping-export-button[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:50%;top:calc(100% + 10px);transform:translate(-50%);width:max-content;max-width:320px;padding:10px 12px;border-radius:12px;background:#141414eb;color:#fff;font-size:12px;font-weight:500;line-height:1.25;box-shadow:0 10px 26px #00000038;opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:10}.shopping-export-button[data-tooltip]:hover:after{opacity:1}.shopping-export-hint{margin-top:8px;margin-bottom:8px;font-size:13px;color:#8a8a8a}.shopping-note-box{margin:10px 0 12px;padding:10px 12px;border-radius:12px;background:#fdf8f0;border:1px solid rgba(63,46,35,.12)}.shopping-note-label{font-weight:600;font-size:13px;color:#5a4635;margin-bottom:4px}.shopping-note-text{font-size:13px;color:#665746;line-height:1.4;white-space:pre-line}.shopping-wrap{padding:16px 20px 18px;border-radius:24px;background:var(--card-white);box-shadow:0 6px 18px #0000000f}.shopping-box-divider{width:100%;height:1px;background:#3f2e2314;margin:8px 0 14px}.shopping-box-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:18px;margin-bottom:16px}.shopping-box-left{display:flex;align-items:center;gap:18px}.shopping-box-title{font-weight:600;font-size:16px;color:var(--text-main)}.day-checkbox-grid{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.day-checkbox{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;background:#fff;font-size:12px;color:var(--text-muted);border:1px solid var(--border-soft);transition:background .18s ease,border-color .18s ease,color .18s ease;cursor:pointer;-webkit-user-select:none;user-select:none}.day-checkbox-all{font-size:11px;padding:3px 8px;opacity:.9}.day-checkbox input{accent-color:var(--accent-main)}.day-checkbox-active{background:#efeeed;color:var(--text-main);border-color:#efeeed}.day-checkbox input:disabled+span{opacity:.5}.people-stepper{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:999px;background:var(--card-soft);border:1px solid var(--border-soft)}.people-stepper-label{font-size:12px;color:var(--text-muted);font-weight:500}.people-stepper-controls{display:inline-flex;align-items:center;gap:8px}.people-stepper-btn{width:26px;height:26px;border-radius:50%;border:none;background:var(--zdk-dark);color:#fff;font-size:16px;line-height:1;cursor:pointer;box-shadow:0 3px 8px #0f172a33;transition:opacity .18s ease,transform .18s ease}.people-stepper-btn:disabled{opacity:.4;cursor:default;box-shadow:none}.people-stepper-btn:not(:disabled):hover{background:var(--zdk-dark-hover);transform:translateY(-1px)}.people-stepper-btn:not(:disabled):active{background:var(--zdk-dark-active)}.people-stepper-value{font-weight:600;color:var(--text-main);min-width:32px;text-align:center}.shopping-list{margin-top:4px;display:flex;flex-direction:column;gap:4px;max-height:420px;overflow-y:auto}.ingPage{font-size:13px;line-height:1.25;background:#ffffffd9;border-radius:26px;padding:16px 18px;border:1px solid rgba(63,46,35,.06);box-shadow:0 10px 30px #0f172a14}.catCard{border:1px solid rgba(63,46,35,.08);border-radius:22px;padding:18px 22px;background:#fff}.catCard+.catCard{margin-top:18px}.catTitle{font-weight:800;font-size:14px;margin:0 0 10px}.itemsGrid{display:grid;grid-template-columns:1fr;gap:6px 18px}@media(min-width:900px){.itemsGrid{grid-template-columns:1fr 1fr}}.itemRow{display:grid;grid-template-columns:70px 1fr;gap:10px;align-items:baseline;padding:6px 8px;border-radius:10px;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;font:inherit}.itemRow.isAlt{background:#f8f5f1b3}.itemRow.isChecked{background:#e0f2e5b3}.itemRow.isChecked .itemName,.itemRow.isChecked .itemQty{text-decoration:line-through;color:#6f6a63}.itemRow:focus-visible{outline:2px solid rgba(226,112,80,.45);outline-offset:2px}.itemQty{font-variant-numeric:tabular-nums;opacity:.9;color:#8c8379;white-space:nowrap}.itemName{font-weight:650;min-width:0}.ingCompact .itemRow{padding:4px 6px}.ingCompact .catCard{padding:12px}.shopping-category{border:1px solid #ead7c7;border-radius:8px;padding:10px;background:#fffaf5}.shopping-category+.shopping-category{margin-top:6px}.shopping-category-title{font-weight:700;font-size:12px;color:var(--text-main);margin-bottom:6px}.shopping-category-items{display:flex;flex-direction:column;gap:4px}.shopping-item{display:flex;align-items:flex-start;gap:6px;font-size:12px;color:var(--text-main)}.shopping-empty{font-size:11px;color:#b8aa9f;text-align:left}.shopping-empty-text{font-size:13px;color:var(--text-muted)}.shopping-empty-cta{margin-top:10px;border-radius:999px;border:none;padding:8px 14px;background:var(--zdk-dark);color:#fff;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 6px 16px #0f172a2e}.shopping-empty-cta:active{background:var(--zdk-dark-active)}.loading-wrap,.error-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-pill{padding:10px 18px;border-radius:999px;background:var(--card-white);box-shadow:0 4px 10px #0000001a;font-size:13px}.error-text{color:var(--status-critical-text)}@media(max-width:1200px){.app-root{padding:24px 24px 28px}.meals{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:900px){.top-grid{display:flex;flex-direction:column;align-items:stretch;gap:10px}.day-summary{max-width:100%}.meals{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.app-root{padding:18px 14px}.brand-wrap{margin-bottom:8px}.brand-wrap.app-header{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:0 0 8px}.app-header-left{width:auto;flex:1 1 auto;justify-content:flex-start}.brand-actions{margin-left:auto;width:auto;flex:0 0 auto;justify-content:flex-end;align-self:center}.logo-wrapper{width:32px;height:32px}.user-trigger{width:40px;height:40px}.main-tabs-wrap{margin:0 auto 10px;width:100%}.main-tabs{width:100%;flex-wrap:wrap;justify-content:space-between;gap:6px}.main-tab-btn{flex:1 1 45%;text-align:center;min-width:0;padding:10px 12px}.pageHeader{padding:0 0 28px}.top-grid{margin-top:4px;margin-bottom:10px;gap:8px}.group-tabs{flex-wrap:wrap}.meals{grid-template-columns:1fr}}@media(max-width:768px){:root{--bottom-nav-height: 88px}.app-root{padding-bottom:calc(110px + env(safe-area-inset-bottom))}.page,.content{padding-bottom:calc(90px + env(safe-area-inset-bottom))}.main-tabs-wrap{position:fixed;left:0;right:0;bottom:0;margin:0;padding:0 14px calc(10px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#f4f4f500,#f4f4f5d9 38%,#f4f4f5);z-index:120}.main-tabs{width:100%;flex-wrap:nowrap;justify-content:space-between;gap:0;padding:10px 12px;border-radius:24px 24px 28px 28px;background:#fffffff5;border:1px solid rgba(15,23,42,.06);box-shadow:0 -8px 22px #0f172a14;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.main-tab-btn{flex:1 1 0;min-width:0;min-height:78px;padding:10px 6px 8px;border-radius:18px;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;font-size:12px;font-weight:600;color:var(--text-subtle);background:transparent;outline:none;-webkit-touch-callout:none;position:relative}.main-tab-btn.has-tag{padding-top:10px}.main-tab-btn-icon{display:block;width:24px;height:24px;color:inherit;line-height:1}.main-tab-btn-icon svg{display:block;vertical-align:top}.main-tab-btn-label{line-height:1.1;display:inline-block;width:auto}.main-tab-btn:focus,.main-tab-btn:focus-visible,.main-tab-btn:active{background:transparent!important;box-shadow:none!important;outline:none;color:inherit}.main-tab-btn.active,.main-tab-btn.active:active,.main-tab-btn.active:focus-visible,.main-tab-btn.active:focus{background:transparent!important;color:var(--zdk-dark);box-shadow:none}.main-tab-btn:after{content:"";position:absolute;left:50%;transform:translate(-50%);bottom:6px;height:3px;border-radius:999px;width:36px;background:transparent}.main-tab-btn.active:after{background:var(--zdk-dark)}.main-tab-btn.active .main-tab-btn-label:after{background:var(--zdk-dark)}.main-tab-btn:hover:not(.active){background:transparent}.top-grid{margin-top:6px;gap:10px}.group-block{padding:12px 14px 10px}.group-desc{display:none}.day-summary{padding:14px 14px 12px;gap:6px;border-radius:20px}.day-summary-title{font-size:15px}.day-kpi-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.day-kpi{text-align:center;border:1px solid var(--border-soft);background:#fff;box-shadow:none;padding:10px 8px}.day-summary-sub{display:none}.week-bar-row{gap:10px;margin-bottom:6px}.week-bar .day-btn{padding:8px 14px}.plan-controls-row{justify-content:space-between;margin-top:0}.plan-controls-right{width:100%;justify-content:space-between}.plan-controls-right .plan-refresh-btn{flex:1 1 auto;min-width:0;height:36px;padding:0 12px;font-size:13px}.plan-controls-right .add-btn{width:36px;height:36px}.list-header{margin:2px 0 8px}.shopping-mobile-bar{display:flex}.shopping-days-title{display:inline-flex}.shopping-desktop-bar,.shopping-desktop-info,.shopping-settings-card,.shopping-days-card{display:none}.shopping-box-left{flex-direction:column;align-items:flex-start;gap:10px}.shopping-box-left .people-stepper,.shopping-export-buttons{display:none}.shopping-wrap{padding:12px 14px 16px;border-radius:20px}.shopping-list{max-height:none;overflow:visible;padding-bottom:calc(80px + env(safe-area-inset-bottom))}.ingPage{padding:12px 14px;border-radius:20px}.catCard{padding:12px 14px}}.recipe-modal-overlay{position:fixed;inset:0;background:#0000003d;display:flex;justify-content:center;align-items:flex-start;padding:40px 24px;z-index:999}.recipe-modal{max-width:1080px;width:100%;max-height:90vh;overflow-y:auto;background:var(--card-softer);border-radius:32px;padding:24px 28px;box-shadow:0 18px 40px #0000002e}.recipe-modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.recipe-modal-pill{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:11px;background:var(--accent-peach);color:var(--text-on-peach);margin-bottom:4px}.recipe-modal-title{margin:0;font-size:22px;font-weight:600;color:var(--text-main)}.recipe-modal-close{border:none;background:var(--accent-peach);border-radius:999px;width:28px;height:28px;font-size:16px;cursor:pointer;color:var(--text-on-peach)}.recipe-modal-close:hover{background:var(--accent-peach-hover)}.recipe-modal-close:active{background:var(--accent-peach-active)}.recipe-modal-macros{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.macro-pill{padding:6px 10px;border-radius:16px;background:var(--card-white);box-shadow:0 2px 6px #0000000a;min-width:90px}.macro-label{font-size:10px;color:var(--text-muted)}.macro-value{font-size:13px;font-weight:600;color:var(--text-main)}.recipe-modal-body{display:grid;grid-template-columns:1.2fr 1.5fr;gap:24px;align-items:flex-start}.recipe-section-title{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text-main)}.recipe-ingredients-list,.recipe-steps-list{margin:0;padding-left:18px;font-size:13px;color:var(--text-main)}.recipe-empty{font-size:12px;color:var(--text-subtle)}.recipe-modal-image-wrap{grid-column:1 / -1;margin-top:12px;display:flex;justify-content:center}.recipe-modal-image{max-width:100%;border-radius:24px;object-fit:cover}.filter-panel{margin-top:16px;padding:12px 16px;border-radius:24px;background:#fff;box-shadow:0 8px 24px #00000008}.filter-panel .filter-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:4px}.filter-panel .filter-title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1 1 auto}.filter-panel .filter-label{font-size:14px;font-weight:600;color:var(--text-main);margin:0}.filter-panel .filter-chips{display:flex;flex-wrap:wrap;gap:6px}.filter-panel .filter-header-right{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.filter-panel .filter-header-slot{display:flex;align-items:center}.filter-panel .filter-header-right .week-bar-wrapper,.filter-panel .filter-header-right .week-bar{margin:0}.filter-panel .chip-btn{display:inline-flex!important;align-items:center;justify-content:center;border:0px solid var(--border-soft)!important;padding:4px 10px;border-radius:999px;font-size:12px;cursor:pointer;background:#f4efe9!important;color:var(--text-main)!important;box-shadow:none;white-space:nowrap;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease}.filter-panel .chip-btn:disabled,.filter-panel .chip-btn-disabled{background:#f0efee!important;border:1px dashed rgba(58,58,58,.15)!important;color:#3a3a3a8c!important;cursor:not-allowed;box-shadow:none}.filter-panel .chip-btn:hover{background:#ece5dd!important;color:var(--text-main)!important}.filter-panel .chip-btn:active{background:#e3d9cf!important;color:var(--text-main)!important}.filter-panel .chip-btn.selected,.filter-panel .chip-btn-active{background:var(--accent-peach)!important;border-color:transparent!important;color:var(--text-on-peach)!important;font-weight:600;box-shadow:0 3px 8px #0000000f}.filter-panel .chip-btn.selected:hover,.filter-panel .chip-btn-active:hover{background:var(--accent-peach)!important;color:var(--text-on-peach)!important}.filter-panel .chip-btn.selected:active,.filter-panel .chip-btn-active:active{background:var(--accent-peach-active)!important;color:var(--text-on-peach)!important}.filter-panel .chip-btn[aria-controls=db-advanced-filters]{background:#fde9cc!important;color:var(--text-main)!important}.filter-panel .chip-btn.chip-btn-active[aria-controls=db-advanced-filters]{background:#fad6c6!important;color:var(--text-main)!important}.filter-panel .chip-label-text{display:inline-flex;align-items:center;font-weight:500}.filter-panel .chip-soon-label{margin-left:6px;padding:1px 6px;border-radius:999px;background:#3a3a3a1f;color:#3a3a3aa6;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.filter-panel .chip-clear{display:inline-flex!important;align-items:center;justify-content:center;background:transparent!important;border:1px solid var(--border-soft)!important;color:var(--accent-main)!important;padding:4px 10px;font-size:12px;font-weight:500;white-space:nowrap}.filter-panel .chip-clear:hover{background:#f4efe9!important}.plan-controls-row{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:12px;margin-top:4px}.plan-controls-right{display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.plan-controls-right .meals-per-day{margin-left:0}.plan-controls-right .plan-refresh-btn{height:40px;border-radius:999px;padding:0 18px}.plan-controls-right .plan-add-food-btn{height:40px;border-radius:999px;padding:0 14px}.plan-controls-right .icon-btn{--btn-bg: var(--ui-surface);--btn-bg-hover: var(--ui-ghost);--btn-bg-pressed: var(--ui-ghost-pressed);--btn-text: var(--ui-text);--btn-border: var(--ui-border);--btn-shadow: none;border-radius:14px}.plan-controls-right .add-btn{width:40px;height:40px;margin-left:4px}.plan-layout--mobile{padding-bottom:calc(176px + env(safe-area-inset-bottom))}.plan-layout--mobile .group-block{display:none}.mobile-group-tabs{display:flex;flex-wrap:wrap;gap:8px}.floating-action-bar{position:fixed;left:50%;bottom:calc(28px + env(safe-area-inset-bottom) + var(--bottom-nav-height, 0px));transform:translate(-50%);width:min(520px,calc(100% - 32px));display:flex;align-items:center;gap:12px;padding:0;background:transparent;border:none;box-shadow:none;z-index:140}.floating-action-bar__primary{flex:1 1 auto;height:48px;border-radius:999px;border:none;padding:0 20px;font-size:15px;font-weight:600;background:var(--ui-primary);color:var(--ui-text-on-primary);cursor:pointer;box-shadow:0 10px 22px #0f172a24}.floating-action-bar__primary:active{background:var(--ui-primary-pressed)}.floating-action-bar__overflow{width:48px;height:48px;border-radius:999px;border:1px solid var(--ui-border);background:var(--ui-ghost);color:var(--ui-text);font-size:18px;font-weight:700;letter-spacing:1px;cursor:pointer;box-shadow:0 10px 22px #0f172a1f}.floating-action-bar__overflow:active{background:var(--ui-ghost-pressed)}.plan-actions-sheet{display:flex;flex-direction:column;gap:10px}.plan-action-item{width:100%;border-radius:14px;border:1px solid var(--ui-border);background:#fff;padding:12px 14px;display:inline-flex;align-items:center;gap:12px;font-size:15px;font-weight:600;color:var(--ui-text);text-align:left}.plan-action-item:active{background:var(--ui-ghost)}.plan-action-icon{width:36px;height:36px;border-radius:12px;background:var(--ui-ghost);display:inline-flex;align-items:center;justify-content:center;font-size:18px}.plan-action-label{flex:1}.save-plan-btn{height:40px;border-radius:999px;padding:0 16px}.plan-status-row{display:flex;gap:12px;align-items:center;margin:6px 0 10px}.plan-success-text{color:var(--zdk-dark);font-weight:600}.saved-plans-section{margin:12px 0 24px;padding:14px 18px;border:1px solid var(--border-soft);border-radius:14px;background:var(--card-softer)}.saved-plans-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.saved-plans-list{list-style:none;padding:0;margin:10px 0 0;display:flex;flex-direction:column;gap:10px}.saved-plan-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-soft)}.saved-plan-row:last-child{border-bottom:none}.saved-plan-meta{display:flex;flex-direction:column;gap:4px}.saved-plan-actions{display:flex;align-items:center;gap:8px}.saved-plan-actions .icon-btn{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.saved-plan-date{color:var(--text-muted);font-size:12px}.plan-modal-backdrop{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;padding:20px;z-index:9999}.plan-modal{width:min(460px,100%);background:#fffaf4;border-radius:18px;padding:20px 20px 16px;box-shadow:0 16px 40px #0000002e;border:1px solid #f0e2d7}.plan-modal-header h3{margin:0 0 12px}.plan-modal-body{display:flex;flex-direction:column;gap:8px}.plan-modal-label{font-size:13px;color:var(--text-muted)}.plan-modal-input{width:100%;border-radius:10px;border:1px solid var(--border-soft);padding:10px 12px;font-size:15px;background:#fff}.plan-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.plan-modal-error{margin:0}.shopping-banner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 24px;margin:28px 0 20px;border-radius:18px;border:1px solid #f3d7c5;background:linear-gradient(135deg,#fff9f4,#fff3eb);box-shadow:0 12px 30px #4d332014}.shopping-banner-copy{display:flex;flex-direction:column;gap:4px;color:#5b4a3a}.shopping-banner-title{font-size:16px;font-weight:600;margin:0}.shopping-banner-text{font-size:14px;margin:0;color:#7c6a58}.shopping-banner-button{padding:10px 18px;border-radius:999px;border:none;background:#f0a77b;color:#fff;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 10px 20px #f0a77b59;transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap}.shopping-banner-button:hover{transform:translateY(-1px);box-shadow:0 14px 28px #f0a77b73}.shopping-banner-button:active{transform:translateY(0);box-shadow:0 6px 18px #f0a77b4d}@media(max-width:900px){.shopping-banner{flex-direction:column;align-items:flex-start}.shopping-banner-button{width:100%;text-align:center}}.meals-dropdown{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:4px 18px;border-radius:999px;border:1px solid var(--border-soft);background:var(--card-softer);color:var(--text-main);font-size:13px;cursor:pointer;line-height:1.3;box-shadow:0 3px 8px #0f172a1f}.add-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--zdk-dark);color:#fff;font-size:18px;font-weight:500;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px #0f172a2e;transition:background .16s ease,box-shadow .16s ease,transform .16s ease}.add-btn:hover{background:var(--zdk-dark-hover);box-shadow:0 4px 10px #0f172a40;transform:translateY(-1px)}.add-btn:active{transform:translateY(0);box-shadow:0 2px 6px #0f172a2e;background:var(--zdk-dark-active)}.chip-btn{display:flex;align-items:center;justify-content:center;height:32px;padding:0 14px;border-radius:16px;border:1px solid transparent;cursor:pointer;font-size:13px}.chip-btn.primary{background-color:var(--zdk-dark);color:#fff}.chip-btn.primary:hover{background-color:var(--zdk-dark-hover)}.chip-btn.primary:active{background-color:var(--zdk-dark-active)}.chip-btn.week-overview-btn{background:#f4f5f7;color:var(--text-main);border-color:var(--zdk-border-soft);box-shadow:none}.chip-btn.week-overview-btn:hover{background:#eceff3;border-color:#0f172a24;color:var(--text-main)}.chip-btn.week-overview-btn:focus-visible{box-shadow:0 0 0 2px #0f172a14}.chip-btn.week-overview-btn.chip-btn-active{background:#eef1f5;border-color:var(--zdk-border-soft);color:var(--text-main)}.chip-btn.week-overview-btn.chip-btn-active:hover{background:#e6eaef;border-color:#0f172a2e}.mobile-sheet-overlay{position:fixed;inset:0;background:#0f172a47;display:flex;align-items:flex-end;justify-content:center;z-index:60;padding:0 10px env(safe-area-inset-bottom)}.mobile-sheet-overlay-center{align-items:center;padding:24px 10px}.mobile-sheet{width:min(420px,92vw);background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -6px 28px #0f172a2e;overflow:hidden;animation:slideUp .18s ease-out;padding-bottom:env(safe-area-inset-bottom)}.mobile-sheet--centered{width:min(360px,86vw);border-radius:20px;padding-bottom:0;margin:0 auto;align-self:center;transform:translateY(-88px)}@keyframes slideUp{0%{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}.mobile-sheet-handle{width:48px;height:6px;border-radius:999px;background:#0f172a1f;margin:10px auto 6px}.mobile-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 14px 8px}.mobile-sheet-title{font-size:15px;font-weight:700;color:var(--text-main)}.mobile-sheet-close{width:36px;height:36px;border-radius:12px}.mobile-sheet--centered .mobile-sheet-close{width:44px;height:44px}.mobile-sheet--centered .mobile-sheet-close svg{width:24px;height:24px}.mobile-sheet-body{max-height:70vh;overflow-y:auto;padding:4px 14px 14px;display:flex;flex-direction:column;gap:12px}.db-actions-sheet{margin-top:-6px}.mobile-sheet-footer{padding:10px 14px 14px;background:linear-gradient(180deg,#fff0,#ffffffe6 38%,#fff)}.mobile-sheet-close-action{width:100%;height:48px;border-radius:14px;border:1px solid var(--ui-border);background:#f3f1ee;color:var(--ui-text);font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 6px 16px #0f172a1a}.mobile-sheet-close-action:hover{background:#eeebe7}.mobile-sheet-close-action:active{background:#e6e2dd;box-shadow:0 4px 12px #0f172a14}.mobile-save-button{width:100%;height:54px;border-radius:14px;border:none;background:var(--zdk-dark);color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 10px 28px #0f172a33;transition:background .18s ease,transform .12s ease,box-shadow .18s ease}.mobile-save-button:hover{background:var(--zdk-dark-hover);box-shadow:0 12px 32px #0f172a3d}.mobile-save-button:active{background:var(--zdk-dark-active);transform:translateY(1px);box-shadow:0 8px 22px #0f172a2e}.mobile-save-button:disabled{background:#d9d9d9;color:#888;cursor:not-allowed;box-shadow:none}.mobile-sheet-section{background:#faf8f6;border:1px solid rgba(15,23,42,.05);border-radius:14px;padding:12px;box-shadow:inset 0 1px #fff9}.mobile-sheet-section .meals-per-day{width:100%;flex-wrap:wrap;justify-content:space-between}.mobile-sheet-section .save-plan-btn{order:3}.mobile-sheet-section .meals-per-day-select-wrap{margin-left:auto}.mobile-filter-chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.mobile-filter-chip-grid .chip-btn{width:100%;justify-content:center;font-weight:600}.mobile-filter-chip-grid .chip-btn-active{background:var(--accent-peach);color:var(--text-on-peach);border-color:transparent;box-shadow:0 6px 14px #e2956e47}.mobile-filter-chip-grid .chip-btn-disabled,.mobile-filter-chip-grid .chip-btn:disabled{background:#f0efee;border:1px dashed rgba(58,58,58,.15);color:#3a3a3a8c;cursor:not-allowed;box-shadow:none}.mobile-filter-label{display:block;font-weight:700;font-size:13px;margin-bottom:6px}.mobile-filter-input{width:100%;border:1px solid var(--border-soft);border-radius:12px;padding:10px 12px;font-size:14px;color:var(--text-main);background:#fff}.mobile-filter-selected{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.mobile-filter-footer{display:flex;justify-content:space-between;gap:10px}.mobile-settings-group{display:flex;flex-direction:column;gap:10px}.mobile-settings-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.mobile-settings-row--toggle{align-items:flex-start;flex-direction:column}.mobile-settings-row--toggle .prep-toggle{width:100%;justify-content:space-between}.mobile-settings-row--toggle .prep-toggle-btn{flex:1;text-align:center;padding:8px 10px}.mobile-settings-title{font-weight:700;color:var(--text-main);font-size:14px}.mobile-settings-sub{font-size:12px;color:var(--text-muted)}.welcome-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#fde2cf;padding:24px}.welcome-card{width:100%;max-width:500px;background:#fff;border-radius:16px;box-shadow:0 18px 40px #e2905440;padding:32px;text-align:center;flex:1}.welcome-card h1{margin-bottom:4px;color:#b35a2e}.welcome-created{font-size:14px;color:#b37a57;margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}.welcome-subtitle{color:#8a6f58;margin-bottom:14px}.welcome-toggle{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:24px}.welcome-toggle button{border:1px solid #f0c6a7;background:transparent;border-radius:999px;padding:10px;font-weight:600;cursor:pointer;color:#c07845;transition:all .2s ease}.welcome-toggle button.active{background:#e39c5c;color:#fff;border-color:#e39c5c}.welcome-form{display:flex;flex-direction:column;gap:16px;text-align:left}.welcome-form label{font-size:14px;color:#7b6554;display:flex;flex-direction:column;gap:6px}.welcome-form input{border-radius:10px;border:1px solid #ead7cb;padding:10px 12px;font-size:15px}.welcome-form button[type=submit]{border:none;border-radius:999px;padding:12px;font-size:16px;font-weight:600;background:#c96d2d;color:#fff;margin-top:8px;cursor:pointer;transition:background .2s ease,transform .2s ease}.welcome-form button[type=submit]:hover:enabled{background:#e47b32;transform:translateY(-1px)}.welcome-form button[type=submit]:disabled{opacity:.65;cursor:not-allowed}.welcome-reset-hint{margin:4px 0 0;padding:10px 12px;background:#fff6ef;border:1px dashed #f0c6a7;border-radius:10px;color:#7b6554;font-size:14px;line-height:1.5}.welcome-link{background:none;border:none;padding:0;color:#c96d2d;font-weight:700;text-decoration:underline;text-underline-offset:3px;cursor:pointer;align-self:flex-start}.welcome-link:hover{color:#e47b32}.welcome-error{color:#c62828;font-size:14px}.welcome-info{color:#2e7d32;font-size:14px}.welcome-herohero-note{margin-top:32px;padding-top:24px;border-top:1px solid #f0e0d5;font-size:14px;color:#7b6554;line-height:1.5}.welcome-herohero-note a{color:#c96d2d;font-weight:700;text-decoration:underline;text-underline-offset:2px}.welcome-herohero-help,.relay-help{margin-top:12px}.welcome-help-toggle{display:inline-flex;align-items:center;gap:8px;padding:6px 9px;border-radius:10px;border:1px solid #ece2d9;background:#fffaf6;color:#7b6554;font-weight:600;cursor:pointer}.welcome-help-toggle:hover{background:#fff2ea;border-color:#e8d8cd}.welcome-help-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:#e8d8cd;color:#8a6f60;font-weight:800;font-size:12px}.welcome-help-content{margin-top:10px;padding:12px;border-radius:12px;background:#fff9f3;border:1px solid #f0e0d5;color:#6a5648;font-size:14px}.welcome-help-content p{margin:0 0 10px}.welcome-help-img{display:block;width:100%;max-width:460px;border-radius:12px;border:1px solid #e6d6c8;box-shadow:0 10px 30px #00000014}.welcome-footer{margin-top:20px;font-size:13px;color:#7b6554}.welcome-footer a{color:#c96d2d;font-weight:600}.herohero-gate{display:flex;align-items:center;justify-content:center;background:var(--app-bg);padding:32px 24px}.herohero-card{max-width:680px;width:100%;background:#fff;border-radius:18px;box-shadow:0 20px 48px #bc622f2e;padding:36px;text-align:left;border:1px solid rgba(201,109,45,.08)}.herohero-card h1{margin-bottom:6px;color:#b35a2e;font-size:clamp(26px,3vw,30px)}.herohero-card p{color:#6a5648;line-height:1.6}.herohero-card a{color:#c96d2d;font-weight:600}.herohero-sub{margin-top:0;margin-bottom:16px;color:#8a6f60}.herohero-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:12px 0 16px}.herohero-option{border:1px solid rgba(201,109,45,.14);border-radius:14px;padding:16px;background:#fffaf6}.herohero-option-primary{border-color:#c96d2d4d;background:linear-gradient(180deg,#fff1e7,#fffaf6);box-shadow:0 12px 32px #bc622f1f}.herohero-option h3{margin:6px 0 8px;color:#b35a2e;font-size:18px}.herohero-option-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.herohero-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#ffe2ce;color:#9a4a1d;font-weight:700;font-size:13px;letter-spacing:.1px}.herohero-pill-neutral{background:#f1e8e1;color:#7b6554}.herohero-price{font-weight:700;color:#b35a2e}.herohero-price-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.herohero-price-old{text-decoration:line-through;color:#a27d6b;font-weight:600;font-size:13px}.herohero-option p{margin:0;color:#6a5648}.herohero-benefits{list-style:none;padding:0;margin:8px 0 0;color:#6a5648;line-height:1.5}.herohero-benefits li{padding-left:0;position:relative}.herohero-link{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-weight:600;color:#c96d2d}.herohero-note{margin:12px 0 0;padding:14px 16px;border-radius:12px;background:#fff6f0;border:1px solid rgba(201,109,45,.12);color:#7b6554}.herohero-actions{margin-top:24px;display:flex;flex-direction:column;gap:12px}.herohero-btn{border:none;border-radius:999px;padding:14px 18px;font-size:15px;cursor:pointer;width:100%;text-align:center}.herohero-btn.primary{background:#c96d2d;color:#fff;font-weight:700}.herohero-btn.outline{background:#fff;color:#b35a2e;border:1px solid rgba(201,109,45,.35);font-weight:600}.herohero-btn.ghost{background:transparent;color:#b35a2e;border:1px solid rgba(179,90,46,.35);font-weight:600}.herohero-btn:disabled{opacity:.6;cursor:not-allowed}.herohero-logout-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.herohero-link-btn{background:transparent;border:none;color:#a26031;font-weight:600;text-decoration:underline;text-underline-offset:3px;cursor:pointer;align-self:flex-start;padding:6px 0}.herohero-logout-btn{width:auto;padding:4px 0;display:inline-flex;align-items:center}.herohero-email-note{margin:0;font-size:13px;color:#8a6f60;align-self:center;display:inline-flex;align-items:center;line-height:1.3}.herohero-error{margin-top:12px;color:#c62828}.footer-legal{margin-top:48px;padding:16px 0 32px;text-align:center;font-size:14px;line-height:1.5;color:#a6a6a6;max-width:1000px;margin-left:auto;margin-right:auto;opacity:.8}.footer-legal p{margin:0}.footer-share-row{display:flex;align-items:flex-start;justify-content:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.footer-share{display:flex;justify-content:center}.footer-share .share-cta{align-items:center}.footer-share .share-feedback{text-align:center}.footer-upgrade-cta{align-items:center}.footer-upgrade-btn{width:100%;justify-content:center}.footer-share-row .share-btn{width:100%;max-width:520px}.academy-page{width:100%}.academy-layout{display:flex;flex-direction:column;gap:28px}.academy-home,.academy-screen{display:flex;flex-direction:column;gap:32px}.academy-screen{background:#fff;border-radius:24px;padding:24px}.academy-section{display:flex;flex-direction:column;gap:18px;padding:24px;background:var(--card-softer);border-radius:20px}.academy-section.academy-section-muted{background:linear-gradient(180deg,#ffffffe0,#f7f8faeb);border:1px solid rgba(15,23,42,.06)}.academy-section .section-title{display:inline-flex;align-items:center;gap:8px;font-size:18px;font-weight:700}.academy-section-icon{width:28px;height:28px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#0f172a14;color:var(--accent-main)}.academy-section-icon svg{width:16px;height:16px}.academy-hero{padding:28px 28px 22px;margin-bottom:0;background:linear-gradient(135deg,#fffffff5,#f4f7faf2);border:1px solid rgba(15,23,42,.08);border-radius:22px;box-shadow:0 18px 32px #0f172a14}.academy-hero .pageHeaderTop{align-items:flex-start}.academy-hero .pageHeaderTitle{font-size:clamp(34px,5vw,46px);letter-spacing:-.02em;line-height:1.1}.academy-hero .pageHeaderDescription{font-size:14px;max-width:520px}.academy-hero-badge{align-self:flex-start;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-main);background:#0f172a0f;border:1px solid rgba(15,23,42,.12)}.academy-section.academy-start{background:linear-gradient(180deg,#ffffffe0,#f7f8faeb);border:1px solid rgba(15,23,42,.06)}.academy-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.academy-section-description{margin:0;color:var(--text-muted);font-size:14px}.academy-start-card{display:flex;flex-direction:column;align-items:stretch;gap:12px;padding:20px;border-radius:18px;border:1px solid rgba(15,23,42,.1);background:linear-gradient(180deg,#fff,#fbfcfe);text-align:left;font-size:16px;cursor:pointer;box-shadow:0 20px 36px #0f172a1a;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.academy-start-card:hover{transform:translateY(-2px);border-color:#0f172a29;box-shadow:0 24px 40px #0f172a1f}.academy-start-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.academy-start-card-title{display:flex;align-items:flex-start;gap:12px}.academy-start-icon{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#0f172a14;color:var(--accent-main)}.academy-start-icon svg{width:20px;height:20px}.academy-start-cta{white-space:nowrap;align-self:flex-start}.academy-start-card h3{margin:0 0 6px;font-size:18px}.academy-start-card p{margin:0;color:var(--text-muted);font-size:14px}.academy-start-progress{height:6px;border-radius:999px;background:#0f172a14;overflow:hidden}.academy-start-progress span{display:block;height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,#0f172ae6,#0f172a80);transition:width .3s ease}.academy-checklist-progress{font-size:14px;font-weight:600;color:var(--text-muted)}.academy-checklist{display:grid;gap:10px;padding:0;background:transparent;border-radius:0;border:none}.academy-checklist-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:14px;background:var(--card-white);border:1px solid rgba(15,23,42,.08);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;font-size:14px;color:var(--text-main)}.academy-checklist-row--action{width:100%;text-align:left;font:inherit}.academy-checklist-row.is-complete{border-color:#26845d59;background:#e2f4ec99}.academy-checklist-check{width:22px;height:22px;border-radius:999px;border:1px solid rgba(15,23,42,.2);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--text-muted);flex:0 0 auto}.academy-checklist-row.is-complete .academy-checklist-check{background:#26845d2e;border-color:#26845d66;color:#1f6b4a}.academy-checklist-row:hover{transform:translateY(-1px);border-color:#0f172a29;box-shadow:0 14px 24px #0f172a1f}.academy-checklist-row:active{transform:translateY(0);box-shadow:0 10px 18px #0f172a1f}.academy-checklist-row input{margin-top:2px;width:18px;height:18px;accent-color:var(--accent-main);box-shadow:0 6px 12px #0f172a1f}.academy-checklist-label{flex:1;line-height:1.4;display:flex;flex-direction:column;gap:2px}.academy-checklist-title{font-weight:600;color:var(--text-main)}.academy-checklist-subtitle{font-size:12px;color:var(--text-muted)}.academy-start-cta-full{margin-top:6px;align-self:flex-start}.academy-collection-card,.academy-plan-card{display:flex;align-items:flex-start;justify-content:flex-start;gap:16px;padding:18px;border-radius:20px;border:1px solid rgba(15,23,42,.08);background:var(--card-white);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.academy-collection-card h3,.academy-plan-card h3{margin:0 0 6px;font-size:18px}.academy-collection-desc,.academy-plan-meta{margin:0;font-size:14px;color:var(--text-muted)}.academy-collection-cover{--cover-hue: 220;width:58px;height:58px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,hsl(var(--cover-hue),80%,85%),hsl(var(--cover-hue),70%,75%));color:#0f172acc;flex-shrink:0}.academy-collection-cover svg{width:22px;height:22px}.academy-collection-body{flex:1;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.academy-collection-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.academy-tag{padding:4px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:lowercase;background:#0f172a14;color:var(--text-main)}.academy-collection-action{display:inline-flex;align-items:center;gap:6px;align-self:flex-start}.academy-collection-action svg,.academy-faq-cta svg{width:14px;height:14px}.academy-collection-card:hover,.academy-plan-card:hover,.academy-card:hover{transform:translateY(-2px);border-color:#0f172a29;box-shadow:0 18px 30px #0f172a1f}.academy-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.help-link-btn{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px}@media(max-width:768px){.academy-collection-card,.academy-plan-card{flex-direction:column;align-items:flex-start}.academy-collection-body{width:100%;flex-direction:column}}.academy-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.academy-card{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:16px;border:1px solid rgba(0,0,0,.06);background:var(--card-white);text-align:left;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.academy-card-header{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.academy-card-header h3{margin:0;font-size:18px}.academy-card-date{font-size:12px;color:var(--text-muted)}.academy-card-excerpt{margin:0;font-size:14px;color:var(--text-muted)}.academy-card-link{font-weight:600;color:var(--accent-main)}.academy-topbar{display:flex;justify-content:flex-start}.academy-detail-date{margin-top:-8px;color:var(--text-muted);font-size:13px}.academy-empty{margin:0;color:var(--text-muted)}.academy-markdown{display:flex;flex-direction:column;gap:12px;line-height:1.6}.academy-markdown p{margin:0}.academy-markdown a{color:var(--accent-main)}.academy-detail-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.academy-detail-cta{display:inline-flex;align-items:center;gap:6px}.academy-onboarding-panel{display:flex;justify-content:space-between;gap:18px;padding:18px 20px;border-radius:18px;background:linear-gradient(135deg,#f7f5ef,#eef6f1 45%,#eef2f7);border:1px solid rgba(15,23,42,.08);box-shadow:0 12px 24px #0f172a14;position:relative;overflow:hidden}.academy-onboarding-panel:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.7),transparent 45%),radial-gradient(circle at 85% 0%,rgba(255,255,255,.45),transparent 40%),radial-gradient(circle at 90% 90%,rgba(255,255,255,.6),transparent 45%);pointer-events:none}.academy-onboarding-copy{position:relative;z-index:1}.academy-onboarding-title{display:flex;gap:12px;align-items:flex-start;margin-bottom:6px}.academy-onboarding-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;background:#0f172a1a;color:var(--text-main)}.academy-onboarding-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:999px;background:#0f172a14;color:var(--text-main);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.academy-onboarding-copy h3{margin:0 0 6px}.academy-onboarding-copy p{margin:0;color:var(--text-muted)}.academy-onboarding-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;position:relative;z-index:1}.academy-onboarding-panel .academy-onboarding-actions{position:absolute;top:50%;right:20px;transform:translateY(-50%);z-index:2}.academy-onboarding-actions .academy-detail-cta{padding:8px 14px;border-radius:999px;border:1px solid rgba(15,23,42,.12);background:linear-gradient(135deg,#101827,#1f2937);color:#f8fafc;font-weight:600;transition:transform .16s ease,box-shadow .16s ease;opacity:0}.academy-onboarding-actions .academy-onboarding-cta-visible{opacity:1}.academy-onboarding-actions .academy-detail-cta:hover{transform:translateY(-1px);box-shadow:0 12px 22px #0f172a33}.academy-detail-cta--ghost{background:#fff9;color:var(--text-main);border-color:#0f172a1f}@media(max-width:760px){.academy-onboarding-panel{flex-direction:column;align-items:flex-start}.academy-onboarding-panel .academy-onboarding-actions{position:static;transform:none;width:100%;margin-top:12px;justify-content:flex-start}}.academy-checklist-intro{margin:0;color:var(--text-muted)}.academy-faq-list{display:flex;flex-direction:column;gap:14px}.academy-faq-item{padding:14px 16px;border-radius:16px;background:var(--card-white);border:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:8px;transition:border-color .16s ease,box-shadow .16s ease}.academy-faq-item:hover{border-color:#0f172a24;box-shadow:0 10px 18px #0f172a14}.academy-faq-answer{margin:0;color:var(--text-muted);font-size:14px}.academy-faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0;border:none;background:none;cursor:pointer;font-size:15px;font-weight:600;color:var(--text-main);text-align:left}.academy-faq-question span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.academy-faq-toggle{width:26px;height:26px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#0f172a14;color:var(--text-main);font-size:16px;transition:transform .18s ease,background .18s ease;flex-shrink:0}.academy-faq-body{max-height:0;opacity:0;overflow:hidden;padding-top:0;transition:max-height .18s ease,opacity .18s ease}.academy-faq-item.is-open{border-color:#0f172a29;box-shadow:0 14px 24px #0f172a1a}.academy-faq-item.is-open .academy-faq-body{max-height:320px;opacity:1;padding-top:10px}.academy-faq-item.is-open .academy-faq-toggle{transform:rotate(45deg);background:#0f172a24}.academy-faq-cta{margin-top:10px;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid rgba(15,23,42,.28);background:#0f172a0a;color:var(--text-main);font-size:13px;font-weight:600;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.academy-faq-cta:hover{border-color:#0f172a66;background:#0f172a14;box-shadow:0 6px 12px #0f172a14}.academy-search{margin-bottom:16px}.academy-faq-search{margin-top:4px;margin-bottom:0}.academy-search input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.08);background:var(--card-white);font-size:14px}.academy-search-results{display:flex;flex-direction:column;gap:12px}.academy-search-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;border:1px solid rgba(0,0,0,.06);background:var(--card-white);text-align:left;cursor:pointer}.academy-search-title{font-weight:600}.academy-search-type{font-size:12px;color:var(--text-muted)}.academy-md-heading{margin:8px 0 0}.academy-md-list{margin:0;padding-left:18px;color:var(--text-main)}.academy-md-spacer{height:8px}@media(max-width:768px){.academy-layout,.academy-home,.academy-screen{gap:18px}.academy-screen{padding:16px;border-radius:18px}.academy-section{padding:14px}.academy-start-card{flex-direction:column;align-items:flex-start;gap:10px;padding:16px}.academy-category-header{padding:16px;border-radius:16px}.academy-level-body{padding:4px 12px 14px}.academy-guide-card{padding:12px}}.academy-intro{display:flex;flex-direction:column;gap:6px}.academy-intro h2{margin:0;font-size:22px}.academy-intro p{margin:0;color:var(--text-muted)}.academy-category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.academy-category-card{display:flex;flex-direction:column;gap:12px;padding:16px 18px;border-radius:22px;border:none;background:#fff;text-align:left;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;min-height:170px}.academy-category-card:hover{transform:translateY(-2px);box-shadow:0 18px 30px #0f172a1f}.academy-category-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.academy-category-icon{width:56px;height:56px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:hsla(var(--category-hue),70%,88%,.9);color:hsl(var(--category-hue),35%,30%);flex-shrink:0}.academy-category-icon svg{width:24px;height:24px}.academy-category-meta{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;white-space:nowrap}.academy-meta-chip{padding:4px 8px;border-radius:999px;font-size:11px;font-weight:600;background:hsla(var(--category-hue),55%,85%,.7);color:hsl(var(--category-hue),30%,30%)}.academy-category-badge{padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:hsl(var(--category-hue),60%,70%);color:#1b1b1b}.academy-category-body h3{margin:0;font-size:18px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.academy-category-desc{margin:6px 0 0;color:var(--text-muted);font-size:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.academy-category-progress{margin-top:auto;display:flex;flex-direction:column;align-items:flex-start;gap:6px;font-size:12px;color:var(--text-muted)}.academy-progress-text{font-weight:600;color:var(--text-main)}.academy-progress-bar{flex:1;height:6px;border-radius:999px;background:#0f172a24;overflow:hidden;width:100%}.academy-progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent-main),rgba(15,23,42,.6));transition:width .3s ease}.academy-category-header{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;padding:20px;border-radius:20px;background:var(--card-softer);border:1px solid rgba(15,23,42,.08)}.academy-category-header h2{margin:0;font-size:22px}.academy-category-header p{margin:6px 0 0;color:var(--text-muted)}.academy-category-summary{display:flex;flex-direction:column;gap:10px;min-width:200px}.academy-category-count{font-weight:600;color:var(--text-main)}.academy-level{border-radius:18px;border:1px solid rgba(15,23,42,.08);background:var(--card-white);overflow:hidden}.academy-level-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:none;border:none;font-size:15px;font-weight:600;cursor:pointer;color:var(--text-main)}.academy-level-toggle svg{width:18px;height:18px}.academy-level-body{padding:4px 14px 16px}.academy-guide-list{display:flex;flex-direction:column;gap:12px}.academy-guide-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:#fff;text-align:left;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.academy-guide-card:hover{transform:translateY(-1px);box-shadow:0 12px 20px #0f172a14;border-color:#0f172a24}.academy-guide-left{display:flex;gap:14px;align-items:flex-start;flex:1}.academy-guide-icon{width:36px;height:36px;border-radius:12px;background:#0f172a14;display:inline-flex;align-items:center;justify-content:center;color:var(--accent-main);flex-shrink:0}.academy-guide-icon svg{width:18px;height:18px}.academy-guide-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.academy-guide-title-row h4{margin:0;font-size:16px}.academy-guide-desc{margin:6px 0 0;color:var(--text-muted);font-size:13px}.academy-guide-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.academy-guide-tag{font-size:11px;padding:4px 8px;border-radius:999px;background:#0f172a14;color:var(--text-main);text-transform:lowercase}.academy-guide-cta{font-weight:600;color:var(--accent-main);white-space:nowrap}.academy-guide-cta-button{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;border:1px solid rgba(15,23,42,.16);color:var(--text-main);font-size:12px;font-weight:600;background:transparent}.academy-guide-state{width:22px;height:22px;border-radius:999px;border:1px solid rgba(15,23,42,.2);display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);flex-shrink:0}.academy-guide-state.is-read{background:#26845d2e;border-color:#26845d66;color:#1f6b4a}.academy-guide-state svg{width:14px;height:14px}.academy-article{padding-bottom:90px}.academy-article-sticky{position:sticky;top:0;z-index:5;background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid rgba(15,23,42,.08);padding:14px 0 12px}.academy-article-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.academy-article-header h2{margin:0;font-size:22px}.academy-article-meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.academy-article-tag{padding:4px 10px;border-radius:999px;font-size:11px;background:#0f172a14;color:var(--text-main);text-transform:lowercase}.academy-article-progress{margin-top:12px;height:4px;background:#0f172a14;border-radius:999px;overflow:hidden}.academy-article-progress span{display:block;height:100%;background:var(--accent-main);transition:width .2s ease}.academy-article-layout{margin-top:20px;display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:28px;align-items:start}.academy-article-sidebar{position:sticky;top:120px;display:flex;flex-direction:column;gap:16px;align-self:start}.academy-article-main{min-width:0}.academy-article-body{max-width:720px;display:flex;flex-direction:column;gap:18px}.academy-article-mobile-toc{display:none;margin-bottom:16px}.academy-article-toc,.academy-article-mini-checklist{padding:14px 16px;border-radius:14px;border:1px solid rgba(15,23,42,.08);background:#fff}.academy-article-toc h4,.academy-article-mini-checklist h4{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.02em}.academy-article-toc ul,.academy-article-mini-checklist ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}.academy-toc-link{border:none;background:transparent;text-align:left;padding:4px 0;font-size:13px;color:var(--text-main);cursor:pointer}.academy-toc-link.is-active{color:var(--accent-main);font-weight:600}.academy-pill-btn{height:40px;padding:0 18px;border-radius:999px;border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.academy-pill-btn--primary{background:var(--accent-main);color:#fff;box-shadow:0 12px 20px #0f172a33}.academy-pill-btn--secondary{background:#0f172a0f;color:var(--text-main);border-color:#0f172a1f}.academy-pill-btn--ghost{background:transparent;color:var(--text-main);border-color:#0f172a2e}.academy-pill-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 18px #0f172a1f}.academy-pill-btn:focus-visible{outline:2px solid rgba(15,23,42,.4);outline-offset:2px}.academy-pill-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.academy-article-actionbar{position:sticky;bottom:16px;display:flex;gap:12px;flex-wrap:wrap;background:#ffffffeb;padding:12px;border-radius:16px;border:1px solid rgba(15,23,42,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);margin-top:28px}.summaryCard{border:1px solid #e9e9e9;background:#f6f6f6;border-radius:14px;padding:16px 18px}.summaryHeader{font-weight:700;font-size:14px;color:#111;margin-bottom:8px;letter-spacing:.2px}.summaryMeta{margin-bottom:10px}.summaryBadge{display:inline-block;font-size:12px;font-weight:600;color:#444;background:#ededed;border:1px solid #e3e3e3;padding:6px 10px;border-radius:999px}.summaryList{margin:0;padding-left:18px;color:#222;line-height:1.55;font-size:14px}.summaryList li{margin:6px 0}.summaryActions{margin-top:12px;display:flex;gap:10px}.summaryActionBtn{height:36px;padding:0 14px;border-radius:999px;border:1px solid #dcdcdc;background:#fff;font-weight:600;font-size:13px;color:#222;cursor:pointer}.summaryActionBtn:hover{background:#f1f1f1}.academy-article-section h3{margin:0 0 8px;scroll-margin-top:120px}.academy-article-section{scroll-margin-top:120px}.academy-article-subpoints,.academy-article-steps{margin:10px 0 0;padding-left:18px;color:var(--text-main);line-height:1.6}.academy-callout{padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.1);background:#0f172a0a}.academy-callout-title{display:flex;align-items:center;gap:8px;margin-bottom:6px}.academy-callout-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;background:#0f172a14;color:var(--text-main)}.academy-callout-icon{color:var(--text-muted)}.academy-callout--tip{border-color:#26845d4d;background:#e2f4ec99}.academy-callout--pozor{border-color:#d87d2059;background:#ffedd5b3}.academy-callout--fail{border-color:#c9404059;background:#fde2e2b3}.academy-callout--info{border-color:#3b82f647;background:#dbeafeb3}.academy-article-checklist,.academy-article-mini-checklist{font-size:13px}.academy-article-checklist h4{margin:0 0 8px;font-size:14px}.academy-article-checklist ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.academy-checklist-item{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text-main)}.academy-checklist-item input{accent-color:var(--accent-main);margin-top:2px}.academy-steps-block{padding:14px 16px;border-radius:14px;border:1px solid rgba(15,23,42,.08);background:#0f172a0a}.academy-steps-block h4{margin:0 0 6px;font-size:15px}.academy-steps-block ol{margin:8px 0 0;padding-left:18px}.academy-do-dont{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding:14px 16px;border-radius:14px;border:1px solid rgba(15,23,42,.08);background:#fff}.academy-do-dont h4{margin:0 0 8px;font-size:14px}.academy-do-dont ul{margin:0;padding-left:18px}.academy-faq-block{display:flex;flex-direction:column;gap:10px}.academy-faq-row{text-align:left;border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:12px;padding:12px 14px;font-size:14px;display:flex;flex-direction:column;gap:8px}.academy-faq-row span:first-child{font-weight:600}.academy-faq-row .academy-faq-toggle{align-self:flex-end;color:var(--text-muted)}.academy-faq-answer{color:var(--text-muted);line-height:1.6}.academy-quick-actions{display:flex;flex-wrap:wrap;gap:10px}@media(max-width:768px){.academy-category-card{flex-direction:column}.academy-category-header{flex-direction:column;position:relative;padding:12px;gap:12px}.academy-category-summary{width:100%;gap:8px}.academy-category-summary .chip-btn.primary{padding:6px 12px}.academy-category-header>div:first-child{padding-right:48px}.academy-category-count{position:absolute;top:14px;right:16px}.academy-guide-card{flex-direction:column;align-items:flex-start}.academy-guide-title-row{width:100%}.academy-category-meta{flex-wrap:wrap}.academy-article-layout{grid-template-columns:1fr}.academy-article-sidebar{display:none}.academy-article-mobile-toc{display:block}.academy-article-actionbar{position:static}}.recipe-detail-overlay{position:fixed;inset:0;background:#30201459;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:40px 16px;z-index:1000}body.recipe-detail-open{overflow:hidden}.recipe-page{width:min(1100px,100%);margin:0 auto 32px;background:#fff;border-radius:28px;padding:40px 48px 48px;box-shadow:0 30px 70px #00000029;position:relative;font-family:Sora,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#3b2a1f}.recipe-close{position:absolute;top:24px;right:24px;width:36px;height:36px;border-radius:50%;border:none;background:#f7e8d8;box-shadow:0 6px 20px #0000001f;font-size:18px;cursor:pointer;color:#4a3426;z-index:3}.recipe-hero-shell{position:relative;margin-bottom:24px;border-radius:18px;overflow:hidden}.recipe-hero{width:100%;height:260px;display:block;object-fit:cover}.recipe-hero-placeholder{background:#f4e5d5;min-height:260px;display:flex;align-items:center;justify-content:center;color:#bbb}.recipe-hero-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:24px 24px 26px;background:linear-gradient(to top,#0000008c,#00000026 55%,#0000)}.recipe-title-block{display:flex;flex-direction:column;gap:12px;width:100%}.recipe-title{font-size:clamp(26px,4vw,38px);font-weight:600;margin:0;padding-right:56px;line-height:1.15;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.55)}.recipe-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.recipe-custom-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0 6px}.recipe-custom-actions__label{display:inline-flex;align-items:center;padding:6px 12px;background:#f5efe8;color:#4b3526;border-radius:14px;text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:700}.recipe-custom-actions__right{display:inline-flex;align-items:center;gap:8px}.portion-mode-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:999px;background:#ffffff38;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);width:fit-content}.portion-mode-toggle__option{border:none;background:transparent;color:#fff;font-weight:600;font-size:13px;padding:6px 14px;border-radius:999px;cursor:pointer;opacity:.85;transition:background .2s ease,color .2s ease,opacity .2s ease}.portion-mode-toggle__option.is-active{background:#fff;color:#4a3426;opacity:1;box-shadow:0 6px 16px #0000002e}.portion-mode-toggle__option:focus-visible{outline:2px solid #f4a261;outline-offset:2px}.recipe-section-toggle{display:inline-flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px;border-radius:999px;background:#fff;box-shadow:0 10px 22px #0000001f;width:fit-content}.recipe-section-toggle__option{border:none;background:transparent;color:#4a3426;font-weight:600;font-size:14px;padding:8px 16px;border-radius:999px;cursor:pointer;opacity:.7;transition:background .2s ease,color .2s ease,opacity .2s ease}.recipe-section-toggle__option.is-active{background:#4a3426;color:#fff;opacity:1}.recipe-section-toggle__option:focus-visible{outline:2px solid #f4a261;outline-offset:2px}.recipe-meta-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.recipe-cook-actions{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 22px}.meta-pill{padding:6px 14px;background:#f5efe8;border-radius:999px;box-shadow:0 2px 6px #0000000f;font-size:14px;display:inline-flex;align-items:center;gap:6px;color:#4b3526}.meta-pill-icon{font-size:14px}.recipe-tags-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.tag-pill{padding:4px 12px;font-size:13px;border-radius:999px;background:#f5efe8;color:#5a4332;font-weight:400;white-space:nowrap;box-shadow:0 1px 3px #0000000a;border:none}.tag-pill[role=button]{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.tag-pill[role=button]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3640a338}.tag-pill[role=button]:focus-visible{outline:2px solid #6e78ff;outline-offset:2px}.recipe-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:32px;margin-top:32px;align-items:start}.recipe-left,.recipe-panel{display:flex;flex-direction:column;gap:24px}.recipe-panel[hidden]{display:none}.recipe-section-heading{margin:0;font-size:18px;font-weight:600;color:#3b2a1f}.recipe-description{font-size:15px;line-height:1.6;color:#3f2d21;margin:-2px 0 18px}.howto-title{font-size:22px;font-weight:600;margin:-18px 0 0;color:#3b2a1f}.howto-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.howto-steps li{display:flex;gap:12px;align-items:flex-start;background:#fff;border-radius:16px;padding:18px 20px;box-shadow:0 6px 18px #0000000d}.step-number{width:32px;height:32px;border-radius:50%;border:none;font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;color:#4a3426;background:#f6e7d3;flex-shrink:0}.step-text{font-size:15px;line-height:1.6;color:#3f2d21}.info-card{margin-top:0;padding:14px 16px;border-radius:14px;background:#f5efe8;color:#3f2d21;font-size:14px}.info-card h3{margin-top:0;margin-bottom:6px;font-size:15px;font-weight:600;color:#3b2a1f}.info-card p{margin:0;font-size:15px;line-height:1.6;color:#3b3b3b}.recipe-faq-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.recipe-faq-item{padding:6px 0;border-bottom:1px solid rgba(0,0,0,.05)}.recipe-faq-item:last-child{border-bottom:none}.recipe-faq-question{margin:0;font-weight:600;color:#2f200f}.recipe-faq-answer{margin:4px 0 0;color:#1e160fcc;line-height:1.5}.recipe-right{display:flex;flex-direction:column;gap:20px}.ingredients-box{background:#f5efe8;padding:24px;border-radius:18px;box-shadow:0 6px 20px #0000000f;border:none}.ingredients-box h3{margin-top:0;margin-bottom:12px;font-size:18px;font-weight:600;color:#3b2a1f}.ingredients-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.ingredients-header--batch{flex-direction:column;align-items:center;text-align:center}.ingredients-box ul{margin:16px 0 0 18px;padding:0;color:#4a321c;line-height:1.6;font-size:15px}.ingredients-box ul li{color:#3f2d21;margin-bottom:4px}.ingredients-table-wrap{width:100%;margin-top:16px;overflow:hidden;border-radius:16px;border:1px solid rgba(234,223,206,.55);background:#fdf8f2}.ingredients-table{width:100%;border-collapse:collapse;font-size:15px;color:#3f2d21;background:#fdf8f2}.ingredients-table td{padding:8px 12px;border-bottom:1px solid rgba(234,223,206,.55);line-height:1.35}.ingredients-table tr:last-child td{border-bottom:none}.portion-select{border:none;background:transparent;font-size:15px;font-weight:600;color:#5a4332;appearance:none;padding-right:8px;cursor:pointer}.portion-select:focus{outline:none}.portion-select:focus-visible{outline:2px solid #f4a261;outline-offset:2px;border-radius:6px}.portion-counter{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;border-radius:12px;background:#ffffffe6;box-shadow:inset 0 0 0 1px #0000000f;margin-left:auto}.portion-counter__label{font-size:14px;font-weight:600;color:#3b2a1f}.portion-counter__actions{display:inline-flex;align-items:center;gap:6px}.portion-counter__btn{width:32px;height:32px;border-radius:8px;border:none;background:#f5efe8;color:#4a3426;font-size:18px;font-weight:600;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,transform .15s ease}.portion-counter__btn:hover:not(:disabled){background:#f0e0ce;box-shadow:0 4px 10px #00000014;transform:translateY(-1px)}.portion-counter__btn:active:not(:disabled){transform:translateY(0);box-shadow:none}.portion-counter__btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.batch-portion-panel{display:flex;flex-direction:column;gap:4px;padding:8px 12px;border-radius:12px;background:#ffffffe6;box-shadow:inset 0 0 0 1px #0000000f;margin-left:auto;min-width:220px}.batch-portion-row{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}.ingredients-header--batch .batch-portion-panel{margin-left:0;align-items:center}.ingredients-header--batch .batch-portion-row{justify-content:center;text-align:center}.ingredients-header--batch .batch-portion-row--controls{order:2;flex-wrap:wrap;justify-content:center}.ingredients-header--batch .batch-portion-summary{order:1;text-align:center}.batch-portion-label{font-size:14px;font-weight:600;color:#3b2a1f}.batch-portion-controls{display:inline-flex;align-items:center;gap:8px}.batch-portion-value{font-weight:600;color:#4a3426;min-width:80px;text-align:center}.batch-portion-summary{font-size:13px;font-weight:600;color:#6a4c37}.batch-portion-summary--inline{font-size:14px;margin-left:6px;white-space:nowrap}.batch-portion-row--summary{justify-content:flex-end}.batch-portion-row--controls{flex-wrap:wrap}.portion-note{font-size:13px;color:#7a614a;margin:12px 0 0}.recipe-right-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;padding:0 4px}.empty-text{font-size:15px;color:#8a8a8a;margin:0}@media(max-width:900px){.recipe-page{padding:32px 28px 40px}}@media(max-width:900px){.recipe-layout{grid-template-columns:1fr;gap:16px}.recipe-right{margin-top:0}.recipe-section-toggle{margin-top:-28px}.ingredients-table{font-size:13.5px}.ingredients-table td{padding:6px 10px;line-height:1.3}}@media(min-width:901px){.ingredients-table{font-size:14px}.ingredients-table td{padding:7px 12px;line-height:1.35}}@media(max-width:560px){.recipe-page{padding:28px 20px 36px}.recipe-close{top:16px;right:16px}.recipe-section-toggle{flex-wrap:nowrap;gap:6px;padding:6px;width:100%;justify-content:space-between}.recipe-section-toggle__option{font-size:13px;padding:6px 10px;white-space:nowrap}.ingredients-box{padding:20px}}.food-card{width:min(520px,96vw);margin:40px auto;background:#fff;border-radius:28px;box-shadow:0 22px 60px #00000024;overflow:hidden;position:relative;color:#2d2219}.food-hero{position:relative;height:220px;background:linear-gradient(135deg,#f5efe8,#e4d6c5);overflow:hidden}.food-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.04);filter:saturate(1.02)}.food-hero-overlay{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:flex-start;padding:18px}.food-badge{background:#000000b3;color:#fff;padding:8px 14px;border-radius:14px;font-size:13px;letter-spacing:.08em;text-transform:uppercase}.food-kcal-pill{background:#000000d1;color:#fff;padding:8px 14px;border-radius:16px;font-weight:700;letter-spacing:.05em;font-size:13px;position:absolute;right:16px;bottom:16px}.food-body{padding:22px 22px 18px;display:flex;flex-direction:column;gap:8px}.food-title{margin:0;font-size:24px;line-height:1.3;color:#2f231a}.food-meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.food-chip{padding:8px 12px;background:#f1ebe3;border-radius:999px;font-size:13px;color:#4a382a;font-weight:600}.food-chip.subtle{background:#f7f2ea;color:#34281dcc;font-weight:500}.food-macros{margin:4px 0 0;font-size:15px;color:#514132;letter-spacing:.01em}.food-note{margin:4px 0 0;color:#322218cc;line-height:1.5}.food-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.food-chip-row.spaced{margin-top:4px}.food-detail-actions{display:flex;justify-content:flex-end;margin-top:12px}.info-hint{position:relative;display:inline-flex;align-items:center;margin-left:6px;flex-shrink:0;vertical-align:middle}.info-hint-button{width:18px;height:18px;border-radius:999px;border:1px solid rgba(15,23,42,.25);background:#fff;color:#0f172acc;font-size:11px;font-weight:600;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease;vertical-align:middle}.info-hint-button:hover,.info-hint-button:focus-visible{background:var(--accent-peach, #ffe9dd);border-color:var(--accent-peach, #ffe9dd);color:var(--text-main, #0f172a)}.info-hint-button:focus-visible{outline:none;box-shadow:0 0 0 2px #ff896e66}.info-hint-tooltip{position:absolute;z-index:40;min-width:200px;max-width:260px;padding:12px 14px;border-radius:14px;background:#fff;box-shadow:0 12px 32px #0f172a2e;color:var(--text-main, #0f172a);font-size:13px;line-height:1.35}.info-hint-tooltip:after{content:"";position:absolute;width:10px;height:10px;background:#fff;transform:rotate(45deg);box-shadow:0 12px 32px #0f172a2e}.info-hint-tooltip-top{bottom:calc(100% + 12px);left:50%;transform:translate(-50%)}.info-hint-tooltip-top:after{top:100%;left:50%;transform:translate(-50%,-50%) rotate(45deg)}.info-hint-tooltip-bottom{top:calc(100% + 12px);left:50%;transform:translate(-50%)}.info-hint-tooltip-bottom:after{bottom:100%;left:50%;transform:translate(-50%,50%) rotate(45deg)}.info-hint-tooltip-left{right:calc(100% + 12px);top:50%;transform:translateY(-50%)}.info-hint-tooltip-left:after{left:100%;top:50%;transform:translate(-50%,-50%) rotate(45deg)}.info-hint-tooltip-right{left:calc(100% + 12px);top:50%;transform:translateY(-50%)}.info-hint-tooltip-right:after{right:100%;top:50%;transform:translate(50%,-50%) rotate(45deg)}.info-hint-tooltip-title{font-weight:600;margin:0 0 6px;font-size:13px}.info-hint-tooltip-text{margin:0;font-size:13px;color:var(--text-subtle, #475569)}.info-hint-modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;justify-content:center;align-items:flex-end;padding:24px 16px 32px;z-index:2000}.info-hint-modal{width:100%;max-width:520px;background:#fff;border-radius:28px 28px 12px 12px;padding:24px 22px 28px;box-shadow:0 -8px 32px #0f172a2e}.info-hint-modal-title{margin:0 0 10px;font-size:17px;font-weight:600;color:var(--text-main, #0f172a)}.info-hint-modal-text{margin:0;font-size:14px;line-height:1.45;color:var(--text-subtle, #475569)}.info-hint-close-btn{width:100%;margin-top:18px;border:none;border-radius:18px;background:var(--accent-peach, #ffb89f);color:#0f172a;font-weight:600;font-size:14px;padding:12px 16px;cursor:pointer;box-shadow:0 6px 20px #ff896e66;transition:filter .15s ease,transform .15s ease}.info-hint-close-btn:hover{filter:brightness(.97)}.info-hint-close-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #0f172a33}.weekly-plans{width:100%;max-width:1200px;margin:0 auto;padding:0 0 40px}.weekly-plans-grid{display:flex;flex-direction:column;gap:20px;margin-top:24px}.weekly-group-chips{margin-top:30px;margin-bottom:-40px;display:flex;gap:10px;flex-wrap:wrap}.weekly-macro-summary{margin-top:0;margin-bottom:0}.weekly-week-macro-row{margin-top:6px;margin-bottom:2%;display:flex;gap:12px;align-items:flex-start}.weekly-week-macro-row .weekly-week-picker{margin-top:50px;width:50%;min-width:320px;align-self:flex-start;border-radius:18px;background:#fff;box-shadow:0 10px 24px #d3d5d833}.weekly-week-macro-row .weekly-week-picker.weekly-week-picker--valentine{background:linear-gradient(140deg,#fff6f8,#fff 55%);box-shadow:0 14px 26px #ea96b42e}.weekly-week-highlight{margin:14px 16px 2px;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#ea96b42e;color:#7b3146;font-size:12px;font-weight:600;letter-spacing:.2px}.weekly-week-macro-row .weekly-macro-summary{width:50%;min-width:320px;display:flex}.weekly-week-macro-row .weekly-day-summary.day-summary{width:100%}.weekly-day-summary.day-summary{max-width:none;padding:12px 16px 0;border-radius:20px;gap:6px}.weekly-day-summary .day-summary-title{font-size:18px}.weekly-day-summary.day-summary-mobile{padding:7px 10px;border-radius:20px;gap:6px}.weekly-day-summary.day-summary-mobile .day-summary-title{font-size:14px}.weekly-day-summary.day-summary-mobile .day-kcal-plain,.weekly-day-summary.day-summary-mobile .day-macro-inline{font-size:15px}.weekly-day-summary.day-summary-mobile .day-macro-item{padding:6px 10px}.weekly-day-summary .day-kpi-row{gap:8px}.weekly-day-summary .day-kpi{padding:8px 10px;border-radius:16px;font-size:12px;background:var(--status-ok-bg);box-shadow:none}.weekly-day-summary .day-kpi.kpi-ok,.weekly-day-summary .day-kpi.kpi-warning,.weekly-day-summary .day-kpi.kpi-critical{background:var(--status-ok-bg)}.weekly-day-summary .day-kpi-label{font-size:9px}.weekly-day-summary .day-summary-sub{font-size:11px}@media(max-width:860px){.weekly-group-chips{margin-top:6px}.weekly-week-macro-row{flex-direction:column}.weekly-week-macro-row .weekly-week-picker,.weekly-week-macro-row .weekly-macro-summary{width:100%;min-width:0}}.weekly-group-chip{border:1px solid #EEEDEB;background:#eeedeb;color:#5b4637;border-radius:999px;padding:6px 14px;font-size:13px;cursor:pointer;position:relative;transition:background .2s ease,color .2s ease,border-color .2s ease}.weekly-group-chip--disabled{cursor:default;opacity:.85}.weekly-group-chip--disabled:hover:after,.weekly-group-chip--disabled:focus-visible:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);background:#3f2e23f2;color:#fff;padding:8px 10px;border-radius:12px;font-size:12px;line-height:1.25;white-space:nowrap;z-index:10;box-shadow:0 10px 24px #0f172a33}.weekly-group-chip--disabled:hover:before,.weekly-group-chip--disabled:focus-visible:before{content:"";position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%);border-width:0 6px 6px;border-style:solid;border-color:transparent transparent rgba(63,46,35,.95);z-index:11}.weekly-group-chip--power{background:#f1f0ef;border-color:#e0dcda;color:#7a6a5f}.weekly-group-chip--power:hover{border-color:#cfc7c3}.weekly-group-chip--active{background:#3f2e23;color:#fff;border-color:#3f2e23;box-shadow:0 4px 12px #3f2e2340}.weekly-group-chip--power.weekly-group-chip--active{background:#5f5f5f;border-color:#5f5f5f;box-shadow:0 4px 12px #28282840}.weekly-plan-empty{margin-top:18px;padding:14px 16px;border-radius:18px;background:#eeedeb;color:#7a6757;font-size:14px;border:1px dashed #EEEDEB}.weekly-plan-detail{background:#f8f8f8;border-radius:28px;padding:22px 22px 26px;box-shadow:0 12px 32px #3f2e2314;display:flex;flex-direction:column;gap:20px;position:relative}.weekly-plans--valentine .weekly-plan-detail{background:#fde4ec!important}.weekly-plan-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.weekly-plan-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;position:absolute;top:18px;right:18px}.weekly-plan-lock-wrap{display:inline-flex;align-items:center}.weekly-plan-detail-kicker{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#a58a76;margin:0 0 6px}.weekly-plan-detail-title{margin:0;font-size:20px;font-weight:600;color:#3f2e23}.weekly-plan-detail-sub{margin:4px 0 0;font-size:14px;color:#7a6757;white-space:normal;line-height:1.5}.weekly-plan-detail-toggle{margin-top:6px;padding:0;border:none;background:none;color:#5b4637;font-size:13px;font-weight:600;cursor:pointer}.weekly-plan-detail-toggle:hover,.weekly-plan-detail-toggle:focus-visible{text-decoration:underline}@media(max-width:720px){.weekly-plan-detail .portion-inline-row{align-items:center;gap:8px}.weekly-plan-detail .card-macros-inline{margin-left:auto;font-size:14px;color:var(--text-muted);white-space:nowrap}.weekly-plan-detail .card-content{padding-bottom:8px;gap:10px}.weekly-plan-detail .card-bottom-actions{margin-top:4px}.weekly-plan-detail .card-bottom{align-items:center}.weekly-plan-detail-sub--clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.weekly-plan-actions{position:static;margin-left:auto;width:100%;justify-content:flex-start}}.weekly-plan-lock-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#eeedeb;color:#5b4637;font-size:13px;font-weight:600}.weekly-plan-tip-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#eeedeb;color:#5b4637;font-size:13px;font-weight:600;text-decoration:none;border:1px solid transparent;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.weekly-plan-tip-btn:hover,.weekly-plan-tip-btn:focus-visible{background:#e4e0dd;border-color:#d5cfcb;box-shadow:0 6px 14px #3f2e231f}.weekly-plan-tip-btn:focus-visible{outline:2px solid #a25b2a;outline-offset:2px}.weekly-plan-edit-btn{border:none;background:#3f2e23;color:#fff;border-radius:999px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,transform .2s ease}.weekly-plan-edit-btn:hover,.weekly-plan-edit-btn:focus-visible{background:#2c2017;box-shadow:0 6px 14px #3f2e2340}.weekly-plan-edit-btn:focus-visible{outline:2px solid #a25b2a;outline-offset:2px}.weekly-plan-edit-btn:active{transform:translateY(1px)}.weekly-plan-detail .meals{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.weekly-plans--valentine .weekly-plan-detail .meals .card{background:#fff7f9;box-shadow:0 6px 16px #e896b22e}.weekly-plan-prep-note{background:#eeedeb;border-radius:22px;padding:18px 20px;border:1px solid #EEEDEB;color:#4c3a30;box-shadow:inset 0 1px #fff6}.weekly-plan-prep-label{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:#a25b2a;font-weight:600}.weekly-plan-prep-text{margin:8px 0 0;font-size:14px;line-height:1.5;color:inherit;white-space:pre-line}.weekly-plan-card{background:#fff;border-radius:24px;padding:18px 18px 20px;box-shadow:0 10px 30px #0f172a14;display:flex;flex-direction:column;gap:12px}.weekly-plan-card-top{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:flex-start}.weekly-plan-card-info{flex:1;min-width:220px;display:flex;flex-direction:column;gap:6px}.weekly-week-picker{margin-top:12px;margin-bottom:0;margin-left:auto;background:#e9e8e8;border-radius:24px;padding:10px 14px;display:flex;flex-direction:column;gap:6px;width:fit-content}.week-picker-control{display:flex;align-items:center;gap:8px}.week-nav-btn{width:32px;height:32px;border-radius:999px;border:none;background:#eeedeb;color:#4b3729;font-size:18px;cursor:pointer;transition:background .2s ease,transform .2s ease}.week-nav-btn:disabled{opacity:.4;cursor:default}.week-nav-btn:not(:disabled):hover{background:#eeedeb;transform:translateY(-1px)}.week-picker-select-wrap{min-width:220px;background:#fff;border-radius:999px;padding:4px 12px;box-shadow:inset 0 0 0 1px #0000000f}.week-picker-select-wrap select{width:100%;border:none;background:transparent;font-size:13px;color:#3f2e23;appearance:none;padding-right:24px;background-image:url("data:image/svg+xml,%3Csvg width='12' height='7' viewBox='0 0 12 7' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235b4637' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.week-select-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9c8f85}.weekly-plan-title{font-size:20px;font-weight:600;margin:0;color:#3f2e23}.weekly-plan-subtitle{font-size:14px;margin:0;color:#7a6757}.weekly-plan-badge{align-self:flex-start;font-size:11px;text-transform:uppercase;letter-spacing:.08em;padding:4px 10px;border-radius:999px;background:#eeedeb;color:#a25b2a}.weekly-plan-meta{display:flex;flex-wrap:wrap;gap:6px}.weekly-plan-chip{font-size:12px;padding:4px 10px;border-radius:999px;background:#eeedeb;color:#5b4637}.weekly-plan-chip.soft{background:#eeedeb;color:#7a6757}.weekly-plan-footer{margin-top:6px;display:flex;gap:8px}.weekly-plan-primary{flex:1;border:none;border-radius:999px;padding:8px 14px;font-size:14px;font-weight:500;background:#3f2e23;color:#fff;cursor:pointer}.weekly-plan-secondary{border-radius:999px;padding:8px 12px;font-size:13px;border:none;background:#eeedeb;color:#3f2e23;cursor:pointer}.weekly-plan-days{margin-top:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.weekly-plan-day{background:#fff;border-radius:18px;padding:12px 14px;box-shadow:0 8px 20px #0f172a0f}.weekly-plan-day-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.weekly-plan-day-label{font-size:14px;font-weight:600;color:#3f2e23}.weekly-plan-day-note{font-size:11px;color:#9c8f85}.weekly-plan-day-meals{list-style:none;padding:0;margin:0;font-size:13px;color:#6d5a4a}.weekly-day-switch{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px}.weekly-day-btn{border:none;border-radius:999px;padding:6px 10px;font-size:12px;background:#eeedeb;color:#6d5a4a;cursor:pointer;transition:background .2s ease,color .2s ease}.weekly-day-btn.active{background:#3f2e23;color:#fff;box-shadow:0 4px 10px #3f2e2340}.weekly-day-btn:disabled{opacity:.35;cursor:default}:root{--zdk-dark: #3a3a3a;--zdk-dark-hover: #2e2e2e;--zdk-dark-active: #242424;--zdk-peach: #f4d7c8;--zdk-peach-hover: #f1c8b2;--zdk-peach-active: #e8b59a;--zdk-text-on-peach: #262626;--zdk-bg-soft: #f7f5f2;--zdk-border-soft: #e5ddd6}.challenge-shell{margin-top:0;width:100%;max-width:1250px;margin-left:auto;margin-right:auto;padding:32px 0;border-radius:32px;background:transparent;color:var(--text-main);box-shadow:none;border:none}.challenge-shell-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap}.challenge-title{margin:0;font-size:clamp(26px,4vw,34px);font-weight:700;letter-spacing:-.01em}.challenge-subtitle{margin:8px 0 0;color:var(--text-muted);max-width:520px;line-height:1.5}.challenge-tabs{display:inline-flex;gap:8px;background:var(--card-softer);padding:6px;border-radius:999px}.challenge-tab{border:none;border-radius:999px;padding:10px 18px;font-size:14px;font-weight:600;color:var(--text-muted);background:transparent;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.challenge-tab.is-active{background:linear-gradient(120deg,var(--accent-peach),var(--accent-peach-hover));color:var(--text-on-peach);box-shadow:0 8px 20px #f4d7c880}.challenge-section{margin-top:32px;padding:24px;border-radius:28px;background:var(--card-white);border:1px solid var(--border-soft);box-shadow:0 12px 30px #0f172a0f}.challenge-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:24px}.challenge-top-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.challenge-top-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.challenge-top-reward-text{font-size:14px;font-weight:600;color:var(--text-muted);text-align:right;line-height:1.4}.challenge-day-label{margin:0 0 6px;font-size:16px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-subtle)}.challenge-day-tagline{margin:0 0 10px;color:var(--text-muted);font-size:14px;font-weight:600;line-height:1.4}.challenge-meter{position:relative;height:12px;border-radius:999px;background:var(--card-softer);overflow:hidden}.challenge-meter.large{height:16px}.challenge-meter-fill{position:absolute;top:0;left:0;bottom:0;background:linear-gradient(120deg,var(--accent-peach),var(--accent-peach-active));border-radius:999px}.challenge-day-meta{margin-top:8px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:var(--text-muted);font-size:13px;font-weight:600}.challenge-day-mode{font-size:13px;font-weight:600;color:var(--text-muted)}.challenge-streak-pill{padding:8px 16px;border-radius:999px;background:#f4d7c840;color:var(--accent-main);font-weight:600}.daysTimeline{margin-top:10px;position:relative;overflow-x:auto;overflow-y:visible;padding:22px 10px 10px;-webkit-overflow-scrolling:touch}.daysTimeline::-webkit-scrollbar{height:0}.daysTimeline{scrollbar-width:none}.daysTrack{position:relative;display:flex;flex-wrap:nowrap;gap:10px;align-items:center;padding:10px 6px;--progress: 0%}.daysTrack:before,.daysTrack:after{content:"";position:absolute;left:0;right:0;top:50%;height:2px;transform:translateY(-50%);border-radius:999px;z-index:0}.daysTrack:before{background:#0f172a14;opacity:.25}.daysTrack:after{right:auto;width:var(--progress);background:#f4d7c8e6;opacity:.6}.dayDot{width:14px;height:14px;min-width:14px;min-height:14px;border-radius:999px;padding:0;line-height:1;box-sizing:border-box;position:relative;z-index:1;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(15,23,42,.24);background:var(--card-white);appearance:none;-webkit-user-select:none;user-select:none;cursor:default;transition:border-color .15s ease,box-shadow .15s ease,opacity .15s ease,background .15s ease}.dayDot.is-milestone{width:18px;height:18px;min-width:18px;min-height:18px;border-width:2px}.dayDot.is-future{opacity:.55}.dayDot.is-today,.dayDot.is-active{border-color:var(--accent-main);box-shadow:0 0 0 3px #f4d7c86b;opacity:1}.dayDot.is-done{background:#f4d7c8a6;border-color:#f4d7c8fa;opacity:1;animation:dayDotPop .15s ease-out}.dayDot.is-done:after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;font-size:11px;line-height:1;font-weight:900;color:var(--accent-main)}.dayDot.is-milestone.is-done:after{font-size:12px}.dayLabel{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:12px;padding:2px 6px;border-radius:999px;border:1px solid rgba(244,215,200,.7);background:#f4d7c840;color:var(--text-muted);font-weight:700;white-space:nowrap;pointer-events:none}.dayDot:focus-visible{outline:2px solid var(--accent-peach);outline-offset:3px}@keyframes dayDotPop{0%{transform:scale(1)}60%{transform:scale(1.06)}to{transform:scale(1)}}.dailyStatusRow{margin:16px 0 14px;display:flex;flex-wrap:nowrap;align-items:center;gap:10px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.dailyStatusRow::-webkit-scrollbar{height:0}.dailyStatusItem{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--border-soft);background:var(--card-white);min-width:0;white-space:nowrap}.dailyStatusItem.pending{opacity:.55;background:var(--card-softer)}.dailyStatusItem.done{opacity:1;border-color:#22c55e80;background:#22c55e1f}.dailyStatusIcon{width:14px;height:14px;border-radius:999px;border:1.5px solid rgba(15,23,42,.22);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;background:transparent}.dailyStatusItem.done .dailyStatusIcon{border-color:#22c55ea6;background:#22c55e2e}.dailyStatusItem.done .dailyStatusIcon:after{content:"✓";font-size:10px;line-height:1;font-weight:900;color:#15803d}.dailyStatusLabel{font-size:12px;font-weight:600;color:var(--text-main)}.challenge-chip{border:1px solid var(--border-soft);color:var(--text-main);background:transparent}.chip-btn.success{background:#22c55e24;color:#15803d;border-color:#22c55e73;box-shadow:0 3px 10px #22c55e24}.chip-btn.success:not(.secondary):not(.danger):hover{background:#22c55e2e;box-shadow:0 4px 12px #22c55e2e}.chip-btn.success:not(.secondary):not(.danger):active{background:#22c55e38}.chip-btn.pastel{background:#f5efe8;color:var(--text-main);border-color:#0f172a1f;box-shadow:0 3px 10px #0f172a14}.chip-btn.pastel:not(.secondary):not(.danger):hover{background:#efe7df;box-shadow:0 4px 12px #0f172a1a}.chip-btn.pastel:not(.secondary):not(.danger):active{background:#e7ded6}.chip-btn-ghost.is-muted{background:#0f172a0f;border-color:#0f172a1f;color:var(--text-muted)}.chip-btn-ghost.is-muted:hover{background:#0f172a17;border-color:#0f172a29;color:var(--text-main)}.chip-btn-ghost.is-muted:active{background:#0f172a1f}.challenge-day-picker{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-muted)}.challenge-day-picker select{border-radius:12px;border:1px solid var(--border-soft);background:var(--card-white);color:var(--text-main);padding:6px 10px}.challenge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.challenge-pillar-status{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin:20px 0}.challenge-pillar-badge{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:16px;border:1px solid var(--border-soft);background:var(--card-white);box-shadow:0 4px 12px #0f172a0a}.challenge-pillar-badge.is-done{border-color:#22c55e66;background:#22c55e1f}.challenge-pillar-badge p{margin:0;font-size:14px;font-weight:600}.challenge-pillar-badge small{display:block;color:var(--text-muted);font-size:12px}.challenge-pillar-badge.is-done small{color:#15803d}.challenge-pillar-dot{width:36px;height:36px;border-radius:12px;background:var(--card-softer);color:transparent;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.challenge-pillar-badge.is-done .challenge-pillar-dot{background:#22c55e2e;color:#15803d}.challenge-pillar-badge.is-done .challenge-pillar-dot:after{content:"✓"}.challenge-day-banner{margin-bottom:20px;padding:18px;border-radius:20px;border:1px solid rgba(34,197,94,.25);background:#22c55e14;color:var(--text-main)}.challenge-day-banner.is-compact{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px}.challenge-day-banner-compact-text{font-weight:700;line-height:1.3}.challenge-day-banner.is-reward{border-color:#f4d7c8e6;background:#f4d7c840;box-shadow:0 12px 30px #f4d7c859}.challenge-day-banner.is-muted{border-color:#3b82f659;background:#3b82f614}.challenge-day-banner-title{font-weight:700;margin-bottom:8px}.challenge-day-banner-note{margin:0;color:var(--text-muted);font-size:13px}.challenge-day-banner-pill-row{display:flex;flex-wrap:wrap;gap:8px}.challenge-day-banner-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:var(--card-white);border:1px solid rgba(34,197,94,.25);font-size:13px;color:var(--text-main)}.challenge-day-banner-check{width:18px;height:18px;border-radius:50%;background:#22c55e26;color:#15803d;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.challenge-card{padding:20px;border-radius:20px;background:var(--card-white);border:1px solid var(--border-soft);display:flex;flex-direction:column;gap:14px;box-shadow:0 6px 16px #0f172a0a}.challenge-card.is-pending{border-color:#3b82f680;box-shadow:0 14px 30px #3b82f626}.challenge-card.is-compact{padding-bottom:16px}.challenge-card-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.challenge-card-header-right{display:flex;align-items:center;gap:8px}.challenge-card-title-row{display:flex;align-items:center;gap:6px}.challenge-card-check{width:18px;height:18px;border-radius:50%;background:#22c55e1f;color:#15803d;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.challenge-auto-pill{margin-left:4px;padding:2px 8px;border-radius:999px;background:#3b82f629;color:#1d4ed8;font-size:11px;font-weight:600}.challenge-info-btn{border:1px solid var(--border-soft);background:var(--card-softer);color:var(--text-muted);border-radius:50%;width:24px;height:24px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.challenge-info-btn:focus-visible{outline:2px solid var(--accent-peach);outline-offset:2px}.challenge-card-title{margin:0;font-size:16px;font-weight:600;color:var(--text-main)}.challenge-link-btn{border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:600;padding:6px 10px;border-radius:12px;cursor:pointer;transition:background .2s ease,color .2s ease}.challenge-link-btn:hover{background:#0f172a0f;color:var(--text-main)}.challenge-link-btn:focus-visible{outline:2px solid var(--accent-peach);outline-offset:2px}.challenge-link-btn-danger{color:var(--status-critical-text)}.challenge-link-btn-danger:hover{background:#ef44441f;color:var(--status-critical-text)}.challenge-link-btn-success{color:#15803d;padding:0;border-radius:0}.challenge-link-btn.challenge-link-btn-success:hover{background:transparent;color:#166534;text-decoration:underline}.challenge-link-btn.challenge-link-btn-success:active{background:transparent;color:#14532d}.challenge-card-subtitle{margin:2px 0 0;color:var(--text-muted);font-size:14px}.challenge-card-subtitle-nowrap{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.challenge-card-meta{margin:4px 0 0;color:var(--text-subtle);font-size:13px}.challenge-card-body{display:flex;flex-direction:column;gap:12px;flex:1}.challenge-complete-toggle{margin-top:auto;border-radius:14px;border:1px dashed rgba(15,23,42,.2);background:transparent;color:var(--text-main);font-weight:600;font-size:13px;padding:10px 14px;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.challenge-complete-toggle.is-active{background:#22c55e1a;border-color:#22c55e99;color:#15803d}.challenge-primary{border:none;border-radius:14px;padding:12px;font-weight:600;font-size:14px;background:linear-gradient(120deg,var(--accent-peach),var(--accent-peach-hover));color:var(--text-on-peach);cursor:pointer;box-shadow:0 10px 20px #f4d7c866}.challenge-secondary-btn{border:1px solid var(--border-soft);border-radius:14px;padding:10px 14px;font-weight:600;font-size:14px;background:var(--card-softer);color:var(--text-main);cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease}.challenge-secondary-btn:hover{background:#f4d7c840;border-color:#f4d7c8e6;transform:translateY(-1px)}.challenge-secondary-btn:focus-visible{outline:2px solid var(--accent-peach);outline-offset:2px}.challenge-inline-actions{display:flex;flex-wrap:wrap;gap:8px}.challenge-inline-actions-bottom{margin-top:auto;justify-content:flex-end}.challenge-switch-row{display:flex;flex-direction:column;gap:8px}.challenge-switch{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--text-main)}.challenge-switch input{accent-color:var(--accent-peach)}.challenge-target-toggle{display:flex;flex-wrap:wrap;gap:8px}.challenge-pill{border-radius:999px;padding:6px 14px;border:1px solid var(--border-soft);background:transparent;color:var(--text-muted);cursor:pointer;font-size:13px}.challenge-pill.is-active{background:#f4d7c847;border-color:#f4d7c8e6;color:var(--text-main)}.challenge-source-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-muted)}.challenge-source-list li{display:flex;justify-content:space-between}.challenge-number-input{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-muted)}.challenge-number-input input{border-radius:12px;border:1px solid var(--border-soft);background:var(--card-white);color:var(--text-main);padding:8px 10px}.challenge-grid.is-collapsed .challenge-card-body{display:none}.challenge-grid.is-collapsed .challenge-card{min-height:auto}.challenge-footer-row{margin-top:20px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:14px;color:var(--text-muted)}.challenge-perfect-pill{margin-left:8px;padding:3px 10px;border-radius:999px;background:#f4d7c859;color:var(--accent-main);font-size:12px;font-weight:600}.challenge-perfect-pill.small{font-size:11px;padding:2px 8px;margin-left:0}.challenge-section-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:20px}.challenge-section-title{margin:0;font-size:22px}.challenge-section-desc{margin:4px 0 0;color:var(--text-muted)}.challenge-section-actions{display:flex;gap:10px;flex-wrap:wrap}.challenge-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.challenge-plan-card{border-radius:16px;padding:16px;background:var(--card-white);border:1px solid var(--border-soft);color:var(--text-main);text-align:left;cursor:pointer;transition:border .2s ease,transform .2s ease,box-shadow .2s ease;box-shadow:0 6px 16px #0f172a0a}.challenge-plan-card.is-active{border-color:#f4d7c8e6;transform:translateY(-2px);box-shadow:0 10px 24px #0f172a1f}.challenge-plan-card-top{display:flex;justify-content:space-between;align-items:center}.challenge-plan-day{font-size:13px;color:var(--text-muted)}.challenge-plan-recipe{margin:8px 0 12px;font-weight:600;min-height:40px;color:var(--text-main)}.challenge-pillar-row{display:flex;flex-wrap:wrap;gap:6px}.challenge-pillar{font-size:11px;padding:4px 8px;border-radius:999px;background:var(--card-softer);color:var(--text-muted)}.challenge-pillar.is-active{background:#f4d7c859;color:var(--text-main)}.challenge-progress-card{padding:20px;border-radius:20px;background:var(--card-white);border:1px solid var(--border-soft);margin-bottom:20px;box-shadow:0 6px 16px #0f172a0a}.challenge-progress-label{margin:0 0 10px;font-weight:600;color:var(--text-main)}.challenge-progress-stats{margin-top:16px;display:flex;gap:32px;flex-wrap:wrap}.challenge-progress-stat-label{display:block;font-size:13px;color:var(--text-muted)}.challenge-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.challenge-summary-card{padding:16px;border-radius:16px;background:var(--card-white);border:1px solid var(--border-soft);box-shadow:inset 0 0 0 1px #0f172a05}.challenge-summary-label{margin:0 0 6px;font-size:13px;color:var(--text-muted)}.challenge-summary-value{margin:0;font-size:20px;font-weight:600;color:var(--text-main)}.challenge-journey-layout{display:flex;flex-direction:column;gap:16px}.challenge-timeline{display:flex;flex-direction:column;gap:10px}.challenge-timeline-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:16px;border:1px solid var(--border-soft);background:var(--card-white)}.challenge-timeline-item.is-locked{background:var(--card-softer);color:var(--text-muted)}.challenge-timeline-left{display:flex;flex-direction:column;gap:4px}.challenge-timeline-title{margin:0;font-weight:600}.challenge-timeline-subtitle{margin:0;font-size:13px;color:var(--text-muted)}.challenge-status-pill{padding:6px 12px;border-radius:999px;border:1px solid var(--border-soft);background:var(--card-white);font-size:12px;font-weight:700;color:var(--text-muted);white-space:nowrap}.challenge-status-pill.is-success{border-color:#22c55e66;background:#22c55e1f;color:#15803d}.challenge-badge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.challenge-badge-card{display:flex;gap:10px;padding:12px 14px;border-radius:16px;border:1px solid var(--border-soft);background:var(--card-white);align-items:flex-start}.challenge-badge-card.is-locked{background:var(--card-softer)}.challenge-badge-icon{width:34px;height:34px;border-radius:12px;background:var(--card-softer);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:transparent}.challenge-badge-card.is-unlocked .challenge-badge-icon{background:#22c55e2e;color:#15803d}.challenge-badge-card.is-unlocked .challenge-badge-icon:after{content:"✓";font-weight:800}.challenge-badge-title{margin:0;font-weight:700;font-size:13px}.challenge-badge-subtitle{margin:4px 0 0;font-size:12px;color:var(--text-muted)}.challenge-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:1000}.challenge-modal{width:min(500px,90vw);max-height:80vh;overflow:hidden;border-radius:20px;background:var(--card-white);border:1px solid var(--border-soft);color:var(--text-main);display:flex;flex-direction:column;box-shadow:0 24px 60px #0f172a40}.challenge-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-soft)}.challenge-modal-body{padding:16px 20px 24px;display:flex;flex-direction:column;gap:12px;overflow:hidden}.challenge-modal-body input{border-radius:12px;border:1px solid var(--border-soft);background:var(--card-white);color:var(--text-main);padding:10px}.challenge-modal-list{overflow-y:auto;max-height:50vh;display:flex;flex-direction:column;gap:8px}.challenge-modal-row{border:none;text-align:left;border-radius:14px;padding:12px;background:var(--card-softer);color:inherit;cursor:pointer;border:1px solid transparent}.challenge-modal-row-title{margin:0;font-weight:600}.challenge-modal-row-subtitle{margin:4px 0 0;font-size:13px;color:var(--text-muted)}.challenge-modal-empty{margin:0;text-align:center;color:var(--text-muted)}.challenge-modal-close{border:none;background:transparent;color:inherit;font-size:18px;cursor:pointer}@media(max-width:768px){.challenge-shell{width:100%;max-width:1250px;padding:20px 0;border-radius:24px}.challenge-section{padding:18px}.challenge-top{flex-direction:column}}.challenge-shell{margin-top:0;padding-top:0}.challenge-day-description{margin:0 0 6px;font-size:20px;font-weight:700;color:var(--text-main);line-height:1.25}.daysTimeline{margin-top:-20px;padding:14px 10px 10px}.dayDot{width:18px;height:18px;min-width:18px;min-height:18px;cursor:pointer}.dayDot.is-selected{box-shadow:0 0 0 3px #0f172a29;border-color:#0f172a66}.dayDot.is-milestone{width:22px;height:22px;min-width:22px;min-height:22px}.dayDot.is-done:after{font-size:12px}.dayDot.is-milestone.is-done:after{font-size:13px}.dayLabel{top:-20px}.challenge-meter{height:14px}.challenge-meter.mini{height:8px;margin:10px 0 12px}.challenge-day-mode-danger{color:#b91c1c}.challengeCard{padding:24px;border-radius:20px}.challengeCardHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.challengeHeaderDayLabel{font-size:12px;letter-spacing:.08em;text-transform:uppercase;opacity:.7}.challengeHeaderTitle{margin-top:4px;font-size:22px;font-weight:700}.challengeHeaderRight{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.challengeHeaderRightTop{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.challengeStartText{font-size:12px;opacity:.7;text-align:right}.challengeCardProgress{margin-top:10px;display:flex;flex-direction:column;gap:10px}@media(max-width:640px){.daysTimeline{padding-top:12px}.challengeCardProgress{margin-top:8px}}.challengeProgressMeta{display:flex;gap:14px;font-size:12px;opacity:.75;flex-wrap:wrap}.challengeCardInfo{margin-top:14px;max-width:820px}.challengeInfoText{margin:0;font-size:13px;line-height:1.35;opacity:.85}.challengeCardChips{margin-top:14px}.challengeCardChips .dailyStatusRow{margin:0;flex-wrap:wrap;overflow-x:visible}.challengeCardPillarsGrid{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}@media(max-width:980px){.challengeCardPillarsGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}.pillarMiniCard{padding:14px 16px;border-radius:16px;min-height:86px}.pillarMiniCardHeader{display:flex;justify-content:space-between;align-items:center;gap:10px}.challengeCardFooter{margin-top:14px;display:flex;justify-content:space-between;align-items:center;font-size:12px;opacity:.7}.challenge-info-panel{margin:10px 0 0;padding:12px 14px;border-radius:18px;border:1px solid var(--border-soft);background:var(--card-softer);color:var(--text-muted);font-size:13px;line-height:1.5}.challenge-info-panel p{margin:0}.challenge-info-panel strong{color:var(--text-main)}.landing-detail-page{min-height:100vh;background:#f5f5f7;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:#111827}.landing-detail-hero{max-width:900px;margin:0 auto;padding:4rem 1.5rem 2rem;text-align:center}.landing-detail-badge{display:inline-flex;align-items:center;padding:.1rem .95rem;border-radius:999px;font-size:.82rem;font-weight:600;border:1px solid currentColor}.landing-detail-badge-free{color:#047857;background:#dcfce7cc}.landing-detail-badge-locked{color:#9a3412;background:#fed7aacc}.landing-detail-hero h1{font-family:Bricolage Grotesque,Inter,sans-serif;font-size:clamp(2rem,6vw,3.2rem);margin:1rem 0 .5rem}.landing-detail-lead{max-width:640px;margin:0 auto 1.5rem;color:#4b5563;line-height:1.6}.landing-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:1.5rem}.landing-detail-meta div{border:1px solid #e5e7eb;border-radius:1rem;padding:.9rem;display:flex;flex-direction:column;gap:.1rem;background:#fff}.landing-detail-meta span{font-size:.78rem;color:#9ca3af}.landing-detail-meta strong{font-size:1rem}.landing-detail-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.landing-detail-ghost,.landing-detail-primary{padding:.75rem 1.6rem;border-radius:999px;font-weight:600;font-size:.95rem;text-decoration:none}.landing-detail-ghost{border:1px solid #e5e7eb;color:#111827;background:#fff}.landing-detail-primary{background:#111827;color:#fff}.landing-detail-section{max-width:960px;margin:0 auto 4rem;padding:0 1.5rem 3rem}.landing-detail-image{border-radius:1.5rem;overflow:hidden;margin-bottom:2rem;border:1px solid #e5e7eb;box-shadow:0 24px 60px #0f172a1a}.landing-detail-image img{width:100%;height:clamp(220px,40vw,420px);object-fit:cover;display:block}.landing-detail-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem}.landing-detail-columns h2{margin-top:0}.landing-detail-columns ul,.landing-detail-columns ol{margin:0;padding-left:1.25rem;line-height:1.7;color:#374151;background:#fff;border-radius:1rem;border:1px solid #e5e7eb;padding:1.1rem 1.25rem}.landing-detail-preview{background:#fff;border-radius:1.5rem;border:1px solid #e5e7eb;padding:2rem;display:flex;flex-direction:column;gap:1rem;line-height:1.7;color:#374151;box-shadow:0 18px 40px #0f172a14}.landing-detail-note{font-size:.9rem;color:#6b7280;margin:0}.landing-detail-page .landing-detail-primary{display:inline-flex;justify-content:center}.landing-detail-card{max-width:480px;margin:8rem auto;padding:2rem;background:#fff;border-radius:1.5rem;border:1px solid #e5e7eb;text-align:center}.landing-detail-link{display:inline-flex;margin-top:1rem;color:#111827;text-decoration:underline}.landing-detail-empty{display:flex;align-items:center;justify-content:center;min-height:80vh;padding:1.5rem}@media(max-width:640px){.landing-detail-hero{padding-top:3rem}.landing-detail-columns ul,.landing-detail-columns ol{padding-left:1rem}}
