/* ============================================================
   FoodNutri — design system (2026)
   ============================================================ */

/* ---- Theme tokens -------------------------------------------------------- */
:root{
    --bg:#ffffff; --bg-soft:#f5f7f9; --surface:#ffffff; --surface-2:#f8fafc;
    --border:#e6e8ec; --border-strong:#d4d8df;
    --text:#14171c; --text-soft:#566072; --muted:#6b7280;
    --brand:#15a34a; --brand-strong:#15803d; --brand-weak:#dcfce7;
    /* Text/icon color for SOLID brand fills (buttons, active pills, badges).
       Dark mode's brand green is light, so white text on it is ~1.9:1 —
       unreadable. This flips to near-black there while light mode keeps white. */
    --on-brand:#fff;
    --accent:#0ea5e9;
    /* --alcohol MUST stay defined: the facts caloric-ratio donut emits
       conic-gradient(var(--alcohol) …) for alcoholic foods, and one undefined
       var() invalidates the whole gradient (blank donut). Tracks --muted, the
       color the alcohol legend/dots use, so it follows the theme. */
    --carb:#f0b429; --fat:#e0483d; --protein:#3b82f6; --alcohol:var(--muted);
    --lvl-low:#aab3bf; --lvl-mid:#15a34a; --lvl-high:#0a9d52;
    /* Health traffic-light tones (see nutri_tone / nutrient_polarity) */
    --tone-good:#16a34a; --tone-warn:#e08a1e; --tone-bad:#e0483d; --tone-neutral:#8b93a2; --tone-low:#cbd2db;
    --ring-track:#eaedf1;
    --shadow:0 1px 2px rgba(16,24,40,.06),0 8px 24px -12px rgba(16,24,40,.18);
    --shadow-lg:0 12px 40px -12px rgba(16,24,40,.28);
    --radius:14px; --radius-sm:10px; --radius-lg:22px;
    --container:1180px;
    --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
    --font-head:'Sora','Inter',system-ui,sans-serif;
    --header-h:70px; --header-h-min:58px;
    --ease:cubic-bezier(.16,1,.3,1); --ease-out:cubic-bezier(.22,.61,.36,1);
    --shadow-pop:0 4px 12px -4px rgba(16,24,40,.12),0 24px 56px -20px rgba(16,24,40,.28);
}
:root[data-theme="dark"]{
    --bg:#0f1115; --bg-soft:#14181f; --surface:#181c23; --surface-2:#1d222b;
    --border:#262c36; --border-strong:#323a47;
    --text:#eef1f5; --text-soft:#a8b2c0; --muted:#8791a1;
    --brand:#34d399; --brand-strong:#22c55e; --brand-weak:#10311f; --on-brand:#08130d;
    --accent:#38bdf8;
    --lvl-low:#5b6573; --lvl-mid:#34d399; --lvl-high:#6ee7b7;
    --tone-good:#34d399; --tone-warn:#f0a93f; --tone-bad:#f06a60; --tone-neutral:#7c8794; --tone-low:#3a424e;
    --ring-track:#262c36;
    --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px -16px rgba(0,0,0,.6);
    --shadow-lg:0 16px 50px -16px rgba(0,0,0,.7);
    --shadow-pop:0 4px 14px -6px rgba(0,0,0,.5),0 28px 64px -22px rgba(0,0,0,.75);
}
@media (prefers-color-scheme:dark){
    :root:not([data-theme="light"]){
        --bg:#0f1115; --bg-soft:#14181f; --surface:#181c23; --surface-2:#1d222b;
        --border:#262c36; --border-strong:#323a47;
        --text:#eef1f5; --text-soft:#a8b2c0; --muted:#8791a1;
        --brand:#34d399; --brand-strong:#22c55e; --brand-weak:#10311f; --on-brand:#08130d;
        --accent:#38bdf8;
        --lvl-low:#5b6573; --lvl-mid:#34d399; --lvl-high:#6ee7b7;
        --tone-good:#34d399; --tone-warn:#f0a93f; --tone-bad:#f06a60; --tone-neutral:#7c8794; --tone-low:#3a424e;
        --ring-track:#262c36;
        --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px -16px rgba(0,0,0,.6);
        --shadow-lg:0 16px 50px -16px rgba(0,0,0,.7);
    }
}

/* ---- Reset -------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
    font-family:var(--font);background:var(--bg);color:var(--text);
    line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;overflow-x:clip;
    display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;
}
#main{flex:1 0 auto}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}
input,select,textarea{font:inherit;color:inherit}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:1}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.2;font-weight:700;letter-spacing:-.01em}
ul{list-style:none;padding:0}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:20px}
.section{padding:56px 0}
.section-alt{background:var(--bg-soft)}
.section-title{font-size:clamp(1.4rem,3vw,2rem);margin-bottom:28px;display:flex;align-items:center;gap:10px}
.section-title .icon{width:1.05em;height:1.05em;flex:none;color:var(--brand-strong)}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}
.section-head .section-title{margin:0}
.visually-hidden,.skip-link{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed!important;top:12px;left:12px;width:auto;height:auto;clip:auto;background:var(--brand);color:#fff;padding:10px 16px;border-radius:8px;z-index:200}

.icon{width:1.25em;height:1.25em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none}
.icon--brand{fill:currentColor;stroke:none}
.grad{background:linear-gradient(120deg,var(--brand),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- Buttons ----------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;padding:11px 18px;border-radius:999px;border:1px solid transparent;transition:transform .12s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease;white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.btn-primary{background:var(--brand);color:var(--on-brand);box-shadow:0 6px 16px -8px color-mix(in srgb,var(--brand) 70%,transparent)}
.btn-primary:hover{background:var(--brand-strong);box-shadow:0 10px 24px -10px color-mix(in srgb,var(--brand) 75%,transparent)}
.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}
.btn-ghost:hover{border-color:var(--border-strong);background:var(--surface-2)}
.btn-block{display:flex;justify-content:center;width:100%;margin-top:10px}
.link-more{display:inline-flex;align-items:center;gap:6px;color:var(--brand);font-weight:600}

/* ---- Header ------------------------------------------------------------ */
.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid transparent;transition:transform .4s var(--ease),background .3s ease,border-color .3s ease,box-shadow .3s ease}
.site-header.scrolled{background:color-mix(in srgb,var(--bg) 88%,transparent);border-bottom-color:var(--border);box-shadow:0 10px 30px -22px rgba(16,24,40,.55)}
.site-header.nav-hidden{transform:translateY(-100%)}
.header-inner{display:flex;align-items:center;gap:14px;height:var(--header-h);transition:height .3s var(--ease)}
.site-header.scrolled .header-inner{height:var(--header-h-min)}

.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;font-size:1.2rem;flex:none}
.brand-mark{position:relative;display:grid;place-items:center;width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;box-shadow:0 6px 16px -6px color-mix(in srgb,var(--brand) 70%,transparent);transition:transform .35s var(--ease)}
.brand:hover .brand-mark{transform:rotate(-8deg) scale(1.06)}
.brand-mark .icon{position:relative;z-index:1;width:21px;height:21px;stroke-width:2.4}
.brand-mark-glow{position:absolute;inset:-35%;border-radius:50%;background:radial-gradient(circle at 50% 30%,rgba(255,255,255,.6),transparent 60%);opacity:0;transition:opacity .35s ease}
.brand:hover .brand-mark-glow{opacity:1}
.brand-name{letter-spacing:-.02em;white-space:nowrap}
.brand-name span{color:var(--brand)}

.primary-nav{margin-inline:auto}
.nav-list{display:flex;align-items:center;gap:2px}
.nav-item{position:relative}
.nav-trigger{display:inline-flex;align-items:center;gap:7px;padding:9px 13px;border-radius:11px;color:var(--text-soft);font-weight:500;font-size:.95rem;line-height:1;transition:color .15s ease,background .15s ease}
.nav-trigger .nav-ico{width:17px;height:17px;opacity:.85}
.nav-trigger .nav-caret{width:14px;height:14px;opacity:.55;transition:transform .25s var(--ease)}
.nav-trigger:hover,.nav-item.open .nav-trigger{color:var(--text);background:var(--bg-soft)}
.nav-item.open .nav-trigger .nav-caret{transform:rotate(180deg)}
.nav-trigger.is-active{color:var(--brand)}
.nav-trigger.is-active .nav-ico{opacity:1}

.mega{position:absolute;top:calc(100% + 11px);left:0;transform:translateY(8px) scale(.98);transform-origin:top left;min-width:340px;opacity:0;visibility:hidden;pointer-events:none;z-index:120;transition:opacity .2s var(--ease),transform .2s var(--ease),visibility 0s linear .2s}
.nav-item:last-child .mega{left:auto;right:0;transform-origin:top right}
.nav-item.open .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0) scale(1);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.mega::before{content:"";position:absolute;top:-13px;left:0;right:0;height:15px}
.mega-card{display:flex;gap:8px;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-pop)}
.mega-main{display:flex;flex-direction:column;gap:1px;min-width:296px}
.mega-eyebrow{font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:6px 10px 5px}
.mega-link{display:flex;align-items:center;gap:13px;padding:10px;border-radius:13px;transition:background .15s ease}
.mega-link:hover{background:var(--bg-soft)}
.mega-link-ico{display:grid;place-items:center;width:40px;height:40px;flex:none;border-radius:11px;background:var(--brand-weak);color:var(--brand-strong);transition:transform .2s var(--ease)}
.mega-link:hover .mega-link-ico{transform:scale(1.07)}
.mega-link-ico .icon{width:19px;height:19px}
.mega-link-tx{display:flex;flex-direction:column;gap:1px;line-height:1.3}
.mega-link-tx b{font-size:.95rem;font-weight:600;color:var(--text)}
.mega-link-tx small{font-size:.8rem;color:var(--text-soft)}
.mega-arrow{width:17px;height:17px;margin-left:auto;color:var(--brand);opacity:0;transform:translateX(-5px);transition:opacity .2s ease,transform .2s ease}
.mega-link:hover .mega-arrow{opacity:1;transform:translateX(0)}
.mega-aside{display:flex;flex-direction:column;gap:9px;width:212px;flex:none;padding:10px;border-radius:14px;background:linear-gradient(165deg,var(--bg-soft),transparent)}
.mega-chips{display:flex;flex-wrap:wrap;gap:6px}
.mega-chips a{font-size:.82rem;font-weight:500;padding:5px 11px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text-soft);transition:color .15s ease,border-color .15s ease,background .15s ease}
.mega-chips a:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.mega-feature{display:flex;align-items:center;gap:11px;margin-top:auto;padding:11px;border-radius:12px;background:var(--surface);border:1px solid var(--border);transition:border-color .15s ease,transform .15s ease}
.mega-feature:hover{border-color:var(--brand);transform:translateY(-1px)}
.mega-feature-ico{display:grid;place-items:center;width:34px;height:34px;flex:none;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff}
.mega-feature-ico .icon{width:18px;height:18px}
.mega-feature-tx{display:flex;flex-direction:column;line-height:1.3}
.mega-feature-tx b{font-size:.88rem;color:var(--text)}
.mega-feature-tx small{font-size:.78rem;color:var(--text-soft)}
.mega-aside--plain{background:none;padding:0}
.mega-promo{display:flex;flex-direction:column;gap:7px;justify-content:center;height:100%;padding:18px;border-radius:14px;background:linear-gradient(150deg,var(--brand),var(--accent));color:#fff;position:relative;overflow:hidden}
.mega-promo::after{content:"";position:absolute;right:-34px;top:-34px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.15)}
.mega-promo>*{position:relative;z-index:1}
.mega-promo-badge{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.22)}
.mega-promo-badge .icon{width:20px;height:20px;color:#fff}
.mega-promo b{font-size:1rem}
.mega-promo small{font-size:.82rem;opacity:.93;line-height:1.4}
.mega-promo-cta{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:700;margin-top:2px}
.mega-promo-cta .icon{width:15px;height:15px;transition:transform .2s ease}
.mega-promo:hover .mega-promo-cta .icon{transform:translateX(3px)}

.header-actions{display:flex;align-items:center;gap:9px}
.cmd-trigger{display:inline-flex;align-items:center;gap:9px;height:40px;padding:0 7px 0 13px;border-radius:11px;background:var(--bg-soft);border:1px solid var(--border);color:var(--muted);font-size:.9rem;min-width:208px;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}
.cmd-trigger:hover{border-color:var(--border-strong);background:var(--surface);box-shadow:var(--shadow)}
.cmd-trigger-ico{width:17px;height:17px;flex:none}
.cmd-trigger-tx{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmd-kbd{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;font-weight:600;color:var(--text-soft);background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:3px 7px;line-height:1;flex:none}
.cmd-kbd abbr{text-decoration:none}
.cmd-trigger-mini{display:none}

.icon-btn{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);transition:color .15s ease,border-color .15s ease,background .15s ease,transform .12s ease}
.icon-btn:hover{color:var(--text);border-color:var(--border-strong);background:var(--bg-soft)}
.icon-btn:active{transform:scale(.93)}
.theme-toggle .icon{transition:transform .45s var(--ease)}
.theme-toggle:hover .icon{transform:rotate(35deg)}
.theme-toggle .i-sun{display:none}
:root[data-theme="dark"] .theme-toggle .i-moon{display:none}
:root[data-theme="dark"] .theme-toggle .i-sun{display:block}
@media (prefers-color-scheme:dark){:root:not([data-theme="light"]) .theme-toggle .i-moon{display:none}:root:not([data-theme="light"]) .theme-toggle .i-sun{display:block}}

.nav-toggle{display:none}
.nav-toggle-bars{position:relative;width:20px;height:14px}
.nav-toggle-bars span{position:absolute;left:0;width:100%;height:2px;border-radius:2px;background:currentColor;transition:transform .3s var(--ease),opacity .2s ease,top .3s var(--ease)}
.nav-toggle-bars span:nth-child(1){top:0}
.nav-toggle-bars span:nth-child(2){top:6px}
.nav-toggle-bars span:nth-child(3){top:12px}
body.mobile-open .nav-toggle-bars span:nth-child(1){top:6px;transform:rotate(45deg)}
body.mobile-open .nav-toggle-bars span:nth-child(2){opacity:0}
body.mobile-open .nav-toggle-bars span:nth-child(3){top:6px;transform:rotate(-45deg)}

.nav-trigger:focus-visible,.cmd-trigger:focus-visible,.mega-link:focus-visible,.mega-chips a:focus-visible,.mega-feature:focus-visible,.mega-promo:focus-visible,.cmdk-item:focus-visible,.mobile-nav-body a:focus-visible,.theme-row:focus-visible{outline:2px solid var(--brand);outline-offset:2px}

@media (max-width:1024px){
    .primary-nav{display:none}
    .cmd-trigger{display:none}
    .cmd-trigger-mini{display:grid}
    .nav-toggle{display:grid}
    .header-actions{margin-left:auto}
}

/* ---- Mobile slide-in drawer -------------------------------------------- */
.mobile-nav{position:fixed;inset:0;z-index:300}
.mobile-nav[hidden]{display:none}
.mobile-nav-backdrop{position:absolute;inset:0;background:rgba(8,11,16,.5);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;transition:opacity .3s ease}
.mobile-nav.open .mobile-nav-backdrop{opacity:1}
.mobile-nav-panel{position:absolute;top:0;right:0;height:100dvh;width:min(370px,87vw);display:flex;flex-direction:column;background:var(--bg);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .38s var(--ease);overflow-y:auto;overscroll-behavior:contain}
.mobile-nav.open .mobile-nav-panel{transform:translateX(0)}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--border)}
.cmd-trigger--block{display:flex;width:auto;min-width:0;margin:16px 18px 6px}
.mobile-nav-body{flex:1;padding:6px 12px 10px}
.m-group{padding:6px 0}
.m-group+.m-group{border-top:1px solid var(--border)}
.m-group-title{display:flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:9px 10px 5px}
.m-group-title .icon{width:15px;height:15px}
.mobile-nav-body a{display:flex;align-items:center;gap:12px;padding:11px 10px;border-radius:11px;color:var(--text-soft);font-weight:500;transition:background .15s ease,color .15s ease}
.mobile-nav-body a:hover,.mobile-nav-body a.is-current{background:var(--bg-soft);color:var(--text)}
.mobile-nav-body a .icon{width:19px;height:19px;color:var(--muted)}
.mobile-nav-body a.is-current .icon{color:var(--brand)}
.mobile-nav-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-top:1px solid var(--border)}
.theme-row{display:inline-flex;align-items:center;gap:11px;font-weight:600;font-size:.9rem;color:var(--text)}
.theme-row-ico{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface)}
.theme-row .icon{width:18px;height:18px}
.theme-row .i-sun{display:none}
:root[data-theme="dark"] .theme-row .i-moon{display:none}
:root[data-theme="dark"] .theme-row .i-sun{display:block}
@media (prefers-color-scheme:dark){:root:not([data-theme="light"]) .theme-row .i-moon{display:none}:root:not([data-theme="light"]) .theme-row .i-sun{display:block}}
.theme-row-off{display:none}
:root[data-theme="dark"] .theme-row-on{display:none}
:root[data-theme="dark"] .theme-row-off{display:inline}
@media (prefers-color-scheme:dark){:root:not([data-theme="light"]) .theme-row-on{display:none}:root:not([data-theme="light"]) .theme-row-off{display:inline}}
.mobile-nav-foot .socials{display:flex;gap:8px}

/* ---- Command palette (⌘K) ---------------------------------------------- */
.cmdk{position:fixed;inset:0;z-index:400;display:flex;align-items:flex-start;justify-content:center;padding:13vh 20px 20px}
.cmdk[hidden]{display:none}
.cmdk-backdrop{position:absolute;inset:0;background:rgba(8,11,16,.55);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);opacity:0;transition:opacity .25s ease}
.cmdk.open .cmdk-backdrop{opacity:1}
.cmdk-modal{position:relative;width:min(620px,100%);max-height:74vh;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-pop);overflow:hidden;opacity:0;transform:translateY(-14px) scale(.97);transition:opacity .25s ease,transform .25s var(--ease)}
.cmdk.open .cmdk-modal{opacity:1;transform:translateY(0) scale(1)}
.cmdk-search{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border)}
.cmdk-search-ico{width:20px;height:20px;color:var(--muted);flex:none}
.cmdk-input{flex:1;min-width:0;border:none;outline:none;background:none;font-size:1.05rem;color:var(--text)}
.cmdk-input::placeholder{color:var(--muted)}
.cmdk-esc{font-size:.72rem;font-weight:600;color:var(--text-soft);background:var(--bg-soft);border:1px solid var(--border);border-radius:7px;padding:4px 8px;flex:none}
.cmdk-results{flex:1;overflow-y:auto;padding:8px;overscroll-behavior:contain}
.cmdk-group-title{font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:11px 12px 6px}
.cmdk-item{display:flex;align-items:center;gap:13px;width:100%;padding:10px 12px;border-radius:12px;text-align:left;color:var(--text);scroll-margin:10px}
.cmdk-item:hover,.cmdk-item.active{background:var(--bg-soft)}
.cmdk-item.active{box-shadow:inset 0 0 0 1px var(--border-strong)}
.cmdk-item-ico{display:grid;place-items:center;width:38px;height:38px;flex:none;border-radius:10px;background:var(--brand-weak);color:var(--brand-strong);overflow:hidden}
.cmdk-item-ico .icon{width:18px;height:18px}
.cmdk-item-ico img{width:38px;height:38px;object-fit:cover}
.cmdk-item-tx{display:flex;flex-direction:column;line-height:1.3;min-width:0}
.cmdk-item-tx b{font-size:.94rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk-item-tx small{font-size:.8rem;color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk-item-go{margin-left:auto;flex:none;color:var(--muted);opacity:0;transition:opacity .15s ease}
.cmdk-item-go .icon{width:16px;height:16px}
.cmdk-item:hover .cmdk-item-go,.cmdk-item.active .cmdk-item-go{opacity:1}
.cmdk-empty{padding:30px 16px;text-align:center;color:var(--text-soft);font-size:.92rem}
.cmdk-foot{display:flex;align-items:center;gap:16px;padding:10px 16px;border-top:1px solid var(--border);background:var(--bg-soft);font-size:.78rem;color:var(--text-soft)}
.cmdk-foot span{display:inline-flex;align-items:center;gap:5px}
.cmdk-foot kbd{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 4px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-soft)}
.cmdk-foot kbd .icon{width:12px;height:12px}
.cmdk-foot-brand{margin-left:auto;font-weight:600}
.cmdk-foot-brand .icon{width:14px;height:14px;color:var(--brand)}
@media (max-width:560px){
    .cmdk{padding:0}
    .cmdk-modal{width:100%;max-height:100dvh;height:100dvh;border:none;border-radius:0}
    .cmdk-foot-brand{display:none}
}

@media (prefers-reduced-motion:reduce){
    .site-header,.header-inner,.mega,.brand-mark,.theme-toggle .icon,.mobile-nav-panel,.mobile-nav-backdrop,.nav-toggle-bars span,.cmdk-modal,.cmdk-backdrop,.mega-link-ico,.mega-arrow{transition-duration:.01ms!important}
    .site-header.nav-hidden{transform:none}
}

/* ---- Autocomplete ------------------------------------------------------ */
.ac-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;z-index:60;display:none;padding:6px}
.ac-results.show{display:block}
.ac-results a,.ac-results button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:9px 10px;border-radius:10px;font-size:.93rem;color:var(--text)}
.ac-results a:hover,.ac-results a.active,.ac-results button:hover,.ac-results button.active{background:var(--bg-soft)}
.ac-results img{width:30px;height:30px;object-fit:contain;flex:none;padding:3px;border-radius:8px;background:var(--bg-soft)}

/* ---- Hero -------------------------------------------------------------- */
/* overflow-x:clip contains the decorative aurora/floats horizontally, while
   overflow-y:visible lets the search autocomplete escape the hero; z-index keeps
   that dropdown above the sections below. */
.hero{position:relative;overflow-x:clip;overflow-y:visible;z-index:2;padding:60px 0 64px}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-aurora{position:absolute;border-radius:50%;filter:blur(72px);will-change:transform}
.hero-aurora-1{width:560px;height:560px;top:-230px;right:-110px;background:radial-gradient(circle,var(--brand),transparent 64%);opacity:.38;animation:heroDrift1 19s var(--ease) infinite alternate}
.hero-aurora-2{width:470px;height:470px;top:-90px;right:170px;background:radial-gradient(circle,var(--accent),transparent 64%);opacity:.26;animation:heroDrift2 23s var(--ease) infinite alternate}
.hero-dots{position:absolute;inset:0;background-image:radial-gradient(var(--border-strong) 1px,transparent 1px);background-size:26px 26px;opacity:.3;-webkit-mask-image:radial-gradient(120% 85% at 72% 0,#000,transparent 70%);mask-image:radial-gradient(120% 85% at 72% 0,#000,transparent 70%)}
@keyframes heroDrift1{to{transform:translate(-44px,32px) scale(1.1)}}
@keyframes heroDrift2{to{transform:translate(34px,42px) scale(1.06)}}

.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:48px;align-items:center}
.hero-copy{max-width:600px}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;font-weight:600;color:var(--brand-strong);background:var(--brand-weak);padding:6px 12px;border-radius:999px}
.eyebrow .icon{width:15px;height:15px}
.hero h1{font-size:clamp(2.2rem,5vw,3.55rem);line-height:1.05;letter-spacing:-.02em;margin:18px 0 14px;font-weight:800}
.hero .lead{font-size:clamp(1.05rem,2vw,1.22rem);color:var(--text-soft);max-width:560px}
.hero-search{margin:28px 0 16px;max-width:600px}
.hero-search-field{display:flex;align-items:stretch;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:7px;box-shadow:var(--shadow);flex-wrap:wrap;transition:border-color .2s ease,box-shadow .2s ease}
.hero-search-field:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-weak),var(--shadow)}
.hero-search-field select{border:none;background:var(--bg-soft);border-radius:13px;padding:0 14px;font-weight:600;font-size:.92rem;outline:none;color:var(--text-soft)}
.hero-search-field select:hover{color:var(--text)}
.hero-search-input{position:relative;display:flex;align-items:center;gap:10px;flex:1;min-width:170px;padding-left:14px}
.hero-search-input .icon{color:var(--muted);width:20px;height:20px;flex:none}
.hero-search-input input{flex:1;border:none;background:none;outline:none;padding:14px 4px;font-size:1.02rem;min-width:0}
.hero-search-field>button{display:inline-flex;align-items:center;gap:7px;background:var(--brand);color:var(--on-brand);font-weight:600;font-size:.98rem;border-radius:13px;padding:0 24px;box-shadow:0 6px 16px -8px color-mix(in srgb,var(--brand) 70%,transparent);transition:background .15s ease,transform .1s ease,box-shadow .15s ease}
.hero-search-field>button:hover{background:var(--brand-strong);box-shadow:0 10px 22px -10px color-mix(in srgb,var(--brand) 75%,transparent)}
.hero-search-field>button:active{transform:scale(.97)}
.hero-search-field>button .icon{width:17px;height:17px}
/* Modern custom category dropdown (JS-enhanced <select>) */
.fsel{position:relative;display:flex}
.fsel-btn{display:inline-flex;align-items:center;gap:9px;height:100%;min-height:50px;border:none;background:var(--bg-soft);border-radius:13px;padding:0 12px;font-family:inherit;font-weight:600;font-size:.92rem;color:var(--text-soft);cursor:pointer;transition:background .15s ease,color .15s ease}
.fsel-btn:hover{background:color-mix(in srgb,var(--brand-weak) 60%,var(--bg-soft));color:var(--text)}
.fsel-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.fsel-btn-tx{white-space:nowrap}
.fsel-btn>.icon{width:16px;height:16px;color:var(--muted);transition:transform .25s var(--ease)}
.fsel.open .fsel-btn>.icon{transform:rotate(180deg)}
.fsel.open .fsel-btn{color:var(--text);background:color-mix(in srgb,var(--brand-weak) 70%,var(--bg-soft))}
.fsel-ico{display:grid;place-items:center;width:26px;height:26px;flex:none;border-radius:8px;overflow:hidden}
.fsel-ico img{width:24px;height:24px;object-fit:contain}
.fsel-ico-all{background:var(--brand-weak)}
.fsel-ico-all .icon{width:15px;height:15px;color:var(--brand-strong)}
.fsel-menu{position:absolute;top:calc(100% + 9px);left:0;min-width:240px;margin:0;padding:6px;list-style:none;background:var(--surface);border:1px solid var(--border);border-radius:15px;box-shadow:var(--shadow-pop);z-index:70;max-height:min(60vh,360px);overflow:auto;opacity:0;transform:translateY(-8px) scale(.97);transform-origin:top left;transition:opacity .18s ease,transform .2s var(--ease);pointer-events:none}
.fsel.open .fsel-menu{opacity:1;transform:none;pointer-events:auto}
.fsel-opt{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:11px;font-size:.93rem;font-weight:500;color:var(--text);cursor:pointer;white-space:nowrap}
.fsel-opt-tx{flex:1}
.fsel-opt.is-active{background:var(--bg-soft)}
.fsel-opt.is-selected{color:var(--brand-strong);font-weight:600}
.fsel-check{display:grid;place-items:center;width:17px;height:17px;flex:none;color:var(--brand);opacity:0;transform:scale(.6);transition:opacity .15s ease,transform .15s var(--ease)}
.fsel-check .icon{width:17px;height:17px}
.fsel-opt.is-selected .fsel-check{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.fsel-menu,.fsel-btn>.icon,.fsel-check{transition:none}}
@media (max-width:560px){
    .hero-search-field{flex-direction:column;align-items:stretch}
    .hero-search-field select{padding:13px 14px}
    .hero-search-field>button{padding:13px 24px;justify-content:center}
    .fsel,.fsel-btn{width:100%}
    .fsel-btn{min-height:48px}
    .fsel-menu{min-width:100%}
}
.hero-suggest{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--muted);font-size:.9rem}
.hero-suggest>span{font-weight:500}
.hero-suggest a{background:var(--surface);border:1px solid var(--border);padding:6px 13px;border-radius:999px;color:var(--text-soft);font-weight:500;transition:border-color .15s ease,color .15s ease,background .15s ease,transform .15s ease}
.hero-suggest a:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak);transform:translateY(-1px)}
.hero-stats{display:flex;flex-wrap:wrap;gap:14px 32px;margin-top:30px;padding-top:24px;border-top:1px solid var(--border)}
.hero-stats li{display:flex;flex-direction:column;line-height:1.15}
.hero-stats b{font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--text)}
.hero-stats span{font-size:.85rem;color:var(--muted)}

.hero-visual{position:relative;justify-self:center;width:100%;max-width:380px;aspect-ratio:1/1}
.hero-orbit{position:absolute;inset:0;display:grid;place-items:center}
.hero-card{width:300px;max-width:100%;padding:18px;z-index:2;border-radius:20px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 86%,transparent);backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);box-shadow:var(--shadow-pop);animation:heroFloat 7s ease-in-out infinite}
.hero-card-top{display:flex;align-items:center;gap:12px}
.hero-card-img{display:grid;place-items:center;width:46px;height:46px;flex:none;border-radius:13px;background:var(--brand-weak)}
.hero-card-img img{width:30px;height:30px;object-fit:contain}
.hero-card-head{display:flex;flex-direction:column;line-height:1.25;margin-right:auto}
.hero-card-head b{font-size:.98rem}
.hero-card-head small{font-size:.78rem;color:var(--muted)}
.hero-card-kcal{display:flex;flex-direction:column;align-items:flex-end;font-family:var(--font-head);font-weight:800;font-size:1.55rem;color:var(--brand-strong);line-height:1}
.hero-card-kcal i{font-style:normal;font-size:.64rem;font-weight:600;color:var(--muted)}
.hero-macro{display:flex;height:9px;border-radius:999px;overflow:hidden;margin:16px 0 8px;background:var(--bg-soft);gap:2px}
.hero-macro .hm{height:100%;border-radius:999px}
.hm-carb{background:var(--carb)}.hm-fat{background:var(--fat)}.hm-prot{background:var(--protein)}
.hero-macro-legend{display:flex;justify-content:space-between;gap:6px;font-size:.72rem;color:var(--text-soft)}
.hero-macro-legend span{display:inline-flex;align-items:center;gap:5px}
.hero-macro-legend .dot{width:8px;height:8px;border-radius:50%;flex:none}
.dot-carb{background:var(--carb)}.dot-fat{background:var(--fat)}.dot-prot{background:var(--protein)}
.hero-card-rows{margin-top:14px;border-top:1px solid var(--border);padding-top:4px}
.hcr{display:flex;justify-content:space-between;padding:7px 0;font-size:.84rem;border-bottom:1px solid var(--border)}
.hcr:last-child{border-bottom:none}
.hcr span{color:var(--text-soft)}
.hcr b{font-weight:600}
.hero-float{position:absolute;display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);font-size:.82rem;font-weight:700;z-index:3}
.hero-float .icon{width:15px;height:15px}
.hero-float-1{top:5%;left:-3%;color:var(--fat);animation:heroFloat 8s ease-in-out infinite}
.hero-float-2{bottom:13%;right:-5%;color:var(--brand-strong);animation:heroFloat 6.5s ease-in-out infinite reverse}
.hero-bubble{position:absolute;display:grid;place-items:center;border-radius:50%;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);z-index:1}
.hero-bubble img{object-fit:contain}
.hero-bubble-1{width:58px;height:58px;top:-1%;right:7%;animation:heroFloat 9s ease-in-out infinite}
.hero-bubble-1 img{width:34px;height:34px}
.hero-bubble-2{width:46px;height:46px;bottom:3%;left:1%;animation:heroFloat 7.5s ease-in-out infinite reverse}
.hero-bubble-2 img{width:28px;height:28px}
.hero-bubble-3{width:40px;height:40px;bottom:31%;right:-3%;animation:heroFloat 10s ease-in-out infinite}
.hero-bubble-3 img{width:24px;height:24px}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media (max-width:920px){
    .hero-inner{grid-template-columns:1fr;gap:0}
    .hero-visual{display:none}
    .hero-copy{max-width:640px}
}
@media (prefers-reduced-motion:reduce){
    .hero-aurora,.hero-card,.hero-float,.hero-bubble{animation:none!important}
}

/* ---- Grids: categories / features / foods ------------------------------ */
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.category-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;font-weight:600;overflow:hidden;transition:transform .18s var(--ease),border-color .18s ease,box-shadow .18s ease}
.category-card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -20%,var(--brand-weak),transparent 60%);opacity:0;transition:opacity .2s ease}
.category-card:hover{transform:translateY(-4px);border-color:var(--brand);box-shadow:var(--shadow)}
.category-card:hover::before{opacity:.7}
.category-card-ic{position:relative;display:grid;place-items:center;width:66px;height:66px;border-radius:18px;background:var(--brand-weak);transition:transform .2s var(--ease)}
.category-card:hover .category-card-ic{transform:scale(1.08)}
.category-card-ic img{width:42px;height:42px;object-fit:contain}
.category-card-tx{position:relative}
.category-card-arr{position:absolute;top:12px;right:12px;width:16px;height:16px;color:var(--brand);opacity:0;transform:translateX(-4px);transition:opacity .2s ease,transform .2s ease}
.category-card:hover .category-card-arr{opacity:1;transform:translateX(0)}

.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.feature-card{position:relative;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .18s var(--ease),border-color .18s ease,box-shadow .18s ease}
.feature-card:hover{transform:translateY(-3px);border-color:var(--brand);box-shadow:var(--shadow)}
.feature-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;margin-bottom:14px;box-shadow:0 6px 16px -8px color-mix(in srgb,var(--brand) 70%,transparent);transition:transform .2s var(--ease)}
.feature-card:hover .feature-icon{transform:scale(1.06) rotate(-4deg)}
.feature-icon .icon{width:22px;height:22px}
.feature-card h3{font-size:1.1rem;margin-bottom:6px}
.feature-card p{color:var(--text-soft);font-size:.95rem}

.food-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.food-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:500;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.food-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}
.food-card img{width:40px;height:40px;object-fit:contain;flex:none;padding:4px;border-radius:9px;background:var(--bg-soft)}
.food-card span{flex:1;min-width:0;font-size:.92rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.food-card .icon{color:var(--muted);width:18px;height:18px;flex:none;align-self:center;transition:transform .15s ease,color .15s ease}
.food-card:hover .icon{color:var(--brand);transform:translateX(3px)}

/* ---- Food category hub + landing -------------------------------------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.cat-tile{display:flex;align-items:center;gap:16px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .15s,border-color .15s,box-shadow .15s}
.cat-tile:hover{transform:translateY(-3px);border-color:var(--brand);box-shadow:var(--shadow)}
.cat-tile-icon{display:grid;place-items:center;width:64px;height:64px;flex:none;border-radius:14px;background:var(--brand-weak);transition:transform .2s var(--ease)}
.cat-tile:hover .cat-tile-icon{transform:scale(1.08)}
.cat-tile-icon img{width:46px;height:46px;object-fit:contain}
.cat-tile-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.cat-tile-name{font-family:var(--font-head);font-weight:700;font-size:1.08rem}
.cat-tile-blurb{color:var(--text-soft);font-size:.88rem;line-height:1.4}
.cat-tile-count{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:.8rem;font-weight:600;margin-top:2px}
.cat-tile-count .icon{width:14px;height:14px}
.cat-tile>.icon{color:var(--muted);width:20px;height:20px;flex:none;align-self:center;transition:color .2s ease,transform .2s ease}
.cat-tile:hover>.icon{color:var(--brand);transform:translateX(3px)}

.cat-hero{display:flex;align-items:flex-start;gap:22px;padding-block:34px 6px}
.cat-hero-icon{display:grid;place-items:center;width:88px;height:88px;flex:none;border-radius:20px;background:var(--brand-weak)}
.cat-hero-icon img{width:60px;height:60px;object-fit:contain}
.cat-hero-copy{flex:1;min-width:0}
.cat-hero-copy h1{font-size:clamp(1.7rem,4vw,2.6rem)}
.cat-hero-copy .lead{color:var(--text-soft);font-size:1.08rem;margin-top:8px;max-width:65ch}
.cat-hero-meta{display:inline-flex;align-items:center;gap:7px;margin-top:14px;color:var(--muted);font-size:.9rem;font-weight:600}
.cat-hero-meta .icon{width:16px;height:16px}

.hl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.hl-card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:4px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.hl-card::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 130% at 100% 0,var(--brand-weak),transparent 60%);opacity:.5;pointer-events:none}
.hl-card>*{position:relative;z-index:1}
.hl-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}
.hl-label{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-strong)}
.hl-label .icon{width:14px;height:14px}
.hl-food{font-weight:600;font-size:1.05rem}
.hl-detail{color:var(--text-soft);font-size:.9rem}

.chips{display:flex;flex-wrap:wrap;gap:9px}
.chips .chip b{margin-left:5px;color:var(--text);font-weight:700}

/* ---- Nutrient guide (hub cards, stat strip, source grid) --------------- */
.nut-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.nut-card{display:flex;flex-direction:column;gap:7px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .15s,border-color .15s,box-shadow .15s}
.nut-card:hover{transform:translateY(-3px);border-color:var(--brand);box-shadow:var(--shadow)}
.nut-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.nut-card-name{font-family:var(--font-head);font-weight:700;font-size:1.1rem}
.nut-card-dv{flex:none;font-size:.72rem;font-weight:700;color:var(--brand-strong);background:var(--brand-weak);padding:3px 8px;border-radius:999px}
.nut-card-tagline{color:var(--text-soft);font-size:.9rem;line-height:1.45;flex:1}
.nut-card-more{display:inline-flex;align-items:center;gap:5px;color:var(--brand);font-weight:600;font-size:.85rem}
.nut-card-more .icon{width:15px;height:15px;transition:transform .15s}
.nut-card:hover .nut-card-more .icon{transform:translateX(3px)}

.nut-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.nut-stat{display:flex;flex-direction:column;gap:4px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.nut-stat-label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.nut-stat-value{font-family:var(--font-head);font-weight:700;font-size:1.15rem}

.bullets{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:10px}
.bullets li{display:flex;align-items:flex-start;gap:10px;color:var(--text-soft)}
.bullets li .icon{width:18px;height:18px;flex:none;margin-top:2px;color:var(--ok,#2f9e63)}

.src-intro{color:var(--text-soft);margin-bottom:18px;max-width:70ch}
.src-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.src-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.src-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}
.src-card img{width:40px;height:40px;object-fit:contain;flex:none;padding:4px;border-radius:9px;background:var(--bg-soft)}
.src-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.src-name{font-weight:500;font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.src-amount{font-size:.84rem;color:var(--muted)}
.src-amount b{color:var(--brand-strong);font-weight:700;margin-left:4px}

/* ---- CTA banner -------------------------------------------------------- */
.cta-banner{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding:34px 36px;border-radius:var(--radius-lg);background:linear-gradient(120deg,var(--brand),var(--accent));color:#fff}
/* Dark mode's brand/accent are light, so white copy on these gradient panels
   fell to ~1.9:1. Darken the gradient there (both selector forms: explicit
   toggle + prefers-color-scheme) so the white text clears AA. */
:root[data-theme="dark"] .cta-banner,:root[data-theme="dark"] .mega-promo{background:linear-gradient(120deg,#0d6b45,#0b5a78)}
@media (prefers-color-scheme:dark){:root:not([data-theme="light"]) .cta-banner,:root:not([data-theme="light"]) .mega-promo{background:linear-gradient(120deg,#0d6b45,#0b5a78)}}
.cta-banner::after{content:"";position:absolute;right:-50px;top:-60px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.13)}
.cta-banner::before{content:"";position:absolute;left:-40px;bottom:-80px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.08)}
.cta-banner>*{position:relative;z-index:1}
.cta-banner h2{font-size:1.5rem}
.cta-banner p{opacity:.92;margin-top:4px}
.cta-banner .btn{background:#fff;color:var(--brand-strong)}
.cta-banner .btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px -12px rgba(0,0,0,.35)}

/* ---- Breadcrumb / page heads ------------------------------------------- */
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding-top:22px;color:var(--muted);font-size:.86rem}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb .icon{width:15px;height:15px}
.page-head{padding-block:40px 8px}
.page-head h1{font-size:clamp(1.7rem,4vw,2.6rem);display:flex;align-items:center;flex-wrap:wrap;gap:10px 14px;letter-spacing:-.01em}
.page-head h1 .icon{flex:none;width:48px;height:48px;padding:11px;border-radius:14px;background:var(--brand-weak);color:var(--brand-strong);box-shadow:0 6px 16px -8px color-mix(in srgb,var(--brand) 60%,transparent)}
.page-head .lead{color:var(--text-soft);font-size:1.08rem;margin-top:8px;max-width:72ch}

/* ---- Facts ------------------------------------------------------------- */
.facts{padding-bottom:72px}
.facts>section{margin-top:40px}
.facts>section:first-of-type{margin-top:28px}
.facts-head{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;margin-top:16px;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}
.facts-head::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 150% at 100% 0,var(--brand-weak),transparent 55%);opacity:.7;pointer-events:none}
.facts-head>*{position:relative;z-index:1}
.facts-id{display:flex;align-items:center;gap:18px}
.facts-thumb{position:relative;display:grid;place-items:center;width:88px;height:88px;flex:none;border-radius:20px;background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow)}
.facts-thumb img{width:62px;height:62px;object-fit:contain}
.facts-id-tx{min-width:0}
.facts-kicker{color:var(--muted);font-size:.85rem}
.facts-head h1{font-size:clamp(1.5rem,3.6vw,2.3rem);margin:2px 0 6px}
.facts-sub{color:var(--text-soft);font-size:.92rem}
.facts-group{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:.8rem;font-weight:600;color:var(--brand-strong);background:var(--brand-weak);border-radius:999px;padding:5px 12px;transition:transform .15s ease,box-shadow .15s ease}
.facts-group:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.facts-group .icon{width:14px;height:14px}
.facts-tools{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.serving{display:flex;flex-direction:column;gap:5px}
.serving label{font-size:.78rem;color:var(--muted);font-weight:600}
.serving-fields{display:flex;gap:8px;align-items:stretch;flex-wrap:wrap}
.serving select{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:11px 13px;outline:none;max-width:260px;font-weight:500;transition:border-color .15s ease,box-shadow .15s ease}
.serving select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
.serving-custom{display:inline-flex;align-items:center;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:0 12px 0 4px;transition:border-color .15s ease,box-shadow .15s ease}
.serving-custom:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
.serving-custom input{width:74px;border:0;background:transparent;outline:none;padding:11px 6px 11px 9px;font-weight:600;font-size:1rem;color:var(--text);font-variant-numeric:tabular-nums;text-align:right}
.serving-custom input::-webkit-outer-spin-button,.serving-custom input::-webkit-inner-spin-button{opacity:1;height:22px}
.serving-custom span{color:var(--muted);font-weight:600;font-size:.9rem}
.facts-tools .btn{padding:11px 16px}

.alt-forms{margin:14px 0 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}
.alt-forms summary{display:flex;align-items:center;gap:8px;padding:12px 16px;font-weight:600;cursor:pointer}
.alt-forms summary .icon{width:18px;height:18px;color:var(--brand)}
.alt-forms-list{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 16px}
.alt-forms-list a{font-size:.86rem;padding:6px 12px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--border);color:var(--text-soft)}
.alt-forms-list a:hover{border-color:var(--brand)}
.alt-forms-list a.current{background:var(--brand);color:var(--on-brand);border-color:var(--brand)}

.macro-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.macro-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.macro-card:hover{transform:translateY(-2px);border-color:var(--brand-weak);box-shadow:var(--shadow)}
.macro-card:first-child{background:linear-gradient(135deg,var(--bg-soft),var(--surface))}
.ring{--p:0;--ring-c:var(--brand);width:62px;height:62px;border-radius:50%;background:conic-gradient(var(--ring-c) calc(var(--p)*1%),var(--ring-track) 0);display:grid;place-items:center;position:relative;flex:none}
.ring::before{content:"";position:absolute;inset:7px;border-radius:50%;background:var(--surface)}
.ring.tone-good{--ring-c:var(--tone-good)}
.ring.tone-warn{--ring-c:var(--tone-warn)}
.ring.tone-bad{--ring-c:var(--tone-bad)}
.ring.tone-neutral{--ring-c:var(--tone-neutral)}
.ring.tone-low{--ring-c:var(--tone-low)}
.ring.tone-na{--ring-c:var(--ring-track)}
.ring-pct{position:relative;font-weight:700;font-size:.82rem}
.macro-meta{display:flex;flex-direction:column}
.macro-val{font-family:var(--font-head);font-weight:700;font-size:1.25rem}
.macro-label{color:var(--muted);font-size:.85rem}

.ratio-block{margin-top:30px}
.block-title{font-size:1.15rem;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.block-title .icon{width:20px;height:20px;color:var(--brand)}
.ratio-head{margin-bottom:16px}
.ratio-head .block-title{margin-bottom:6px}
.ratio-sub{color:var(--text-soft);font-size:.95rem;max-width:64ch;line-height:1.5}

.ratio-panel{position:relative;display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:center;
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 34px;overflow:hidden}
.ratio-panel::before{content:"";position:absolute;inset:0;pointer-events:none;
    background:radial-gradient(130% 150% at 0% 0%,color-mix(in srgb,var(--brand-weak) 45%,transparent),transparent 58%)}

.ratio-donut-wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:14px}
.ratio-donut{--size:186px;width:var(--size);height:var(--size);border-radius:50%;position:relative;display:grid;place-items:center;
    filter:drop-shadow(0 12px 26px rgba(16,24,40,.18))}
.ratio-donut-hole{position:absolute;inset:27px;border-radius:50%;background:var(--surface);box-shadow:inset 0 0 0 1px var(--border),inset 0 2px 6px rgba(16,24,40,.08)}
.ratio-donut-center{position:relative;display:flex;flex-direction:column;align-items:center;line-height:1;text-align:center}
.rd-num{font-family:var(--font-head);font-weight:800;font-size:2.1rem;letter-spacing:-.02em;color:var(--text)}
.rd-lbl{margin-top:5px;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.ratio-tag{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;color:var(--brand-strong);
    background:var(--brand-weak);border-radius:999px;padding:5px 12px;white-space:nowrap}
.ratio-tag .icon{width:14px;height:14px}

.ratio-macros{position:relative;z-index:1;display:flex;flex-direction:column;gap:18px;min-width:0}
.rm{display:grid;gap:8px}
.rm-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.rm-key{display:flex;align-items:center;font-weight:600;color:var(--text)}
.rm-pct{font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:var(--text);font-variant-numeric:tabular-nums}
.rm-pct small{font-size:.72em;font-weight:700;color:var(--muted);margin-left:1px}
.rm-track{height:10px;border-radius:999px;background:var(--bg-soft);overflow:hidden;box-shadow:inset 0 0 0 1px var(--border)}
.rm-track span{display:block;height:100%;border-radius:999px;transition:width .5s var(--ease)}
.rm-carb .rm-track span{background:linear-gradient(90deg,var(--carb),color-mix(in srgb,var(--carb) 62%,#fff))}
.rm-fat .rm-track span{background:linear-gradient(90deg,var(--fat),color-mix(in srgb,var(--fat) 62%,#fff))}
.rm-protein .rm-track span{background:linear-gradient(90deg,var(--protein),color-mix(in srgb,var(--protein) 62%,#fff))}
.rm-alcohol .rm-track span{background:linear-gradient(90deg,var(--muted),color-mix(in srgb,var(--muted) 55%,#fff))}
.rm-grams{font-size:.85rem;color:var(--muted)}
.rm-grams b{color:var(--text-soft);font-weight:700}

.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:7px;flex:none}
.dot-carb{background:var(--carb)}.dot-fat{background:var(--fat)}.dot-protein{background:var(--protein)}.dot-alcohol{background:var(--muted)}

@media (max-width:620px){
    .ratio-panel{grid-template-columns:1fr;gap:24px;padding:22px}
    .ratio-donut{--size:168px}
}

.source-block{margin-top:30px}
.source-sub{color:var(--text-soft);font-size:.95rem;margin:6px 0 16px;max-width:74ch;line-height:1.5}
.source-sub b{color:var(--tone-good);font-weight:700}
.source-chips{display:flex;flex-wrap:wrap;gap:10px}
.source-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-weight:600;font-size:.9rem;color:var(--text);transition:transform .15s var(--ease),border-color .15s ease,box-shadow .15s ease}
.source-chip:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.source-chip b{font-family:var(--font-head);font-variant-numeric:tabular-nums;color:var(--text-soft);font-weight:700}
.source-chip .icon{width:15px;height:15px}
.source-chip .tone-dot{width:9px;height:9px}
.source-chip.excellent{border-color:color-mix(in srgb,var(--tone-good) 42%,var(--border));background:color-mix(in srgb,var(--tone-good) 9%,var(--surface))}
.source-chip.excellent .icon,.source-chip.excellent b{color:var(--tone-good)}

/* Dietary suitability + allergen badges (facts page) */
.diet-strip{margin-top:18px}
.diet-badges{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.diet-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-weight:600;font-size:.86rem;line-height:1;color:var(--text)}
.diet-badge .icon{width:14px;height:14px}
a.diet-badge{transition:transform .15s var(--ease),border-color .15s ease,box-shadow .15s ease,background .15s ease}
a.diet-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.diet-badge.fit{border-color:color-mix(in srgb,var(--tone-good) 40%,var(--border));background:color-mix(in srgb,var(--tone-good) 10%,var(--surface));color:color-mix(in srgb,var(--tone-good) 72%,var(--text))}
.diet-badge.fit .icon{color:var(--tone-good)}
a.diet-badge.fit:hover{border-color:var(--tone-good)}
.diet-allergen-label{display:inline-flex;align-items:center;gap:6px;margin-left:6px;font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--tone-warn)}
.diet-allergen-label .icon{width:15px;height:15px}
.diet-badge.allergen{border-color:color-mix(in srgb,var(--tone-warn) 42%,var(--border));background:color-mix(in srgb,var(--tone-warn) 11%,var(--surface));color:color-mix(in srgb,var(--tone-warn) 78%,var(--text));font-size:.84rem;padding:5px 11px}
.diet-note{margin:11px 0 0;max-width:80ch;font-size:.82rem;line-height:1.5;color:var(--text-soft)}

.nutri-breakdown{margin-top:30px}
.nutri-breakdown-head{display:flex;align-items:center;justify-content:space-between;gap:16px 24px;flex-wrap:wrap}
.nutri-breakdown-head .block-title{margin-bottom:0}
.tone-key{display:flex;flex-wrap:wrap;gap:8px 16px;list-style:none;font-size:.84rem;color:var(--text-soft);font-weight:500}
.tone-key li{display:flex;align-items:center;gap:7px}
.tone-dot{width:11px;height:11px;border-radius:50%;flex:none}
.tone-dot.tone-good{background:var(--tone-good)}
.tone-dot.tone-warn{background:var(--tone-warn)}
.tone-dot.tone-bad{background:var(--tone-bad)}
.tone-dot.tone-neutral{background:var(--tone-neutral)}
.tone-key-note{margin-top:8px;max-width:80ch;font-size:.88rem;color:var(--muted);line-height:1.55}
.nutri-grid{margin-top:18px;display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:18px;align-items:start}
.nutri-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease}
.nutri-card:hover{box-shadow:var(--shadow)}
.nutri-table{width:100%;border-collapse:collapse;font-size:.92rem}
.nutri-table thead th{background:var(--bg-soft);text-align:left;font-family:var(--font-head);font-size:.95rem;padding:13px 16px;border-bottom:1px solid var(--border)}
.nutri-table th.nval,.nutri-table td.nval,.nutri-table th.ndv,.nutri-table td.ndv{text-align:right}
.nutri-table th.ndv{width:110px}
.nrow th{font-weight:500;text-align:left;padding:10px 16px;color:var(--text);overflow-wrap:anywhere}
.nrow th .nlink{color:inherit;text-decoration:none;border-bottom:1px dashed var(--border)}
.nrow th .nlink:hover,.nrow th .nlink:focus-visible{color:var(--brand);border-bottom-color:var(--brand)}
.nrow td{padding:10px 16px;vertical-align:middle}
.nrow.t1 th{padding-left:30px;color:var(--text-soft)}
.nrow.t2 th{padding-left:42px;color:var(--text-soft);font-size:.88rem}
.nrow+.nrow th,.nrow+.nrow td{border-top:1px solid var(--border)}
.nrow:hover>th,.nrow:hover>td{background:var(--bg-soft)}
.nval{font-variant-numeric:tabular-nums;white-space:nowrap}
.dvbar{position:relative;height:18px;border-radius:6px;background:var(--bg-soft);overflow:hidden;min-width:80px}
.dvbar span{position:absolute;inset:0;width:0;background:var(--tone-neutral);border-radius:6px;transition:width .4s var(--ease),background-color .25s ease}
.dvbar.tone-good span{background:linear-gradient(90deg,var(--tone-good),color-mix(in srgb,var(--tone-good) 60%,#fff))}
.dvbar.tone-warn span{background:linear-gradient(90deg,var(--tone-warn),color-mix(in srgb,var(--tone-warn) 60%,#fff))}
.dvbar.tone-bad span{background:linear-gradient(90deg,var(--tone-bad),color-mix(in srgb,var(--tone-bad) 60%,#fff))}
.dvbar.tone-neutral span{background:linear-gradient(90deg,var(--tone-neutral),color-mix(in srgb,var(--tone-neutral) 62%,#fff))}
.dvbar.tone-low span{background:var(--tone-low)}
.dvbar b{position:absolute;right:6px;top:0;line-height:18px;font-size:.72rem;font-weight:700;color:var(--text)}
.dash{color:var(--muted)}
.ntoggle td{padding:0}
.more-btn{display:flex;align-items:center;gap:7px;width:100%;padding:11px 16px;color:var(--brand);font-weight:600;font-size:.88rem;border-top:1px solid var(--border)}
.more-btn .icon{width:16px;height:16px}
.more-btn:hover{background:var(--bg-soft)}

.prose{margin-top:40px}
.prose>*{max-width:74ch}
.prose.narrow{max-width:720px}
/* On the food-facts page the About block spans the full section width, like the
   nutrient grid and related sections around it. */
.facts .prose>*{max-width:none}
.prose h2{font-size:1.3rem;margin:22px 0 10px}
.prose p{color:var(--text-soft);margin-bottom:12px}
.prose .src-note{font-size:.84rem;color:var(--muted)}
.src-list{display:flex;flex-direction:column;gap:8px;color:var(--text-soft)}
.src-list a,.prose a{color:var(--brand);font-weight:500}

.faq{margin-top:44px}
.compare-tables+.faq{margin-top:44px}
.cmp-related{margin-top:44px}
.faq h2{font-size:1.3rem;margin-bottom:14px}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px}
.faq-item summary{padding:14px 18px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::after{content:"+";font-size:1.3rem;color:var(--brand)}
.faq-item[open] summary::after{content:"–"}
.faq-item p{padding:0 18px 16px;color:var(--text-soft)}

/* ---- Search ------------------------------------------------------------ */
/* Enriched "foods highest in X" list page (intro + guide link + FAQ) */
.list-intro{margin-block:-4px 6px}
.list-intro-lead{max-width:80ch;color:var(--text-soft);line-height:1.65}
.list-intro .link-more{margin-top:10px}
.list-extra{padding-bottom:56px}
.list-faq{max-width:82ch;margin:10px 0 30px}
.list-faq .block-title{margin-bottom:14px}
.search-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;padding-top:8px;padding-bottom:60px;align-items:start}
/* Grid items default to min-width:auto and refuse to shrink below the result
   table's min-content, blowing the stacked mobile track out to ~478px (page
   scrolled sideways). min-width:0 lets .table-wrap's overflow-x:auto do its
   job instead. */
.search-layout>*{min-width:0}
.search-filters{position:sticky;top:84px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.filter-block{margin-bottom:14px;border-bottom:1px solid var(--border);padding-bottom:14px}
.filter-label{font-weight:600;font-size:.85rem;display:block;margin-bottom:8px}
.filter-block summary{display:flex;align-items:center;gap:8px;font-weight:600;cursor:pointer;font-size:.92rem}
.filter-block summary .icon{width:17px;height:17px;color:var(--brand)}
.filter-options{max-height:280px;overflow:auto;margin-top:12px;display:flex;flex-direction:column;gap:7px;padding-right:6px}
.filter-subhead{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-top:8px;font-weight:700}
.chk{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--text-soft);cursor:pointer}
.chk input{width:17px;height:17px;accent-color:var(--brand)}
.result-note{color:var(--muted);font-size:.84rem;margin-bottom:10px}
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}
.result-table{width:100%;border-collapse:collapse;font-size:.93rem}
.result-table thead th{text-align:left;background:var(--bg-soft);padding:13px 16px;font-family:var(--font-head);font-size:.9rem;border-bottom:1px solid var(--border);white-space:nowrap}
.result-table thead th.num,.result-table td.num{text-align:right;font-variant-numeric:tabular-nums}
.result-table tbody td{padding:11px 16px;border-top:1px solid var(--border)}
.result-table tbody tr:hover{background:var(--bg-soft)}
.rt-name{display:flex;align-items:center;gap:11px}
.rt-name img{width:36px;height:36px;object-fit:contain;flex:none;padding:3px;border-radius:8px;background:var(--bg-soft)}
.rt-name a{font-weight:500}
.rt-name a:hover{color:var(--brand)}
.kc{font-weight:600}
.noresults{text-align:center;color:var(--muted);padding:40px 16px!important}
.pagination{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:24px}
.pg{display:grid;place-items:center;min-width:40px;height:40px;padding:0 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);font-weight:600;font-size:.9rem}
.pg:hover{border-color:var(--brand);color:var(--brand)}
.pg.current{background:var(--brand);color:var(--on-brand);border-color:var(--brand)}
.pg-dots{display:grid;place-items:center;height:40px;color:var(--muted)}

/* ---- Compare ----------------------------------------------------------- */
.compare-picker{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow)}
.cp-field{flex:1;min-width:220px}
.cp-field label{font-size:.8rem;font-weight:600;color:var(--muted);display:block;margin-bottom:6px}
.cp-field .hero-search-input{background:var(--bg-soft);border:1px solid var(--border);border-radius:11px;padding:4px 12px;transition:border-color .15s ease,box-shadow .15s ease}
.cp-field .hero-search-input:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
.cp-vs{display:grid;place-items:center;width:38px;height:38px;flex:none;margin-bottom:4px;border-radius:50%;background:var(--bg-soft);border:1px solid var(--border);font-family:var(--font-head);font-weight:800;font-size:.82rem;color:var(--muted)}
.cp-locked{display:flex;align-items:center;gap:10px;background:var(--brand-weak);border:1px solid color-mix(in srgb,var(--brand) 28%,var(--border));border-radius:11px;padding:9px 10px 9px 11px}
.cp-locked img{width:38px;height:38px;object-fit:contain;flex:none;border-radius:8px;background:var(--surface);padding:3px}
.cp-locked-name{flex:1;min-width:0;font-weight:600;color:var(--brand-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cp-locked-x{display:grid;place-items:center;width:30px;height:30px;flex:none;border-radius:8px;color:var(--brand-strong)}
.cp-locked-x:hover{background:var(--surface)}
.cp-locked-x .icon{width:16px;height:16px}
.compare-suggest,.hero-suggest{margin-top:16px}
.compare-suggest{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--muted);font-size:.9rem}
.compare-suggest a{padding:5px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text-soft)}
.compare-suggest a:hover{border-color:var(--brand);color:var(--brand)}
.vs-pill{font-size:.7em;background:var(--bg-soft);border:1px solid var(--border);padding:2px 10px;border-radius:999px;color:var(--muted);vertical-align:middle}
.page-head h1.cmp-result-title{font-size:clamp(1.4rem,2.5vw,1.95rem);line-height:1.2;gap:8px 12px}
.compare-heads{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.compare-head{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;gap:8px;padding:22px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.compare-head::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 130% at 50% 0,var(--brand-weak),transparent 60%);opacity:0;transition:opacity .2s ease}
.compare-head:hover{transform:translateY(-3px);border-color:var(--brand);box-shadow:var(--shadow)}
.compare-head:hover::before{opacity:.6}
.compare-head>*{position:relative;z-index:1}
.compare-head img{width:60px;height:60px;object-fit:contain}
.ch-name{font-weight:700;font-size:1.02rem}
.ch-cal{display:inline-flex;align-items:center;color:var(--brand-strong);background:var(--brand-weak);font-size:.8rem;font-weight:700;border-radius:999px;padding:3px 11px}
.compare-tables{margin-top:22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:18px;align-items:start;padding-bottom:60px}
.compare-table{width:100%;table-layout:fixed;border-collapse:collapse;font-size:.92rem}
.compare-table th:first-child,.compare-table td:first-child{width:42%}
.compare-table thead th{background:var(--bg-soft);padding:12px 14px;font-family:var(--font-head);font-size:.86rem;border-bottom:1px solid var(--border);text-align:right}
.compare-table thead th:first-child{text-align:left}
.compare-table thead th .cmp-th-name{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.compare-table th[scope=row]{font-weight:500;text-align:left;padding:9px 14px;color:var(--text-soft)}
.compare-table td{padding:9px 14px;text-align:right;font-variant-numeric:tabular-nums}
.compare-table tbody tr+tr th,.compare-table tbody tr+tr td{border-top:1px solid var(--border)}
.compare-table tbody tr:hover th,.compare-table tbody tr:hover td{background:var(--bg-soft)}
.compare-table td.more{font-weight:700;color:var(--brand-strong);background:var(--brand-weak);box-shadow:inset 2px 0 0 var(--brand)}
.compare-table tr.t1 th{padding-left:24px;font-size:.88rem}

/* ---- Comparison verdict / summary ------------------------------------- */
.muted{color:var(--muted)}
.cmp-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-top:22px}
.cmp-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;text-align:center;transition:border-color .15s ease,box-shadow .15s ease}
.cmp-stat:hover{box-shadow:var(--shadow)}
.cs-label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.cs-vals{display:flex;justify-content:center;gap:10px;font-variant-numeric:tabular-nums}
.cs-v{flex:1;font-size:.92rem;font-weight:600;color:var(--text-soft);padding:4px 2px;border-radius:8px}
.cs-v.win{color:var(--brand-strong);font-weight:800;background:var(--brand-weak)}
.cmp-verdict{margin-top:18px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px}
.cmp-verdict h2{display:flex;align-items:center;gap:8px;font-size:1.05rem;margin-bottom:10px}
.cmp-verdict h2 .icon{width:20px;height:20px;color:var(--brand)}
.cmp-verdict ul{list-style:none;display:grid;gap:8px}
.cmp-verdict li{position:relative;padding-left:20px;color:var(--text-soft)}
.cmp-verdict li::before{content:"";position:absolute;left:4px;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--brand)}
.compare-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:16px;padding-bottom:10px}
.compare-grid a{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 16px;font-size:.92rem;font-weight:500;color:var(--text-soft);transition:border-color .15s,transform .15s}
.compare-grid a:hover{border-color:var(--brand);transform:translateY(-1px)}
.compare-grid .cg-a,.compare-grid .cg-b{flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}
.compare-grid .cg-b{text-align:right}
.compare-grid .cg-vs{font-family:var(--font-head);font-weight:800;font-size:.72rem;color:var(--muted);flex:none}

/* ---- Top foods / glossary --------------------------------------------- */
.topfoods{padding-bottom:60px}
.topfoods-block{margin-bottom:26px}
.topfoods-block h2{font-size:1.2rem;margin-bottom:12px}
.tag-cloud{display:flex;flex-wrap:wrap;gap:9px;align-items:center}
.tag{padding:8px 15px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:.9rem;font-weight:500;color:var(--text-soft)}
.tag:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.tag-pair{display:inline-flex;align-items:stretch}
.tag-pair .tag-l{border-top-right-radius:0;border-bottom-right-radius:0}
.tag-pair .tag-g{display:inline-grid;place-items:center;padding:0 11px;border-left:0;border-top-left-radius:0;border-bottom-left-radius:0;color:var(--text-soft)}
.tag-pair .tag-g .icon{width:16px;height:16px}
.tag-pair .tag-g:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.topfoods-guide-note{display:flex;align-items:center;gap:8px;margin-top:14px;color:var(--text-soft);font-size:.95rem}
.topfoods-guide-note .icon{width:18px;height:18px;flex:none;color:var(--brand)}
.topfoods-guide-note a{color:var(--brand);font-weight:600}
.glossary-filter{max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:2px 16px;margin-bottom:18px}
.glossary-az{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:26px;position:sticky;top:64px;z-index:5;background:var(--bg);padding:8px 0}
.glossary-az a{display:inline-grid;place-items:center;min-width:32px;height:32px;padding:0 6px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-weight:600;font-size:.9rem;color:var(--text-soft)}
.glossary-az a:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.glossary-section{margin-bottom:30px;scroll-margin-top:120px}
.glossary-letter{font-size:1.4rem;color:var(--brand-strong);margin-bottom:14px;padding-bottom:6px;border-bottom:2px solid var(--border)}
.glossary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.glossary-card{display:flex;flex-direction:column;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .15s,transform .15s,box-shadow .15s}
.glossary-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}
.glossary-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.glossary-card h3{font-size:1.08rem;color:var(--brand-strong);margin:0}
.glossary-dv{flex:none;font-size:.78rem;font-weight:600;color:var(--text-soft);background:var(--brand-weak);border-radius:999px;padding:2px 9px;white-space:nowrap}
.glossary-card p{color:var(--text-soft);font-size:.92rem;line-height:1.5;margin:0;flex:1 1 auto}
.glossary-more{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:600;color:var(--brand);text-transform:capitalize}
.glossary-more .icon{width:15px;height:15px;transition:transform .15s}
.glossary-card:hover .glossary-more .icon{transform:translateX(3px)}

/* ---- Forms / alerts ---------------------------------------------------- */
.narrow{max-width:640px}
.field{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.field label{font-weight:600;font-size:.9rem}
.field input,.field textarea{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}
.field input:focus,.field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
.contact-form{padding-bottom:60px}
.alert{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:10px;margin-bottom:18px;font-weight:500}
.alert-success{background:var(--brand-weak);color:var(--brand-strong)}

/* ---- Nutrition label --------------------------------------------------- */
.nutrition-label{max-width:380px;margin:0 auto;background:#fff;color:#000;border:2px solid #000;border-radius:6px;padding:10px 14px;font-family:'Helvetica Neue',Arial,sans-serif}
.nl-title{font-family:var(--font-head);font-size:2rem;font-weight:800;line-height:1;border-bottom:1px solid #000;padding-bottom:4px}
.nl-serv{font-size:.9rem;padding:4px 0}
.nl-rule-thick{height:9px;background:#000;margin:2px 0}
.nl-rule-mid{height:4px;background:#000;margin:2px 0}
.nl-cal{display:flex;justify-content:space-between;align-items:flex-end;font-weight:800}
.nl-cal span:first-child{font-size:1.1rem}
.nl-cal-n{font-size:2rem;line-height:1}
.nl-dv{text-align:right;font-size:.8rem;font-weight:700;padding:3px 0;border-bottom:1px solid #000}
.nl-row{display:flex;justify-content:space-between;font-size:.9rem;padding:3px 0;border-bottom:1px solid #c8c8c8}
.nl-bold{font-weight:400}
.nl-indent{padding-left:18px}
.nl-micro{font-size:.86rem}
.nl-p{font-weight:700}
.nl-foot{font-size:.68rem;color:#222;padding-top:6px;line-height:1.4}

/* ---- Meal / recipe calculator ----------------------------------------- */
.meal-app{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start;margin-top:18px}
.meal-add{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.meal-add-label{display:block;font-weight:600;margin-bottom:10px}
.meal-add .hero-search-input{background:var(--bg-soft);border:1px solid var(--border);border-radius:999px;padding:10px 16px}
.meal-quick{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:14px;color:var(--muted);font-size:.88rem}
.chip{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);font-size:.86rem;font-weight:500;transition:border-color .15s,color .15s,background .15s}
.chip:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.chip .icon{width:14px;height:14px}
.btn-text{display:inline-flex;align-items:center;gap:6px;color:var(--text-soft);font-weight:600;font-size:.88rem;padding:6px 8px;border-radius:8px}
.btn-text:hover{color:var(--brand);background:var(--bg-soft)}
.btn-text .icon{width:16px;height:16px}
.meal-items{margin-top:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.meal-items-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--bg-soft)}
.meal-items-head h2{font-size:1.05rem}
.meal-list{display:flex;flex-direction:column}
.meal-item{display:flex;align-items:center;gap:12px;padding:12px 18px}
.meal-item+.meal-item{border-top:1px solid var(--border)}
.meal-item img{border-radius:8px;flex:none}
.mi-main{display:flex;flex-direction:column;min-width:0;flex:1}
.mi-name{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mi-name:hover{color:var(--brand)}
.mi-cal{font-size:.82rem;color:var(--muted);font-variant-numeric:tabular-nums}
.mi-amount{display:flex;align-items:center;gap:6px;flex:none}
.mi-amount input[type=number]{width:74px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft);color:var(--text);font-variant-numeric:tabular-nums;text-align:right}
.mi-amount input:focus{outline:none;border-color:var(--brand)}
.mi-unit{color:var(--muted);font-size:.85rem}
.mi-amount select{max-width:120px;padding:8px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft);color:var(--text-soft);font-size:.82rem}
.mi-remove{width:34px;height:34px;border-radius:9px}
.mi-remove .icon{width:16px;height:16px}
.meal-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:48px 24px;margin-top:18px;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-soft)}
.meal-empty-icon{display:grid;place-items:center;width:54px;height:54px;border-radius:14px;background:var(--brand-weak);color:var(--brand-strong)}
.meal-empty-icon .icon{width:26px;height:26px}
.meal-empty p{max-width:380px}
.meal-totals{position:sticky;top:84px;display:flex;flex-direction:column;gap:14px}
.meal-cal-card{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.meal-cal-card::before{content:"";position:absolute;inset:0;background:radial-gradient(85% 130% at 100% 0,var(--brand-weak),transparent 55%);opacity:.7;pointer-events:none}
.meal-cal-card>*{position:relative;z-index:1}
.meal-cal-num{font-family:var(--font-head);font-weight:800;font-size:2.6rem;line-height:1;display:flex;align-items:baseline;gap:8px;color:var(--text)}
.meal-cal-num small{font-size:1rem;font-weight:600;color:var(--muted)}
.meal-cal-sub{color:var(--text-soft);font-size:.9rem;margin-top:6px}
.macro-ratio{display:flex;height:12px;border-radius:999px;overflow:hidden;margin-top:16px;background:var(--bg-soft)}
.macro-ratio span{display:block;height:100%;transition:width .25s ease}
.mr-carb{background:var(--carb)}.mr-fat{background:var(--fat)}.mr-prot{background:var(--protein)}
.macro-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px;font-size:.85rem;color:var(--text-soft)}
.macro-legend span{display:inline-flex;align-items:center;gap:6px}
.macro-legend i{width:10px;height:10px;border-radius:3px;display:inline-block}
.macro-legend b{color:var(--text);font-variant-numeric:tabular-nums}
.meal-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}
.meal-actions .more-btn{width:auto;border-top:none;padding:8px 10px}
.meal-table .meal-sec th{background:var(--bg-soft);font-family:var(--font-head);font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:9px 16px;border-top:1px solid var(--border)}
.meal-table-wrap .meal-table .nrow.t2{display:none}
.meal-table-wrap.show-detail .meal-table .nrow.t2{display:table-row}
.meal-note{font-size:.8rem;color:var(--muted)}
.meal-prose{max-width:820px}
.meal-prose ol{margin:0 0 12px 20px;color:var(--text-soft)}
.meal-prose ol li{margin-bottom:8px}

/* ---- Calorie / nutrient calculator ------------------------------------- */
.calc-app{display:grid;grid-template-columns:.95fr 1.05fr;gap:24px;align-items:start;margin-top:18px}
.calc-form{padding:22px}
.calc-form-title{font-size:1.15rem;margin-bottom:16px}
.calc-seg{border:0;padding:0;margin:0 0 16px}
.calc-seg legend{font-weight:600;font-size:.9rem;margin-bottom:8px;padding:0}
.calc-seg{display:flex;flex-wrap:wrap;gap:8px}
.calc-seg legend{flex:0 0 100%}
.seg-opt{position:relative;flex:1 1 auto;min-width:90px}
.seg-opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.seg-opt span{display:block;text-align:center;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:.9rem;font-weight:500;color:var(--text-soft);transition:border-color .15s,background .15s,color .15s}
.seg-opt input:not(:checked):hover+span{border-color:var(--border-strong);background:var(--bg-soft);color:var(--text)}
.seg-opt input:checked+span{border-color:var(--brand);background:var(--brand-weak);color:var(--brand-strong);font-weight:600}
.seg-opt input:focus-visible+span{outline:2px solid var(--brand);outline-offset:2px}
.calc-seg-goal .seg-opt{min-width:110px}
.calc-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.calc-form .field input,.calc-form select{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;outline:none;width:100%;transition:border-color .15s ease,box-shadow .15s ease}
.calc-form .field input:focus,.calc-form select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
.calc-result{padding:24px}
.calc-result-label{font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;margin-bottom:6px}
.calc-result .meal-cal-sub em{color:var(--muted);font-style:normal}
.calc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.calc-stat{display:flex;flex-direction:column;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.calc-stat:hover{transform:translateY(-2px);border-color:var(--brand-weak);box-shadow:var(--shadow)}
.calc-stat-ico{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--brand-weak);color:var(--brand-strong);margin-bottom:6px}
.calc-stat-ico .icon{width:18px;height:18px}
.calc-stat b{font-family:var(--font-head);font-size:1.25rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.calc-stat small{color:var(--text-soft);font-size:.78rem;line-height:1.3}
.calc-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:48px 24px;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-soft);height:100%;justify-content:center}
.calc-empty p{max-width:380px}
.calc-error .meal-empty-icon{background:#fde8e6;color:#c0392b}
:root[data-theme="dark"] .calc-error .meal-empty-icon{background:#3a1f1d;color:#f87171}
.calc-dv{margin-top:48px}
.calc-dv .section-title{margin-bottom:10px}
.calc-dv-intro{color:var(--text-soft);max-width:760px;margin-bottom:18px}
.calc-dv-card .nutri-table td.nval{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}
.calc-dv-card .nutri-table th.ndv,.calc-dv-card .nutri-table td.ndv{width:90px;text-align:right}
.calc-dv-link{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--border);color:var(--text-soft);transition:border-color .15s,color .15s,background .15s}
.calc-dv-link:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.calc-dv-link .icon{width:16px;height:16px}
.calc-formula{background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;font-size:.92rem}
.calc-formula code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text)}
.calc-formula span{color:var(--muted);font-size:.85rem}

/* ---- Footer ------------------------------------------------------------ */
.site-footer{position:relative;background:var(--bg-soft);border-top:1px solid var(--border);margin-top:64px}
.footer-accent{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),var(--accent))}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1fr;gap:30px;padding-top:52px;padding-bottom:28px}
.footer-brand p{color:var(--text-soft);font-size:.92rem;margin:14px 0 16px;max-width:300px}
.footer-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.footer-badge{display:inline-flex;align-items:center;gap:6px;font-size:.76rem;font-weight:500;color:var(--text-soft);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:5px 11px}
.footer-badge .icon{width:13px;height:13px;color:var(--brand)}
.socials{display:flex;gap:10px}
.socials a{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);transition:color .15s ease,border-color .15s ease,background .15s ease,transform .15s ease}
.socials a:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-weak);transform:translateY(-2px)}
.footer-col h3{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:14px}
.footer-col a{display:block;padding:5px 0;color:var(--text-soft);font-size:.93rem;transition:color .15s ease,transform .15s ease}
.footer-col a:hover{color:var(--brand);transform:translateX(3px)}
.footer-popular{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:18px 20px;border-top:1px solid var(--border);font-size:.88rem}
.footer-popular>span{font-weight:600;color:var(--text-soft)}
.footer-popular a{background:var(--surface);border:1px solid var(--border);padding:5px 12px;border-radius:999px;color:var(--text-soft);font-weight:500;transition:border-color .15s ease,color .15s ease,background .15s ease}
.footer-popular a:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-weak)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:18px 20px;border-top:1px solid var(--border);color:var(--muted);font-size:.84rem}
.footer-bottom a{color:var(--text-soft)}
.footer-bottom a:hover{color:var(--brand)}
.footer-top{display:inline-flex;align-items:center;gap:7px;font-size:.84rem;font-weight:600;color:var(--text-soft);border:1px solid var(--border);background:var(--surface);border-radius:999px;padding:7px 14px;transition:color .15s ease,border-color .15s ease,transform .15s ease}
.footer-top:hover{color:var(--brand);border-color:var(--brand);transform:translateY(-2px)}
.footer-top .icon{width:15px;height:15px}

/* ---- Custom select caret (applies to every styled dropdown) ------------ */
.hero-search-field select,.serving select,.calc-form select,.mi-amount select,.field select,.search-filters select{
    -webkit-appearance:none;-moz-appearance:none;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a93a0' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 11px center;padding-right:36px;cursor:pointer;
}
.mi-amount select{background-position:right 8px center;padding-right:28px}

/* ---- Responsive -------------------------------------------------------- */
@media (max-width:860px){
    .search-layout{grid-template-columns:1fr}
    .search-filters{position:static}
    .macro-strip{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:repeat(4,1fr)}
    .footer-brand{grid-column:1/-1;max-width:none}
    .footer-brand p{max-width:520px}
    .facts-tools{width:100%}
    .meal-app{grid-template-columns:1fr}
    .meal-totals{position:static}
    .calc-app{grid-template-columns:1fr}
}
@media (max-width:560px){
    .section{padding:42px 0}
    .macro-strip{grid-template-columns:1fr 1fr;gap:10px}
    /* Let the 2-up macro cards shrink so a wide value (e.g. "211 kcal") can't push the grid off-screen. */
    .macro-card{padding:13px;gap:10px;min-width:0}
    .macro-card .ring{width:54px;height:54px}
    .macro-meta{min-width:0}
    .macro-val{font-size:1.05rem}
    .compare-heads{gap:8px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:22px 24px}
    .cta-banner{padding:26px 22px}
    .calc-grid3{grid-template-columns:1fr}
    .calc-stats{grid-template-columns:1fr 1fr}
    /* Tighten nutrient tables so long names never overflow a narrow card. */
    .nutri-table thead th{padding-left:13px;padding-right:13px}
    .nrow th,.nrow td{padding-left:13px;padding-right:13px}
    .nrow.t1 th{padding-left:24px}
    .nrow.t2 th{padding-left:34px}
    .nutri-table th.ndv,.nutri-table td.ndv{width:88px}
    .dvbar{min-width:60px}
}

/* ---- Motion / print ---------------------------------------------------- */
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
@media print{
    .site-header,.site-footer,.facts-tools,.breadcrumb,.alt-forms,.faq,.cta-banner,.ac-results,.mobile-nav,.cmdk{display:none!important}
    body{background:#fff;color:#000}
    .nutrition-label{border-color:#000}
}

/* ======================================================================
   Site pages — About / Contact / Privacy / Terms  (Run 36)
   ===================================================================== */
.page-head .eyebrow{margin-bottom:14px}

/* About ---------------------------------------------------------------- */
.about-stats{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.about-stats li{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center;transition:transform .15s var(--ease),border-color .15s ease,box-shadow .15s ease}
.about-stats li:hover{transform:translateY(-2px);border-color:var(--brand-weak);box-shadow:var(--shadow)}
.about-stats b{display:block;font-family:var(--font-head);font-size:1.85rem;font-weight:800;color:var(--brand-strong);letter-spacing:-.02em}
.about-stats span{display:block;margin-top:4px;font-size:.86rem;color:var(--muted)}
.about-section{margin-top:46px}
.section-sub{color:var(--text-soft);max-width:70ch;margin:-4px 0 18px;line-height:1.55}
.about-section .feature-grid{margin-top:4px}
.data-sources{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.data-source{display:flex;align-items:center;gap:14px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .15s var(--ease),border-color .15s ease,box-shadow .15s ease}
.data-source:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:var(--shadow)}
.data-source-ic{flex:none;display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--brand-weak);color:var(--brand-strong)}
.data-source-ic .icon{width:20px;height:20px}
.data-source-tx{display:flex;flex-direction:column;gap:2px;min-width:0}
.data-source-tx b{color:var(--text);font-size:.98rem}
.data-source-tx span{color:var(--muted);font-size:.86rem;line-height:1.4}
.data-source-arr{flex:none;width:18px;height:18px;color:var(--muted);margin-left:auto;transition:transform .15s ease,color .15s ease}
.data-source:hover .data-source-arr{color:var(--brand);transform:translateX(3px)}
.check-list{list-style:none;display:flex;flex-direction:column;gap:12px;padding:0}
.check-list li{position:relative;padding-left:30px;color:var(--text-soft);line-height:1.55;max-width:74ch}
.check-list li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:var(--brand-weak);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2315a34a' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.callout{display:flex;gap:14px;align-items:flex-start;padding:20px 22px;border-radius:var(--radius);border:1px solid var(--border);
    background:linear-gradient(120deg,color-mix(in srgb,var(--brand-weak) 40%,var(--surface)),var(--surface));margin-top:30px}
.callout .icon{flex:none;width:22px;height:22px;color:var(--brand-strong);margin-top:1px}
.callout p{color:var(--text-soft);line-height:1.6;margin:0}
.callout b{color:var(--text)}
.about-cta{margin-top:46px;margin-bottom:10px}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-on-brand{background:transparent!important;color:#fff!important;border:1px solid rgba(255,255,255,.55)}
.btn-on-brand:hover{background:rgba(255,255,255,.14)!important;transform:translateY(-2px)}

/* Contact -------------------------------------------------------------- */
.contact-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start;margin-top:8px;margin-bottom:60px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.contact-form.card h2{font-size:1.25rem;margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form .btn{margin-top:4px}
.contact-form .btn .icon{width:16px;height:16px}
.form-note{margin-top:14px;font-size:.85rem;color:var(--muted)}
.contact-aside{display:flex;flex-direction:column;gap:16px}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.contact-card h3{font-size:1.02rem;margin-bottom:14px}
.contact-points{list-style:none;display:flex;flex-direction:column;gap:14px;padding:0}
.contact-points li{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--text-soft);line-height:1.5}
.contact-points .icon{flex:none;width:18px;height:18px;color:var(--brand);margin-top:2px}
.contact-points b{color:var(--text);font-weight:600}
.contact-links{display:flex;flex-direction:column;gap:4px}
.contact-links a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;color:var(--text-soft);font-weight:500;font-size:.92rem;transition:background .15s ease,color .15s ease}
.contact-links a:hover{background:var(--bg-soft);color:var(--brand)}
.contact-links a .icon{flex:none;width:16px;height:16px;color:var(--brand)}
.contact-links a .icon:last-child{margin-left:auto;color:var(--muted)}

/* Legal pages (Privacy / Terms) --------------------------------------- */
.legal-updated{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-size:.85rem;font-weight:600;color:var(--text-soft);
    background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 13px}
.legal-updated .icon{width:14px;height:14px;color:var(--brand)}
.legal-layout{display:grid;grid-template-columns:240px 1fr;gap:40px;align-items:start;margin-top:34px;margin-bottom:64px}
.legal-toc{position:sticky;top:calc(var(--header-h) + 18px)}
.legal-toc-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}
.legal-toc nav{display:flex;flex-direction:column;gap:1px;border-left:2px solid var(--border)}
.legal-toc a{padding:7px 0 7px 14px;margin-left:-2px;border-left:2px solid transparent;color:var(--text-soft);font-size:.9rem;line-height:1.35;transition:color .15s ease,border-color .15s ease}
.legal-toc a:hover{color:var(--brand);border-left-color:var(--brand)}
.legal-content{margin-top:0;max-width:760px}
.legal-content>.legal-section:first-child{margin-top:0}
.legal-section{margin-top:34px;scroll-margin-top:calc(var(--header-h) + 20px)}
.legal-section h2{font-size:1.3rem;margin-bottom:12px;padding-bottom:0}
.legal-section h3{font-size:1.02rem;margin:18px 0 6px;color:var(--text)}
.legal-content p,.legal-content li{color:var(--text-soft);line-height:1.65}
.legal-content p{margin-bottom:12px;max-width:none}
.legal-content ul{margin:0 0 14px;padding-left:20px;display:flex;flex-direction:column;gap:7px}
.legal-content code{background:var(--bg-soft);border:1px solid var(--border);border-radius:6px;padding:1px 6px;font-size:.86em}

/* Favorites ----------------------------------------------------------- */
.fav-link{position:relative}
.fav-badge{position:absolute;top:-3px;right:-3px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;
    background:var(--brand);color:var(--on-brand);font-size:.66rem;font-weight:800;line-height:17px;text-align:center;
    box-shadow:0 0 0 2px var(--surface);font-variant-numeric:tabular-nums}
.fav-btn .icon{transition:fill .15s ease,transform .15s ease}
.fav-btn.is-fav{color:var(--brand-strong);border-color:var(--brand);background:var(--brand-weak)}
.fav-btn.is-fav .icon{fill:currentColor;transform:scale(1.08)}
.fav-page{margin-top:8px;margin-bottom:60px}
.fav-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.fav-summary{font-weight:600;color:var(--text-soft)}
.fav-toolbar .btn .icon{width:15px;height:15px}
.fav-card{position:relative}
.fav-card-link{padding-right:46px}
.fav-card-x{position:absolute;top:50%;right:8px;transform:translateY(-50%);display:grid;place-items:center;
    width:30px;height:30px;border-radius:8px;color:var(--muted);background:transparent;cursor:pointer;
    transition:background .15s ease,color .15s ease}
.fav-card-x:hover{background:var(--bg-soft);color:var(--tone-bad)}
.fav-card-x .icon{width:16px;height:16px}
.fav-empty{text-align:center;max-width:460px;margin:40px auto;padding:40px 24px;border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--surface)}
.fav-empty-ic{display:grid;place-items:center;width:60px;height:60px;margin:0 auto 16px;border-radius:50%;background:var(--brand-weak);color:var(--brand-strong)}
.fav-empty-ic .icon{width:26px;height:26px}
.fav-empty h2{font-size:1.25rem;margin-bottom:8px}
.fav-empty p{color:var(--text-soft);line-height:1.55;margin-bottom:18px}
.fav-empty-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* Best-foods-for landing pages -------------------------------------- */
.bf-block{margin-top:30px}
.bf-block .section-sub{margin:6px 0 0}
.bf-foods{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;margin-top:18px}
.bf-food{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px 12px 12px;transition:transform .15s var(--ease),border-color .15s ease,box-shadow .15s ease}
.bf-food:hover{transform:translateY(-2px);border-color:var(--brand-weak);box-shadow:var(--shadow)}
.bf-rank{flex:none;display:grid;place-items:center;width:30px;height:30px;border-radius:9px;background:var(--bg-soft);color:var(--text-soft);font-family:var(--font-head);font-weight:800;font-size:.95rem}
.bf-food:nth-child(-n+3) .bf-rank{background:var(--brand-weak);color:var(--brand-strong)}
.bf-food-link{display:flex;align-items:center;gap:13px;flex:1;min-width:0}
.bf-food-link img{width:48px;height:48px;flex:none;object-fit:contain;padding:5px;border-radius:11px;background:var(--bg-soft)}
.bf-food-tx{display:flex;flex-direction:column;gap:2px;min-width:0}
.bf-food-tx b{font-size:.98rem;color:var(--text);line-height:1.25}
.bf-food-tx small{font-size:.84rem;color:var(--muted);line-height:1.35}
.bf-food-link:hover b{color:var(--brand)}
.bf-metric{flex:none;display:flex;flex-direction:column;align-items:flex-end;text-align:right;line-height:1.15;min-width:62px}
.bf-metric b{font-family:var(--font-head);font-weight:800;font-size:1.1rem;color:var(--text);font-variant-numeric:tabular-nums}
.bf-metric small{font-size:.73rem;color:var(--muted);font-weight:600}
.bf-note{display:flex;align-items:flex-start;gap:8px;margin-top:16px;font-size:.84rem;color:var(--muted);line-height:1.5;max-width:80ch}
.bf-note .icon{flex:none;width:15px;height:15px;margin-top:2px}
.bf-related{margin-top:44px}
.bf-goal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}
.bf-goal-card{display:flex;align-items:center;gap:13px;padding:15px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .15s var(--ease),border-color .15s ease,box-shadow .15s ease}
.bf-goal-card:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:var(--shadow)}
.bf-goal-ic{flex:none;display:grid;place-items:center;width:40px;height:40px;border-radius:11px;background:var(--brand-weak);color:var(--brand-strong)}
.bf-goal-ic .icon{width:19px;height:19px}
.bf-goal-tx{display:flex;flex-direction:column;min-width:0}
.bf-goal-tx b{font-size:.94rem}
.bf-goal-tx small{font-size:.8rem;color:var(--muted)}
.bf-goal-arr{flex:none;width:17px;height:17px;color:var(--muted);margin-left:auto;transition:transform .15s ease,color .15s ease}
.bf-goal-card:hover .bf-goal-arr{color:var(--brand);transform:translateX(3px)}
.bf-hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin-top:8px}
.bf-hub-card{display:flex;align-items:flex-start;gap:15px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .16s var(--ease),border-color .16s ease,box-shadow .16s ease}
.bf-hub-card:hover{transform:translateY(-3px);border-color:var(--brand);box-shadow:var(--shadow)}
.bf-hub-ic{flex:none;display:grid;place-items:center;width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;box-shadow:0 6px 16px -8px color-mix(in srgb,var(--brand) 70%,transparent)}
.bf-hub-ic .icon{width:22px;height:22px}
.bf-hub-tx{display:flex;flex-direction:column;gap:4px;min-width:0}
.bf-hub-tx b{font-size:1.05rem}
.bf-hub-tx small{font-size:.88rem;color:var(--text-soft);line-height:1.45}
.bf-hub-arr{flex:none;width:18px;height:18px;color:var(--muted);margin-left:auto;margin-top:4px;transition:transform .15s ease,color .15s ease}
.bf-hub-card:hover .bf-hub-arr{color:var(--brand);transform:translateX(3px)}
@media (max-width:560px){
    .bf-food{padding:10px 12px;gap:11px}
    .bf-food-link{gap:11px}
    .bf-food-link img{width:42px;height:42px}
    .bf-rank{width:26px;height:26px;font-size:.85rem}
}

/* Nutrient-density score (Batch 4) ------------------------------------ */
.nutri-score-block{margin-top:24px}
.nutri-score{display:flex;align-items:center;gap:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 26px;position:relative;overflow:hidden}
.nutri-score.tone-good{--ns-c:var(--tone-good)}
.nutri-score.tone-warn{--ns-c:var(--tone-warn)}
.nutri-score.tone-bad{--ns-c:var(--tone-bad)}
.nutri-score::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(130% 150% at 0 0,color-mix(in srgb,var(--ns-c) 14%,transparent),transparent 58%)}
.ns-dial.ring{width:92px;height:92px;flex:none;position:relative;z-index:1}
.ns-dial.ring::before{inset:9px}
.ns-num{position:relative;font-family:var(--font-head);font-weight:800;font-size:1.85rem;color:var(--text);letter-spacing:-.02em}
.ns-tx{position:relative;z-index:1;min-width:0}
.ns-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:1.05rem;color:var(--text-soft)}
.ns-head .icon{width:18px;height:18px;color:var(--ns-c)}
.ns-head b{color:var(--text);font-family:var(--font-head)}
.ns-badge{font-size:.76rem;font-weight:700;color:var(--ns-c);background:color-mix(in srgb,var(--ns-c) 14%,var(--surface));border-radius:999px;padding:3px 10px}
.ns-desc{margin-top:7px;font-size:.9rem;color:var(--muted);line-height:1.55;max-width:78ch}
.ns-desc a{color:var(--brand);font-weight:600}
.ns-meter{height:8px;border-radius:999px;background:var(--bg-soft);overflow:hidden;margin-top:12px;max-width:360px}
.ns-meter span{display:block;height:100%;border-radius:999px;background:var(--ns-c)}
.bf-score b{font-size:1.35rem}
.bf-score.tone-good b{color:var(--tone-good)}
.bf-score.tone-warn b{color:var(--tone-warn)}
.bf-score.tone-bad b{color:var(--tone-bad)}
.bf-score small{font-weight:600}
@media (max-width:560px){
    .nutri-score{flex-direction:column;align-items:flex-start;gap:16px;padding:20px}
    .ns-meter{max-width:none;width:100%}
}

/* Daily food diary ---------------------------------------------------- */
.diary-app{margin-top:8px;margin-bottom:52px}
.diary-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.diary-nav{flex:none;width:38px;height:38px}
.diary-nav[data-diary-prev] .icon{transform:rotate(180deg)}
.diary-date{display:flex;flex-direction:column;line-height:1.2;min-width:128px;text-align:center}
.diary-date b{font-family:var(--font-head);font-size:1.15rem}
.diary-date small{font-size:.78rem;color:var(--muted)}
.diary-today{margin-left:6px;padding:9px 14px}
.diary-today .icon{width:15px;height:15px;transform:scaleX(-1)}
.diary-bar-spacer{flex:1 1 auto}
.diary-clear{color:var(--muted)}
.diary-clear:hover{color:var(--tone-bad)}
.diary-io{color:var(--muted)}
.diary-io:hover{color:var(--brand)}
.diary-io .icon{width:15px;height:15px}
/* Nutrient-gap chips: link the day's lowest beneficial nutrients to their lists */
.diary-gaps{margin:6px 0 24px;padding:18px 20px}
.diary-gaps-head h2{font-size:1.05rem;display:flex;align-items:center;gap:8px}
.diary-gaps-head h2 .icon{width:18px;height:18px;color:var(--brand)}
.diary-gaps-head p{font-size:.88rem;color:var(--muted);margin:4px 0 0}
.diary-gaps-list{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px}
.diary-gap-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:var(--bg-soft);font-size:.9rem;transition:border-color .15s ease,background .15s ease}
.diary-gap-chip:hover{border-color:var(--brand);background:var(--brand-weak)}
.diary-gap-chip .dg-name{font-weight:600}
.diary-gap-chip .dg-pct{color:var(--tone-bad);font-weight:600;font-size:.82rem}
.diary-gap-chip .icon{width:15px;height:15px;color:var(--muted)}
.diary-gaps-none{display:flex;align-items:center;gap:8px;color:var(--tone-good);font-size:.92rem;margin:6px 0 0}
.diary-gaps-none .icon{width:18px;height:18px}
.did-you-mean{margin:12px 0 0;font-size:.98rem}
.did-you-mean a{color:var(--brand);font-weight:600;text-decoration:underline}
.diary-summary{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 28px;margin-bottom:24px}
.diary-cal{display:flex;align-items:center;gap:18px}
.diary-cal .ring{width:98px;height:98px}
.diary-cal .ring::before{inset:11px}
.diary-cal .ring-pct{font-size:1.05rem}
.diary-cal-tx{display:flex;flex-direction:column;gap:3px}
.diary-cal-tx b{font-family:var(--font-head);font-size:1.7rem;font-weight:800;letter-spacing:-.02em;line-height:1}
.diary-cal-tx b small{font-size:.82rem;font-weight:600;color:var(--muted)}
.diary-cal-left{font-size:.86rem;color:var(--text-soft);font-weight:500}
.diary-macros{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.diary-macro{display:flex;flex-direction:column;gap:5px}
.diary-macro-top{display:flex;align-items:baseline;justify-content:space-between;gap:6px;font-size:.82rem;color:var(--text-soft)}
.diary-macro-top b{font-family:var(--font-head);font-size:1.02rem;color:var(--text);font-variant-numeric:tabular-nums}
.diary-macro-bar{height:7px;border-radius:999px;background:var(--bg-soft);overflow:hidden}
.diary-macro-bar span{display:block;height:100%;border-radius:999px;background:var(--brand);transition:width .35s var(--ease)}
.diary-macro[data-macro="203"] .diary-macro-bar span{background:var(--protein)}
.diary-macro[data-macro="205"] .diary-macro-bar span{background:var(--carb)}
.diary-macro[data-macro="204"] .diary-macro-bar span{background:var(--fat)}
.diary-macro[data-macro="291"] .diary-macro-bar span{background:var(--tone-good)}
.diary-macro small{font-size:.72rem;color:var(--muted)}
.diary-meals{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(340px,100%),1fr));gap:16px;margin-bottom:24px}
.diary-meal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;min-width:0}
.diary-meal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.diary-meal-head h2{font-size:1.05rem;display:flex;align-items:center;gap:8px}
.diary-meal-head h2 .icon{width:17px;height:17px;color:var(--brand)}
.diary-meal-cal{font-size:.84rem;color:var(--muted)}
.diary-meal-cal b{color:var(--text);font-family:var(--font-head);font-weight:700}
.diary-meal-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.diary-meal-list:not(:empty){margin-bottom:12px}
.diary-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;background:var(--bg-soft)}
.diary-item img{width:36px;height:36px;flex:none;object-fit:contain;border-radius:8px;background:var(--surface);padding:3px}
.di-main{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.25}
.di-name{font-size:.9rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.di-name:hover{color:var(--brand)}
.di-cal{font-size:.76rem;color:var(--muted)}
.di-amount{flex:none;display:flex;align-items:center;gap:4px}
.di-amount input{width:50px;border:1px solid var(--border);border-radius:8px;padding:5px 6px;background:var(--surface);text-align:right;font-variant-numeric:tabular-nums;font-weight:600;font-size:.85rem;outline:none;color:var(--text)}
.di-amount input:focus{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-weak)}
.di-amount > span{font-size:.78rem;color:var(--muted)}
.di-amount select{max-width:82px;font-size:.76rem;padding:5px 22px 5px 7px;border:1px solid var(--border);border-radius:8px;background-color:var(--surface);color:var(--text-soft);outline:none;-webkit-appearance:none;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a93a0' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center}
.di-remove{flex:none;width:28px;height:28px;color:var(--muted)}
.di-remove:hover{color:var(--tone-bad);background:var(--surface)}
.di-remove .icon{width:15px;height:15px}
.diary-add{position:relative;margin-top:auto}
.diary-add .hero-search-input{background:var(--bg-soft);border:1px solid var(--border);border-radius:11px;padding-left:12px;min-width:0;transition:border-color .15s ease,box-shadow .15s ease}
.diary-add .hero-search-input:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-weak)}
.diary-add .hero-search-input .icon{width:18px;height:18px}
.diary-add .hero-search-input input{padding:10px 4px;font-size:.92rem;background:none}
.diary-quick{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:11px;font-size:.82rem;color:var(--muted)}
.diary-quick .chip{font-size:.8rem;padding:5px 10px}
.diary-totals{margin-top:6px}
.diary-totals-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.diary-totals-head h2{font-size:1.05rem;display:flex;align-items:center;gap:8px}
.diary-totals-head h2 .icon{width:18px;height:18px;color:var(--brand)}
.diary-totals .nutri-table .meal-sec th{background:var(--bg-soft);font-family:var(--font-head);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:9px 16px;border-top:1px solid var(--border)}
.diary-note{display:flex;align-items:flex-start;gap:8px;padding:13px 18px;font-size:.82rem;color:var(--muted);line-height:1.5}
.diary-note .icon{flex:none;width:15px;height:15px;margin-top:2px}
/* Personalized targets (Batch 3) */
.calc-save{margin-top:18px;display:flex;flex-direction:column;align-items:center;gap:10px}
.calc-save .btn .icon{width:16px;height:16px}
.calc-save-note{display:inline-flex;align-items:flex-start;gap:8px;font-size:.88rem;color:var(--text-soft);max-width:46ch;text-align:left}
.calc-save-note .icon{flex:none;width:16px;height:16px;color:var(--brand);margin-top:2px}
.calc-save-note a{color:var(--brand);font-weight:600}
.facts-personal{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px;padding:10px 14px;border-radius:999px;
    background:var(--brand-weak);color:var(--brand-strong);font-size:.88rem;font-weight:500;width:fit-content;max-width:100%}
.facts-personal .icon{flex:none;width:16px;height:16px}
.facts-personal a{color:var(--brand-strong);font-weight:700;text-decoration:underline}
.facts-personal .btn-text{color:var(--brand-strong);opacity:.8;font-size:.84rem}
.facts-personal .btn-text:hover{opacity:1}
.diary-targets{margin-bottom:18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}
.diary-targets.is-custom{border-color:color-mix(in srgb,var(--brand) 45%,var(--border))}
.diary-targets-toggle{display:flex;align-items:center;gap:11px;width:100%;padding:13px 16px;text-align:left}
.diary-targets-toggle > .icon{flex:none;width:18px;height:18px;color:var(--brand)}
.diary-targets-toggle span{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.diary-targets-toggle b{font-size:.96rem}
.diary-targets-toggle small{font-size:.82rem;color:var(--muted)}
.diary-targets.is-custom .diary-targets-toggle b{color:var(--brand-strong)}
.diary-targets-caret{flex:none;width:17px;height:17px;color:var(--muted);margin-left:auto;transition:transform .2s var(--ease)}
.diary-targets.open .diary-targets-caret{transform:rotate(180deg)}
.diary-targets-form{padding:4px 16px 16px;border-top:1px solid var(--border)}
.diary-targets-hint{font-size:.86rem;color:var(--text-soft);margin:12px 0 14px;line-height:1.5}
.diary-targets-hint a{color:var(--brand);font-weight:600}
.diary-targets-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.diary-target-field{display:flex;flex-direction:column;gap:5px;font-size:.82rem;font-weight:600;color:var(--text-soft)}
.tinput{display:flex;align-items:center;gap:4px;background:var(--bg-soft);border:1px solid var(--border);border-radius:9px;padding:0 9px 0 0;transition:border-color .15s ease,box-shadow .15s ease}
.tinput:focus-within{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-weak)}
.tinput input{width:100%;min-width:0;border:0;background:none;outline:none;padding:9px 4px 9px 10px;font-weight:700;font-size:.95rem;color:var(--text);font-variant-numeric:tabular-nums}
.tinput i{font-style:normal;font-size:.78rem;color:var(--muted);font-weight:600}
.diary-targets-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.diary-targets-actions .btn .icon{width:15px;height:15px}
@media (max-width:680px){.diary-targets-grid{grid-template-columns:1fr 1fr 1fr}}

@media (max-width:620px){
    .diary-summary{grid-template-columns:1fr;gap:20px;padding:20px}
    .diary-cal{justify-content:center}
    .diary-macros{grid-template-columns:1fr 1fr}
    .diary-meals{grid-template-columns:minmax(0,1fr)}
    /* Force a clean 2-row diary bar: day-nav (prev/date/next/today) on top,
       actions (clear/export/import) below. Without this the growing spacer
       scattered the buttons across ~6 uneven rows. */
    .diary-bar-spacer{flex-basis:100%;height:0;margin:0}
    .diary-date{flex:1 1 auto}
    .diary-today{margin-left:0}
    .diary-clear{margin-left:0}
}

@media (max-width:860px){
    .legal-layout{grid-template-columns:1fr;gap:8px}
    .legal-toc{position:static;border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;background:var(--surface);margin-bottom:20px}
    .legal-toc nav{border-left:0;display:grid;grid-template-columns:1fr 1fr;gap:2px 18px}
    .legal-toc a{border-left:0;padding:6px 0;margin-left:0}
    .contact-layout{grid-template-columns:1fr}
}
@media (max-width:620px){
    .about-stats{grid-template-columns:1fr 1fr}
    .field-row{grid-template-columns:1fr}
    .card{padding:22px}
    .legal-toc nav{grid-template-columns:1fr}
}
