/* ============================================================================
   KINETIC GLASS — Soft-Glass Neumorphism design system for Hearthyn.
   Self-hosted (CSP-safe): Outfit font + inline-SVG mask icons, no CDN.
   Styles the existing markup vocabulary (family-*, module-head, add-panel,
   check-list, hub-list, bento, sidebar, topbar, bottom-tabs). Replaces the
   legacy app.css / family-app-apple-glass.css / theme.css trio.
   Spec: docs/design-kinetic-glass.md
   ============================================================================ */
@font-face{
  font-family:'Outfit';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('/fonts/outfit-latin.woff2') format('woff2');
}

/* ---------- Tokens ---------- */
:root{
  --surface:#0e131d; --surface-low:#171c26; --surface-c:#1b202a; --surface-high:#252a35; --surface-highest:#303540;
  --ink:#dee2f1; --muted:#c1c6d7; --outline:#8b90a0; --outline-variant:#414755;
  --primary:#ffb0d4; --primary-strong:#e5357f; --on-primary:#52052b;
  --secondary:#55e16b; --on-secondary:#00390f; --tertiary:#ffb3b1; --on-tertiary:#660613; --error:#ffb4ab;
  /* Hearthyn brand default: the logo's pink-magenta accent + a purple second tone (--accent-2)
     so primary actions sweep pink->purple like the heart. --brand-gold echoes the child glow. */
  --accent:#ffb0d4; --accent-strong:#e5357f; --on-accent:#52052b; --accent-2:#9b2fb0; --brand-gold:#ffbf28;
  --glass-bg:rgba(255,255,255,.055); --glass-brd:rgba(255,255,255,.09); --glass-top:rgba(255,255,255,.05);
  --recess-bg:rgba(0,0,0,.20);
  /* per-section identity tints */
  --c-shopping:#4b8eff; --c-chores:#02ad3f; --c-calendar:#d9920a; --c-meals:#e7696a;
  --c-pets:#8b5cf6; --c-pantry:#0ea5e9; --c-house:#0d9488; --c-notices:#19b6a8; --c-admin:#8b90a0;
  --r-card:24px; --r-ctrl:16px; --r-sm:12px; --pad:24px; --gap:20px; --tap:44px; --sidebar-w:264px;
  --shadow-soft:0 10px 30px -12px rgba(0,0,0,.55);
  color-scheme:dark;
}
:root[data-accent=blue]  {--accent:#adc6ff;--accent-strong:#4b8eff;--on-accent:#002e69;}
:root[data-accent=teal]  {--accent:#7ff0e6;--accent-strong:#19b6a8;--on-accent:#00322e;}
:root[data-accent=purple]{--accent:#d6bcff;--accent-strong:#8b5cf6;--on-accent:#2a0e60;}
:root[data-accent=green] {--accent:#73fe84;--accent-strong:#02ad3f;--on-accent:#00390f;}
:root[data-accent=rose]  {--accent:#ffb3c1;--accent-strong:#e11d48;--on-accent:#4d0017;}
:root[data-accent=amber] {--accent:#ffd591;--accent-strong:#d97706;--on-accent:#3a2300;}
:root[data-accent=hearthyn]{--accent:#ffb0d4;--accent-strong:#e5357f;--on-accent:#52052b;--accent-2:#9b2fb0;}
:root[data-theme=light]{
  --surface:#eef1f7; --surface-low:#ffffff; --surface-c:#ffffff; --surface-high:#f4f6fb; --surface-highest:#e8ebf3;
  --ink:#1a1d27; --muted:#4a4f60; --outline:#71778a; --outline-variant:#cfd4e2;
  --glass-bg:rgba(255,255,255,.72); --glass-brd:rgba(20,24,40,.08); --glass-top:rgba(255,255,255,.9);
  --recess-bg:rgba(20,24,40,.05); --shadow-soft:0 12px 30px -14px rgba(20,24,40,.22);
  color-scheme:light;
}
@media (prefers-color-scheme:light){
  :root[data-theme=auto]{
    --surface:#eef1f7; --surface-low:#ffffff; --surface-c:#ffffff; --surface-high:#f4f6fb; --surface-highest:#e8ebf3;
    --ink:#1a1d27; --muted:#4a4f60; --outline:#71778a; --outline-variant:#cfd4e2;
    --glass-bg:rgba(255,255,255,.72); --glass-brd:rgba(20,24,40,.08); --glass-top:rgba(255,255,255,.9);
    --recess-bg:rgba(20,24,40,.05); --shadow-soft:0 12px 30px -14px rgba(20,24,40,.22);
    color-scheme:light;
  }
}
:root[data-density=compact]{--pad:16px; --gap:14px; --r-card:18px; --tap:40px;}

/* ---------- Base ---------- */
*{box-sizing:border-box;}
html,body{margin:0;}
body{background:var(--surface);color:var(--ink);font-family:'Outfit',system-ui,-apple-system,sans-serif;
  font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em;}
p{margin:0;} a{color:inherit;}
button,input,select,textarea{font:inherit;color:inherit;}
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-thumb{background:rgba(140,144,160,.4);border-radius:10px;}
[hidden]{display:none !important;}

/* ---------- Typography helpers (existing classes) ---------- */
.family-headline{font-size:clamp(26px,5vw,34px);line-height:1.1;letter-spacing:-.02em;font-weight:800;}
.family-title{font-size:18px;font-weight:700;}
.family-label,.card-label,.pref-label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.family-callout,.family-body,.meta{color:var(--muted);font-size:14px;}
.status-line{color:var(--muted);font-size:13px;}
.empty{color:var(--muted);}

/* ---------- Surfaces ---------- */
.family-card,.add-panel.family-card,.account-menu.family-card{
  background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-brd);box-shadow:inset 0 1px 1px var(--glass-top),var(--shadow-soft);
  border-radius:var(--r-card);padding:var(--pad);}
.info-box,.project-summary,.calendar-status-grid{background:var(--recess-bg);border-radius:var(--r-ctrl);
  border:1px solid var(--glass-brd);padding:16px;}

/* ---------- App shell ---------- */
#app.family-app{min-height:100dvh;}
.family-sidebar{position:fixed;left:0;top:0;height:100dvh;width:var(--sidebar-w);display:none;flex-direction:column;
  padding:20px 16px;border-right:1px solid var(--glass-brd);
  background:color-mix(in srgb,var(--surface-low) 70%,var(--surface));backdrop-filter:blur(20px);z-index:60;}
.family-sidebar-inner{display:flex;flex-direction:column;height:100%;gap:10px;}
.sidebar-head{display:flex;align-items:center;gap:13px;padding:10px 6px 20px;}
.sidebar-avatar{width:42px;height:42px;flex:none;border-radius:14px;display:grid;place-items:center;font-weight:800;font-size:18px;
  background:linear-gradient(135deg,var(--accent-strong),var(--accent));color:var(--on-accent);}
.sidebar-head-text{flex:1;min-width:0;}
.sidebar-name{font-size:16px;font-weight:800;margin:0;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sidebar-sub{font-size:11px;letter-spacing:.07em;color:var(--muted);opacity:.8;margin:4px 0 0;text-transform:uppercase;}
.family-nav-list-wrap{display:flex;flex-direction:column;gap:4px;overflow-y:auto;flex:1;}
.family-nav-item{display:flex;flex-direction:row;align-items:center;gap:13px;padding:11px 14px;border-radius:14px;border:none;
  background:transparent;color:var(--muted);cursor:pointer;font-weight:600;font-size:15px;text-align:left;width:100%;min-height:0;
  transition:background .16s,color .16s,transform .12s;}
.family-nav-item:hover{color:var(--ink);background:color-mix(in srgb,var(--surface-highest) 50%,transparent);}
.family-nav-item.active,.family-nav-item[aria-current=page]{color:var(--accent);font-weight:700;
  background:color-mix(in srgb,var(--accent-strong) 16%,transparent);
  box-shadow:0 0 18px -6px color-mix(in srgb,var(--accent) 55%,transparent);}
.family-nav-item:active{transform:scale(.98);}
.family-nav-item::before{content:"";width:22px;height:22px;flex:none;background:currentColor;
  -webkit-mask:var(--icon) center/contain no-repeat;mask:var(--icon) center/contain no-repeat;}
.sidebar-footer{display:flex;flex-direction:column;gap:8px;padding:12px 4px 4px;margin-top:6px;border-top:1px solid var(--glass-brd);}
.sidebar-add-member{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border-radius:14px;cursor:pointer;
  font:inherit;font-weight:700;font-size:14px;color:var(--accent);
  background:color-mix(in srgb,var(--surface-highest) 55%,transparent);border:1px solid var(--glass-brd);transition:background .15s,border-color .15s;}
.sidebar-add-member:hover{background:color-mix(in srgb,var(--accent-strong) 16%,transparent);border-color:color-mix(in srgb,var(--accent) 30%,transparent);}
.sidebar-add-member svg{width:18px;height:18px;}
.sidebar-help{display:flex;align-items:center;gap:12px;padding:9px 12px;border:none;background:transparent;color:var(--muted);
  font:inherit;font-size:14px;font-weight:500;cursor:pointer;border-radius:12px;text-align:left;}
.sidebar-help:hover{color:var(--ink);} .sidebar-help svg{width:20px;height:20px;flex:none;}
.sidebar-collapse,.sidebar-close{display:none;}

/* topbar */
.family-topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:12px;
  padding:max(10px,env(safe-area-inset-top)) 18px 10px;min-height:62px;
  background:color-mix(in srgb,var(--surface) 62%,transparent);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--glass-brd);}
.topbar-brand{display:none;}
.topbar-titles{flex:1;min-width:0;}
.topbar-titles .family-title{font-size:22px;font-weight:800;color:var(--accent);}
.topbar-titles .family-callout{display:none;}
.topbar-search{display:none;}
.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto;}
.family-icon-button{width:var(--tap);height:var(--tap);min-width:var(--tap);display:grid;place-items:center;border:none;
  background:transparent;color:var(--muted);cursor:pointer;border-radius:12px;transition:color .15s,transform .12s;}
.family-icon-button:hover{color:var(--accent);} .family-icon-button:active{transform:scale(.94);}
.topbar-avatar{width:42px;height:42px;border-radius:50%;border:1px solid var(--glass-brd);cursor:pointer;
  display:grid;place-items:center;font-weight:700;font-size:13px;
  background:linear-gradient(135deg,var(--accent-strong),var(--accent));color:var(--on-accent);overflow:hidden;}
.topbar-avatar img{width:100%;height:100%;object-fit:cover;}
.account-menu-wrap{position:relative;}
.account-menu{position:absolute;right:0;top:52px;width:220px;padding:8px;z-index:80;}
/* Opaque dropdown — the shared glass background let page content bleed through and made
   the menu hard to read. Override the .family-card glass with a solid elevated surface. */
.account-menu.family-card{background:var(--surface-high);backdrop-filter:none;-webkit-backdrop-filter:none;
  border:1px solid var(--glass-brd);box-shadow:0 18px 50px rgba(0,0,0,.45),0 2px 8px rgba(0,0,0,.3);}
.account-menu-head{padding:8px 10px;border-bottom:1px solid var(--glass-brd);margin-bottom:6px;}
.account-menu-item{display:block;width:100%;text-align:left;padding:11px 12px;border:none;background:transparent;
  color:var(--ink);border-radius:10px;cursor:pointer;font-weight:600;}
.account-menu-item:hover{background:color-mix(in srgb,var(--accent-strong) 18%,transparent);}
.account-menu-item.danger{color:var(--error);}

/* main + views */
.family-shell{min-height:100dvh;}
.family-main{max-width:1400px;margin:0 auto;width:100%;padding:24px 18px 120px;display:flex;flex-direction:column;gap:var(--gap);}
.view{display:none;}
.view.active{display:block;animation:kg-fade .28s ease;}
@keyframes kg-fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.search-results{margin-bottom:16px;}

/* module header — rendered as a clean page hero (matches the mockups: big headline,
   no icon clutter, supporting subtitle) */
.module-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px;}
.module-head>.family-icon-tile{display:none;}
.module-head>div{display:flex;flex-direction:column;gap:6px;}
.module-head .family-headline{font-size:clamp(28px,5vw,40px);font-weight:800;letter-spacing:-.02em;}
.module-head .family-callout{display:block;font-size:15px;color:var(--muted);}
.family-icon-tile{width:46px;height:46px;flex:none;border-radius:14px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent-strong) 22%,transparent);color:var(--accent);}
.family-icon-tile::before{content:"";width:24px;height:24px;background:currentColor;
  -webkit-mask:var(--icon) center/contain no-repeat;mask:var(--icon) center/contain no-repeat;}
/* section identity tints */
.theme-shopping .family-icon-tile{background:color-mix(in srgb,var(--c-shopping) 22%,transparent);color:var(--c-shopping);}
.theme-chores .family-icon-tile{background:color-mix(in srgb,var(--c-chores) 22%,transparent);color:var(--c-chores);}
.theme-calendar .family-icon-tile{background:color-mix(in srgb,var(--c-calendar) 22%,transparent);color:var(--c-calendar);}
.theme-meals .family-icon-tile{background:color-mix(in srgb,var(--c-meals) 22%,transparent);color:var(--c-meals);}
.theme-pets .family-icon-tile{background:color-mix(in srgb,var(--c-pets) 22%,transparent);color:var(--c-pets);}
.theme-maintenance .family-icon-tile{background:color-mix(in srgb,var(--c-house) 22%,transparent);color:var(--c-house);}
.theme-reminders .family-icon-tile{background:color-mix(in srgb,var(--c-notices) 22%,transparent);color:var(--c-notices);}

/* ---------- Home / bento ---------- */
.home-primary{display:flex;flex-direction:column;gap:var(--gap);}
.family-hero-card{padding:4px 2px 8px;}
.family-hero-card .family-headline{font-size:clamp(30px,6vw,46px);}
.hero-brand{display:none;}
.family-bento-grid,.home-bento{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap);}
.family-bento-card{position:relative;overflow:hidden;border-radius:var(--r-card);padding:var(--pad);min-height:140px;cursor:pointer;
  background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-brd);box-shadow:inset 0 1px 1px var(--glass-top),var(--shadow-soft);
  display:flex;flex-direction:column;gap:8px;transition:transform .14s;}
.family-bento-card:active{transform:scale(.97);}
.family-bento-card .family-title{font-size:17px;}
.family-bento-card .family-callout{flex:1;font-size:13px;}
.bento-count{font-size:28px;font-weight:800;letter-spacing:-.02em;color:var(--accent);}
.family-soft-glow{position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;border-radius:50%;
  background:var(--accent-strong);opacity:.10;filter:blur(8px);pointer-events:none;}
.family-bento-card .family-icon-tile{width:42px;height:42px;}

/* ---------- Grids / stacks ---------- */
.family-grid{display:grid;gap:var(--gap);grid-template-columns:1fr;}
.family-grid.two-up{grid-template-columns:1fr;}
.family-stack{display:flex;flex-direction:column;gap:var(--gap);}
.stack,.page-list,.hub-list,.check-list,.admin-list,.calendar-event-list{display:flex;flex-direction:column;gap:12px;}
.project-category-list,.project-summary{display:flex;flex-direction:column;gap:12px;}

/* ---------- Add panel / forms ---------- */
.add-panel{margin-bottom:18px;}
.add-panel summary{cursor:pointer;font-weight:700;list-style:none;display:flex;align-items:center;gap:8px;}
.add-panel summary::-webkit-details-marker{display:none;}
.add-panel summary::before{content:"+";width:26px;height:26px;border-radius:8px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent-strong) 24%,transparent);color:var(--accent);font-weight:800;}
.add-panel[open] summary{margin-bottom:14px;}
.task-form,.stack-form,.hub-form{display:flex;flex-direction:column;gap:12px;margin-top:4px;}
.task-form{flex-flow:row wrap;align-items:center;}
.inline-form{display:flex;gap:12px;flex-wrap:wrap;}
.inline-form>*{flex:1;min-width:140px;}
.money-row{display:flex;gap:12px;} .money-row>*{flex:1;}
.date-field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted);}
input,select,textarea{width:100%;min-height:var(--tap);padding:11px 15px;border-radius:var(--r-ctrl);
  background:var(--recess-bg);border:1px solid rgba(255,255,255,.06);color:var(--ink);font-size:16px;outline:none;
  box-shadow:inset 2px 2px 6px rgba(0,0,0,.30),inset -1px -1px 2px rgba(255,255,255,.04);transition:border .15s,box-shadow .15s;}
textarea{min-height:84px;resize:vertical;line-height:1.5;}
input:focus,select:focus,textarea:focus{border-color:color-mix(in srgb,var(--accent) 60%,transparent);
  box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--accent) 32%,transparent);}
input[type=color]{padding:4px;min-height:46px;}
input[type=file]{padding:10px;box-shadow:none;}
/* native dropdown popup: force readable option colors (the OS popup doesn't inherit the dark theme) */
select{color-scheme:dark;}
:root[data-theme=light] select{color-scheme:light;}
@media (prefers-color-scheme:light){:root[data-theme=auto] select{color-scheme:light;}}
select option,select optgroup{background-color:var(--surface-high);color:var(--ink);}
.photo-picker{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);}
label{font-size:14px;}
button[type=submit],.family-button,.btn,.recipe-primary-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:var(--tap);padding:0 20px;border:none;border-radius:var(--r-ctrl);font-weight:700;cursor:pointer;
  background:linear-gradient(135deg,var(--accent-strong),color-mix(in srgb,var(--accent-strong) 56%,#7b2fb0));color:#fff;box-shadow:0 0 20px -4px color-mix(in srgb,var(--accent) 55%,transparent);
  transition:transform .12s,filter .2s;white-space:nowrap;}
button[type=submit]:hover,.family-button:hover,.btn:hover{filter:brightness(1.06);}
button[type=submit]:active,.family-button:active,.btn:active{transform:scale(.96);}
.family-button.is-muted,.btn.ghost,.sidebar-aux-link{background:var(--glass-bg);color:var(--accent);
  border:1px solid var(--glass-brd);box-shadow:none;}
.form-status,.meta.status-line{font-size:13px;color:var(--muted);}

/* ---------- Lists / rows / items ---------- */
.check-list>*,.page-list>*,.hub-list>*,.admin-list>*,.person,.app-row,.native-empty-card{
  background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);border-radius:var(--r-ctrl);padding:13px 15px;
  display:flex;align-items:center;gap:13px;}
.app-row-main,.rtext{flex:1;min-width:0;} .app-row-main .title,.title{font-weight:600;}
.app-row-main .meta,.native-card-detail{font-size:12px;color:var(--muted);}
.check-list .done,.is-done{opacity:.6;}
.check-list .done .title,.line-through{text-decoration:line-through;}
input[type=checkbox]{width:24px;height:24px;min-height:0;flex:none;accent-color:var(--accent-strong);box-shadow:none;}
.empty,.native-empty-card{justify-content:center;color:var(--muted);text-align:center;}

/* project money strip + summary */
.project-summary{flex-flow:row wrap;gap:6px 18px;align-items:baseline;}
.project-summary strong{font-size:22px;font-weight:800;color:var(--accent);}
.project-money-strip{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);}
.project-money-strip b{color:var(--accent);}

/* ---------- Settings: theme + accent pickers ---------- */
.pref-group{margin-bottom:20px;}
.theme-picker{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;}
.theme-chip{flex:1;min-width:90px;cursor:pointer;}
.theme-chip input{display:none;}
.theme-chip-card{display:flex;flex-direction:column;gap:2px;padding:12px;border-radius:14px;border:1px solid var(--glass-brd);
  background:var(--recess-bg);text-align:center;transition:.15s;}
.theme-chip-card b{font-weight:700;} .theme-chip-card small{font-size:11px;color:var(--muted);}
.theme-chip input:checked+.theme-chip-card{border-color:transparent;
  background:color-mix(in srgb,var(--accent-strong) 22%,transparent);color:var(--accent);}
.accent-picker{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap;}
.accent-swatch{cursor:pointer;} .accent-swatch input{display:none;}
.accent-swatch>span{display:block;width:38px;height:38px;border-radius:50%;border:3px solid transparent;transition:.15s;}
.accent-swatch[data-swatch=blue]>span{background:#4b8eff;} .accent-swatch[data-swatch=teal]>span{background:#19b6a8;}
.accent-swatch[data-swatch=purple]>span{background:#8b5cf6;} .accent-swatch[data-swatch=green]>span{background:#02ad3f;}
.accent-swatch[data-swatch=rose]>span{background:#e11d48;} .accent-swatch[data-swatch=amber]>span{background:#d97706;}
.accent-swatch[data-swatch=hearthyn]>span{background:linear-gradient(135deg,#ff6b35,#e5357f,#9b2fb0);}
.accent-swatch input:checked+span{border-color:var(--ink);transform:scale(1.08);}

/* ---------- KG page components (used by rebuilt renderers) ---------- */
.kg-grid{display:grid;grid-template-columns:1fr;gap:var(--gap);}
.kg-stack{display:flex;flex-direction:column;gap:var(--gap);}
.kg-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;}
.kg-card-head h3{font-size:18px;font-weight:700;}
.kg-rows{display:flex;flex-direction:column;gap:10px;}
.kg-item{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:var(--r-ctrl);
  background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);box-shadow:inset 2px 2px 6px rgba(0,0,0,.22);}
.kg-item input[type=checkbox]{position:absolute;opacity:0;width:24px;height:24px;cursor:pointer;}
.kg-check{width:24px;height:24px;flex:none;border-radius:8px;border:2px solid var(--outline-variant);display:grid;place-items:center;
  color:transparent;position:relative;}
.kg-check::after{content:"";width:13px;height:9px;border-left:2.5px solid currentColor;border-bottom:2.5px solid currentColor;
  transform:rotate(-45deg) translateY(-1px);}
.kg-item input:checked~.kg-check{background:var(--secondary);border-color:var(--secondary);color:var(--on-secondary);}
.kg-item.is-done .kg-item-main strong{text-decoration:line-through;color:var(--muted);}
.kg-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.kg-item-main strong{font-weight:600;} .kg-item-main small{font-size:12px;color:var(--muted);}
/* checkbox is its own tap target; tapping the item body opens the photo instead of completing */
.kg-check-wrap{position:relative;flex:none;width:24px;height:24px;display:inline-grid;place-items:center;cursor:pointer;}
button.kg-item-main{border:none;background:none;font:inherit;color:inherit;text-align:left;align-items:flex-start;cursor:pointer;padding:0;}
button.kg-item-main.has-photo:hover strong{color:var(--accent);}
.kg-del{margin-left:auto;width:32px;height:32px;flex:none;border:none;background:transparent;color:var(--muted);
  border-radius:9px;cursor:pointer;font-size:18px;line-height:1;}
.kg-del:hover{color:var(--error);background:color-mix(in srgb,var(--error) 16%,transparent);}
.kg-pill{padding:5px 11px;border-radius:999px;font-size:12px;font-weight:700;background:var(--surface-highest);color:var(--muted);}
.kg-pill.ok{background:var(--secondary);color:var(--on-secondary);} .kg-pill.warn{background:var(--tertiary);color:var(--on-tertiary);}
.kg-pill.soft{background:var(--surface-highest);color:var(--muted);}
.kg-ring-row{display:flex;align-items:center;gap:18px;}
.kg-ring{width:96px;height:96px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(closest-side,var(--surface-c) 82%,transparent 84%),
  conic-gradient(var(--accent-strong) calc(var(--p,0)*1%),var(--surface-highest) 0);}
.kg-ring span{font-size:22px;font-weight:800;}
.kg-ring-row .meta b{color:var(--ink);font-weight:800;}
@media (min-width:1024px){
  .kg-grid{grid-template-columns:repeat(12,1fr);align-items:stretch;}
  .kg-c3{grid-column:span 3;} .kg-c4{grid-column:span 4;} .kg-c5{grid-column:span 5;} .kg-c6{grid-column:span 6;} .kg-c7{grid-column:span 7;} .kg-c8{grid-column:span 8;} .kg-c12{grid-column:span 12;}
  /* cards fill their (stretched) cell so cards in the same row are equal height */
  .kg-grid>[class*="kg-c"]>.family-card{height:100%;}
  /* opt-out: column hugs its own content instead of stretching to the row height */
  .kg-grid>.kg-self-start{align-self:start;}
  .kg-grid>.kg-self-start>.family-card{height:auto;}
}

/* ---------- KG mockup-fidelity components ---------- */
.kg-hero{margin-bottom:6px;}
.kg-hero h2{font-size:clamp(28px,5vw,44px);line-height:1.05;letter-spacing:-.02em;font-weight:800;}
.kg-hero p{color:var(--muted);font-size:16px;margin-top:8px;max-width:46ch;}
/* big empty state */
.kg-empty-card{min-height:380px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px;position:relative;overflow:hidden;}
.kg-empty-card .glow-a{position:absolute;top:-80px;left:-80px;width:240px;height:240px;border-radius:50%;background:color-mix(in srgb,var(--accent-strong) 18%,transparent);filter:blur(80px);}
.kg-empty-card .glow-b{position:absolute;bottom:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:color-mix(in srgb,var(--secondary) 18%,transparent);filter:blur(80px);}
.kg-empty-circle{position:relative;width:148px;height:148px;border-radius:50%;display:grid;place-items:center;background:var(--surface-c);border:1px solid var(--glass-brd);box-shadow:inset 0 2px 6px rgba(0,0,0,.3);}
.kg-empty-circle svg{width:70px;height:70px;color:color-mix(in srgb,var(--accent) 60%,transparent);}
.kg-float-chip{position:absolute;top:-8px;right:-14px;padding:6px 12px;border-radius:999px;font-weight:700;font-size:12px;background:var(--secondary-container,#02ad3f);color:#fff;}
.kg-empty-card h3{font-size:22px;} .kg-empty-card p{color:var(--muted);max-width:34ch;}
/* quick picks */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.quick-card{display:flex;flex-direction:column;gap:14px;padding:14px;border-radius:var(--r-sm);cursor:pointer;
  background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);box-shadow:inset 2px 2px 6px rgba(0,0,0,.25);transition:border .15s;}
.quick-card:hover{border-color:color-mix(in srgb,var(--accent) 40%,transparent);}
.quick-card .qrow{display:flex;align-items:center;justify-content:space-between;color:var(--muted);}
.quick-card .qadd{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent-strong) 22%,transparent);color:var(--accent);font-weight:800;}
.quick-card strong{font-weight:600;font-size:14px;}
/* big ring */
.kg-ring-lg{width:170px;height:170px;border-radius:50%;display:grid;place-items:center;margin:0 auto;
  background:radial-gradient(closest-side,var(--surface-c) 84%,transparent 86%),
  conic-gradient(var(--accent-strong) calc(var(--p,0)*1%),var(--surface-highest) 0);}
.kg-ring-lg b{font-size:40px;font-weight:800;line-height:1;} .kg-ring-lg b i{font-size:22px;opacity:.5;font-style:normal;}
.kg-ring-lg small{display:block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:4px;}
.kg-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:22px;}
.kg-stat{padding:14px;border-radius:16px;background:var(--recess-bg);box-shadow:inset 2px 2px 6px rgba(0,0,0,.25);}
.kg-stat span{display:block;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);opacity:.7;}
.kg-stat b{font-size:22px;font-weight:800;}
.kg-card-center{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;}
/* do-first header accent bar + urgent pill */
.kg-accentbar{width:8px;height:30px;border-radius:999px;background:var(--tertiary);}
/* crew energy */
.kg-crew{display:flex;flex-direction:column;gap:20px;}
.kg-crew-row{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.kg-avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:14px;flex:none;
  background:linear-gradient(135deg,var(--accent-strong),var(--accent));color:var(--on-accent);border:1px solid var(--glass-brd);position:relative;}
.kg-avatar .on{position:absolute;bottom:-1px;right:-1px;width:13px;height:13px;border-radius:50%;background:var(--secondary);border:2px solid var(--surface);}
.kg-crew-row .who strong{display:block;font-weight:700;} .kg-crew-row .who small{color:var(--muted);font-size:12px;}
.kg-crew-row .pts{text-align:right;} .kg-crew-row .pts b{font-size:18px;color:var(--secondary);font-weight:800;}
.kg-crew-row .pts small{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
/* upcoming row */
.kg-seg{display:flex;gap:6px;background:var(--recess-bg);border-radius:999px;padding:4px;}
.kg-seg button{border:none;background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:13px;padding:6px 14px;border-radius:999px;cursor:pointer;}
.kg-seg button.on{background:color-mix(in srgb,var(--accent-strong) 26%,transparent);color:var(--accent);}
.kg-up-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;}
.kg-up-card{padding:16px;border-radius:18px;background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:8px;}
.kg-up-card .uhead{display:flex;align-items:center;justify-content:space-between;}
.kg-up-card .uchip{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:999px;
  background:color-mix(in srgb,var(--accent-strong) 22%,transparent);color:var(--accent);}
.kg-up-card .udue{font-size:12px;color:var(--muted);} .kg-up-card strong{font-size:15px;}
.kg-up-card .uwho{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;}
.kg-up-card .uwho .kg-avatar{width:26px;height:26px;font-size:11px;}
.kg-btn-soft{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 22px;border:none;border-radius:14px;
  font:inherit;font-weight:700;cursor:pointer;background:var(--accent-strong);color:#fff;box-shadow:0 0 20px -6px color-mix(in srgb,var(--accent) 60%,transparent);}
.kg-btn-soft:active{transform:scale(.96);}

/* ---------- Responsive scaling & overflow safety ---------- */
.kg-grid>*{min-width:0;}
.kg-item-main strong,.kg-up-card strong,.kg-crew-row .who strong,.family-card h3,.family-headline{overflow-wrap:anywhere;}
.family-card img{max-width:100%;height:auto;}
.kg-ring,.kg-ring-lg,.kg-empty-circle,.kg-avatar{flex:none;}
/* Tablet (2-column rich layout): full-width hero/wide cards, paired narrow cards */
@media (min-width:680px) and (max-width:1023px){
  .kg-grid{grid-template-columns:1fr 1fr;grid-auto-flow:dense;}
  .kg-c12,.kg-c8,.kg-c7,.kg-c6,.kg-c5,.kg-c4{grid-column:span 2;}
  .kg-c3{grid-column:span 1;}
}
/* Small phones: tighten spacing + shrink large gauges */
@media (max-width:430px){
  .family-main{padding:18px 14px 110px;}
  .kg-ring-lg{width:150px;height:150px;} .kg-ring-lg b{font-size:34px;}
  .kg-empty-circle{width:128px;height:128px;}
  .quick-grid{grid-template-columns:1fr 1fr;}
  .kg-stats{grid-template-columns:1fr 1fr;}
  .kg-up-grid{grid-template-columns:1fr;}
  .kg-pet-hero{gap:16px;}
  .kg-pet-hero-photo{width:84px;height:84px;border-radius:22px;}
  .kg-pet-hero-copy h3{font-size:21px;}
  .kg-pet-hero-actions{gap:12px 14px;}
  .kg-meal-stats{gap:10px;}
}
/* Guard against sideways scroll without breaking sticky ancestors */
.family-main{overflow-x:clip;}
/* Home panels are now clickable; show it. Chore rows get an edit affordance next to delete. */
#home [data-view]{cursor:pointer;}
.kg-up-card[data-edit-chore]{cursor:pointer;}
.kg-up-card[data-edit-chore]:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--glass-brd));}
.kg-item .kg-item-main{flex:1 1 auto;min-width:0;}
.kg-chore-edit{flex:0 0 auto;width:30px;height:30px;border:none;border-radius:9px;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s;}
.kg-chore-edit:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);}
.chore-edit-form label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--muted);}
.chore-edit-form .edit-actions{display:flex;gap:10px;margin-top:6px;}
.chore-edit-form .edit-actions button{flex:1;}

/* ---------- FAB + Add modal ---------- */
.kg-fab{position:fixed;right:20px;bottom:92px;width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;z-index:48;
  background:linear-gradient(135deg,var(--accent-strong),color-mix(in srgb,var(--accent-strong) 56%,#7b2fb0));color:#fff;display:grid;place-items:center;
  box-shadow:0 10px 26px -6px color-mix(in srgb,var(--accent) 70%,transparent),0 4px 12px rgba(0,0,0,.45);transition:transform .14s;}
.kg-fab:hover{transform:scale(1.07);} .kg-fab:active{transform:scale(.94);}
.kg-fab svg{width:28px;height:28px;stroke:currentColor;stroke-width:2.6;fill:none;stroke-linecap:round;}
.kg-fab[hidden]{display:none;}
@media (min-width:1024px){.kg-fab{bottom:32px;right:32px;}}
.kg-modal-overlay{position:fixed;inset:0;z-index:95;display:grid;place-items:center;padding:18px;
  background:rgba(4,7,12,.6);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);}
.kg-modal-overlay[hidden]{display:none;}
body.kg-modal-open{overflow:hidden;}
.kg-modal{width:min(560px,100%);max-height:88dvh;overflow:auto;border-radius:var(--r-card);padding:var(--pad);
  background:var(--surface-c);border:1px solid var(--glass-brd);box-shadow:0 30px 70px -20px rgba(0,0,0,.75);animation:kg-pop .2s ease;}
@keyframes kg-pop{from{opacity:0;transform:translateY(14px) scale(.98);}to{opacity:1;transform:none;}}
/* ---------- Toasts + confirm/alert dialogs (replace the native browser popups) ---------- */
.kg-toast-wrap{position:fixed;z-index:200;left:50%;transform:translateX(-50%);
  bottom:calc(20px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:10px;
  width:min(420px,calc(100vw - 28px));pointer-events:none;}
@media (min-width:1024px){.kg-toast-wrap{left:auto;right:24px;transform:none;align-items:flex-end;}}
.kg-toast{pointer-events:auto;display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:16px;width:100%;
  background:var(--surface-c);border:1px solid var(--glass-brd);box-shadow:0 18px 44px -16px rgba(0,0,0,.7);
  color:var(--ink);font-size:14px;font-weight:600;line-height:1.4;
  opacity:0;transform:translateY(14px);transition:opacity .24s ease,transform .24s ease;}
.kg-toast.in{opacity:1;transform:none;}
.kg-toast.out{opacity:0;transform:translateY(8px);}
.kg-toast-msg{flex:1;min-width:0;overflow-wrap:anywhere;}
.kg-toast-ico{width:9px;height:9px;flex:none;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent);}
.kg-toast-error .kg-toast-ico{background:#ff5c7a;box-shadow:0 0 0 4px color-mix(in srgb,#ff5c7a 24%,transparent);}
.kg-toast-success .kg-toast-ico{background:#34c759;box-shadow:0 0 0 4px color-mix(in srgb,#34c759 24%,transparent);}
.kg-toast-x{flex:none;border:none;background:transparent;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:2px 5px;border-radius:8px;}
.kg-toast-x:hover{color:var(--ink);}
.kg-dialog-overlay{position:fixed;inset:0;z-index:210;display:grid;place-items:center;padding:20px;
  background:rgba(4,7,12,.62);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  opacity:0;transition:opacity .18s ease;}
.kg-dialog-overlay.in{opacity:1;}
body.kg-dialog-open{overflow:hidden;}
.kg-dialog{width:min(400px,100%);border-radius:22px;padding:24px;background:var(--surface-c);border:1px solid var(--glass-brd);
  box-shadow:0 30px 70px -20px rgba(0,0,0,.78);transform:translateY(14px) scale(.97);transition:transform .2s ease;text-align:center;}
.kg-dialog-overlay.in .kg-dialog{transform:none;}
.kg-dialog-title{font-size:18px;font-weight:800;letter-spacing:-.01em;margin-bottom:8px;}
.kg-dialog-msg{color:var(--muted);font-size:14.5px;line-height:1.5;overflow-wrap:anywhere;white-space:pre-wrap;}
.kg-dialog-actions{display:flex;gap:10px;margin-top:22px;}
.kg-dialog-actions>button{flex:1;min-width:0;justify-content:center;text-align:center;}
.kg-dialog-input{width:100%;margin-top:16px;padding:12px 14px;border-radius:12px;border:1px solid var(--glass-brd);
  background:var(--recess-bg);color:var(--ink);font:inherit;font-size:16px;text-align:left;}
.kg-dialog-input:focus{outline:none;border-color:color-mix(in srgb,var(--accent) 55%,transparent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent);}
.kg-dialog-ok.is-danger{background:linear-gradient(135deg,#ff5c7a,#e5325a);color:#fff;border:none;}
@media (max-width:560px){.kg-dialog-actions{flex-direction:column-reverse;}}
.kg-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px;}
.kg-modal-head h3{font-size:21px;font-weight:800;letter-spacing:-.01em;}
.kg-modal-head .meta{margin-top:3px;}
.kg-modal-close{width:38px;height:38px;flex:none;border:none;background:var(--recess-bg);color:var(--muted);border-radius:11px;cursor:pointer;font-size:20px;line-height:1;}
.kg-modal-close:hover{color:var(--ink);}
.kg-modal-body{display:flex;flex-direction:column;gap:14px;}
/* the form inside the modal: it's normally inside a (hidden) add-panel; show it plainly here */
.kg-modal-body .task-form,.kg-modal-body .stack-form,.kg-modal-body .hub-form{margin:0;}
/* Hide the collapsible dropdown add-panel on pages that use the FAB+modal instead */
#chores>.add-panel,#shopping>.add-panel,#pantry>.add-panel,#meals>.add-panel,#pets>.add-panel{display:none;}
/* Pantry */
.kg-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;border-radius:var(--r-ctrl);margin-bottom:20px;
  background:color-mix(in srgb,var(--accent-strong) 13%,var(--glass-bg));border:1px solid color-mix(in srgb,var(--accent) 22%,var(--glass-brd));}
.kg-banner>div{display:flex;align-items:center;gap:12px;min-width:0;}
.kg-banner svg{width:22px;height:22px;flex:none;color:var(--accent);}
.kg-pan-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap;}
.kg-pan-head h3{font-size:20px;font-weight:700;}
.kg-tabs{display:flex;gap:8px;flex-wrap:wrap;}
.kg-tabs button{border:1px solid var(--glass-brd);background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:13px;padding:7px 15px;border-radius:999px;cursor:pointer;}
.kg-tabs button.on{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,transparent);background:color-mix(in srgb,var(--accent-strong) 14%,transparent);}
.kg-pan-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:16px;background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);}
.kg-pan-row+.kg-pan-row{margin-top:12px;}
.kg-pan-row.is-low{border-color:color-mix(in srgb,var(--tertiary) 28%,transparent);}
.kg-pan-left{display:flex;align-items:center;gap:14px;min-width:0;}
.kg-pan-ico{width:48px;height:48px;flex:none;border-radius:14px;border:none;cursor:pointer;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent-strong) 18%,transparent);color:var(--accent);}
.kg-pan-ico.low{background:color-mix(in srgb,var(--tertiary) 22%,transparent);color:var(--tertiary);}
.kg-pan-ico svg{width:24px;height:24px;}
.kg-pan-name{min-width:0;} .kg-pan-name strong{display:block;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;} .kg-pan-name small{display:block;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.kg-pan-right{display:flex;align-items:center;gap:14px;flex:none;}
.kg-pan-level{width:90px;height:7px;border-radius:999px;background:var(--surface-highest);overflow:hidden;flex:none;}
.kg-pan-level span{display:block;height:100%;border-radius:999px;}
.kg-stepper{display:flex;align-items:center;gap:6px;flex:none;background:var(--surface-c);border:1px solid var(--glass-brd);border-radius:999px;padding:4px 6px;}
.kg-stepper button{width:30px;height:30px;border:none;border-radius:50%;background:var(--surface-high);color:var(--ink);cursor:pointer;font-size:17px;font-weight:700;display:grid;place-items:center;line-height:1;}
.kg-stepper button:hover{background:color-mix(in srgb,var(--accent-strong) 28%,transparent);color:var(--accent);}
.kg-stepper strong{min-width:42px;text-align:center;font-weight:700;font-size:13px;}
/* Pantry: tiled product cards with auto-loaded catalog photos */
.kg-pan-card{padding:14px;}
.kg-pan-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:12px;}
.kg-pan-empty{grid-column:1/-1;}
.kg-pan-tile{position:relative;display:flex;flex-direction:column;border-radius:16px;background:var(--recess-bg);border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:border-color .15s,transform .15s;}
.kg-pan-tile:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 30%,var(--glass-brd));}
.kg-pan-tile.is-low{border-color:color-mix(in srgb,var(--tertiary) 34%,transparent);}
.kg-pan-thumb{position:relative;display:block;width:100%;aspect-ratio:1/1;border:none;cursor:pointer;background:var(--surface-high);overflow:hidden;}
/* absolute so the photo fills a fixed square and can NEVER stretch the tile to its own shape */
.kg-pan-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.kg-pan-thumb-ico{position:absolute;inset:0;display:grid;place-items:center;color:var(--accent-strong);}
.kg-pan-thumb-ico svg{width:42%;height:42%;}
.kg-pan-thumb .kg-pan-ico-badge{position:absolute;top:8px;left:8px;width:18px;height:18px;border-radius:50%;background:var(--accent-strong);color:var(--accent-ink,#fff);font-size:11px;font-weight:800;display:grid;place-items:center;font-family:Georgia,serif;font-style:italic;border:2px solid #fff;}
.kg-pan-lowpill{position:absolute;left:8px;bottom:8px;}
.kg-pan-del{position:absolute;top:8px;right:8px;z-index:2;width:26px;height:26px;border:none;border-radius:50%;cursor:pointer;background:rgba(8,10,14,.55);color:#fff;font-size:18px;line-height:1;display:grid;place-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);}
.kg-pan-del:hover{background:color-mix(in srgb,var(--accent-strong) 88%,#000);}
.kg-pan-tile-body{display:flex;flex-direction:column;gap:9px;padding:11px 12px 13px;}
.kg-pan-tile .kg-pan-name{min-width:0;}
.kg-pan-tile .kg-pan-name strong{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:14px;line-height:1.25;min-height:2.5em;}
.kg-pan-tile .kg-pan-name small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px;}
.kg-pan-tile .kg-pan-level{display:block;width:100%;}
.kg-pan-tile .kg-stepper{align-self:flex-start;}
@media (max-width:560px){.kg-pan-tiles{grid-template-columns:repeat(auto-fill,minmax(144px,1fr));gap:10px;}.kg-pan-tile-body{padding:9px 10px 11px;gap:8px;}}
.kg-pan-size{font-size:11px;color:var(--muted);font-weight:600;margin-top:-3px;}
/* Shopping — aisle-grouped pantry-style tiles */
.kg-shop-bar{margin-bottom:16px;padding:16px 18px;border-radius:18px;background:var(--recess-bg);border:1px solid var(--glass-brd);}
.kg-shop-bar-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.kg-shop-bar-head h3{margin:0;font-size:20px;}
.kg-shop-progress{height:9px;border-radius:999px;background:var(--surface-high);overflow:hidden;margin-top:12px;}
.kg-shop-progress>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-strong));transition:width .25s;}
.kg-shop-tabs{margin-bottom:18px;}
.kg-shop-aisle{margin-bottom:22px;}
.kg-shop-aisle-head{display:flex;align-items:center;gap:9px;margin:0 0 11px;}
.kg-shop-aisle-head h4{margin:0;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.kg-shop-aisle-ico{font-size:17px;line-height:1;}
.kg-shop-tile{position:relative;display:flex;align-items:center;gap:12px;padding:12px 13px;border-radius:16px;background:var(--recess-bg);border:1px solid rgba(255,255,255,.06);transition:border-color .15s,transform .15s,opacity .15s;}
.kg-shop-tile:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 30%,var(--glass-brd));}
.kg-shop-tile.is-done{opacity:.5;}
.kg-shop-tile.is-done .kg-shop-tile-body strong{text-decoration:line-through;}
.kg-shop-check{position:relative;flex:0 0 auto;width:26px;height:26px;cursor:pointer;}
.kg-shop-check input{position:absolute;inset:0;opacity:0;cursor:pointer;margin:0;}
.kg-shop-tick{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;border:2px solid color-mix(in srgb,var(--accent) 45%,var(--glass-brd));background:transparent;transition:background .15s,border-color .15s;}
.kg-shop-tick::after{content:"";width:11px;height:6px;border-left:2.5px solid var(--accent-ink,#fff);border-bottom:2.5px solid var(--accent-ink,#fff);transform:rotate(-45deg) translateY(-1px) scale(0);transition:transform .15s;}
.kg-shop-check input:checked+.kg-shop-tick{background:var(--accent-strong);border-color:var(--accent-strong);}
.kg-shop-check input:checked+.kg-shop-tick::after{transform:rotate(-45deg) translateY(-1px) scale(1);}
.kg-shop-tile-thumb{flex:0 0 auto;width:42px;height:42px;border-radius:11px;border:none;padding:0;overflow:hidden;cursor:pointer;background:var(--surface-high);}
.kg-shop-tile-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.kg-shop-tile-body{min-width:0;flex:1 1 auto;display:flex;flex-direction:column;gap:2px;}
.kg-shop-tile-body strong{font-size:14px;line-height:1.25;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.kg-shop-tile-body small{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.kg-shop-x{flex:0 0 auto;width:24px;height:24px;border:none;border-radius:50%;cursor:pointer;background:transparent;color:var(--muted);font-size:18px;line-height:1;display:grid;place-items:center;transition:background .15s,color .15s;}
.kg-shop-x:hover{background:color-mix(in srgb,var(--tertiary) 22%,transparent);color:var(--ink);}
.kg-pan-onhand{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:1px;}
.kg-pan-onhand .meta{font-size:10px;text-transform:uppercase;letter-spacing:.07em;font-weight:700;}
.kg-pan-onhand .kg-stepper strong{min-width:26px;}
.pantry-usage-head{font-size:13px;font-weight:700;margin:14px 0 6px;}
.pantry-usage-log{list-style:none;display:flex;flex-direction:column;gap:6px;}
.pantry-usage-log li{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;padding:7px 11px;border-radius:10px;background:var(--recess-bg);}
.pantry-usage-empty{margin-top:8px;}
.pantry-count-fields{display:flex;gap:10px;flex-wrap:wrap;}
.pantry-count-fields label{flex:1 1 110px;display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted);}
.pantry-count-fields input{width:100%;}
.kg-alert-ico{color:var(--error);flex:none;display:grid;place-items:center;} .kg-alert-ico svg{width:22px;height:22px;}
@media (max-width:600px){
  .kg-pan-level{display:none;}
  /* Stack: full-width name on top, controls (incl. Low stock) on their own row,
     so the item name is never squeezed off by the right-side cluster. */
  .kg-pan-row{flex-wrap:wrap;gap:10px 12px;}
  .kg-pan-left{flex:1 1 100%;}
  .kg-pan-right{flex:1 1 100%;justify-content:flex-end;gap:12px;}
}
/* Already Grabbed (simple struck list) + small helpers */
.kg-grabbed-list{display:flex;flex-direction:column;gap:13px;}
.kg-grabbed{display:flex;align-items:center;gap:12px;color:var(--muted);}
.kg-grabbed>span:last-child{text-decoration:line-through;}
.kg-grabbed-check{width:22px;height:22px;flex:none;border-radius:6px;display:grid;place-items:center;background:var(--secondary);color:var(--on-secondary);}
.kg-grabbed-check svg{width:14px;height:14px;stroke:currentColor;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.kg-link{border:none;background:transparent;color:var(--accent);font:inherit;font-weight:700;font-size:13px;cursor:pointer;}
.quick-card .qico{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.kg-pill.accent{background:var(--accent-strong);color:#fff;}

/* ---------- Meals ---------- */
.kg-eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;}
.kg-btn-primary{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:52px;border:none;border-radius:18px;cursor:pointer;
  font:inherit;font-weight:700;font-size:16px;background:var(--accent-strong);color:#fff;box-shadow:0 10px 26px -10px color-mix(in srgb,var(--accent) 70%,transparent);}
.kg-btn-primary:active{transform:scale(.97);}
.kg-btn-dashed{width:100%;margin-top:18px;padding:13px;border:1px dashed var(--outline-variant);border-radius:16px;background:transparent;
  color:var(--muted);font:inherit;font-weight:600;font-size:13px;cursor:pointer;}
.kg-btn-dashed:hover{border-color:color-mix(in srgb,var(--accent) 45%,transparent);color:var(--accent);}
.kg-cal-nav{display:flex;gap:8px;align-items:center;}
.kg-cal-nav button{height:40px;min-width:40px;padding:0 12px;display:grid;place-items:center;border-radius:13px;cursor:pointer;
  background:var(--glass-bg);border:1px solid var(--glass-brd);color:var(--ink);font:inherit;font-weight:600;font-size:13px;}
.kg-cal-nav button svg{width:20px;height:20px;}
.kg-cal-nav .kg-cal-today-btn{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 25%,transparent);background:color-mix(in srgb,var(--accent-strong) 12%,transparent);}
.kg-cal-card{padding:0;overflow:hidden;border-radius:18px;}
.kg-cal-dow{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border-bottom:1px solid var(--glass-brd);background:color-mix(in srgb,var(--surface-high) 55%,transparent);}
.kg-cal-dow span{padding:12px 0;text-align:center;font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--muted);}
/* minmax(0,1fr) + min-width:0/overflow on the cell stop a nowrap event chip from forcing its
   column wider (the bug that made events bleed into the next day). */
.kg-cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));}
.kg-cal-cell{position:relative;min-width:0;overflow:hidden;min-height:112px;padding:8px 9px 9px;display:flex;flex-direction:column;gap:5px;
  border-right:1px solid color-mix(in srgb,var(--glass-brd) 55%,transparent);border-bottom:1px solid color-mix(in srgb,var(--glass-brd) 55%,transparent);transition:background .15s;}
.kg-cal-cell:nth-child(7n){border-right:none;}
.kg-cal-cell:not(.out):hover{background:color-mix(in srgb,var(--accent) 5%,transparent);}
.kg-cal-cell.out{opacity:.26;}
.kg-cal-cell.today{background:color-mix(in srgb,var(--accent-strong) 8%,transparent);}
.kg-cal-top{display:flex;align-items:center;justify-content:space-between;gap:6px;min-height:22px;}
.kg-cal-num{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;font-size:12px;font-weight:700;color:var(--ink);}
.kg-cal-cell.today .kg-cal-num{background:var(--accent-strong);color:var(--accent-ink,#fff);}
.kg-cal-today{font-size:9px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);}
.kg-cal-add{margin-top:auto;width:100%;height:34px;border:1px dashed var(--outline-variant);border-radius:11px;background:var(--surface-high);
  color:var(--muted);cursor:pointer;display:grid;place-items:center;opacity:.5;transition:opacity .15s,border-color .15s;}
.kg-cal-cell:hover .kg-cal-add{opacity:1;border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--accent);}
.kg-cal-add svg{width:16px;height:16px;}
.kg-meal-chip{margin-top:auto;display:block;width:100%;text-align:left;padding:6px 8px;border-radius:10px;cursor:pointer;font:inherit;
  font-size:11px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);background:color-mix(in srgb,var(--accent-strong) 16%,transparent);color:var(--accent);}
.kg-meal-chip+.kg-meal-chip{margin-top:5px;}
.kg-meal-chip.k0{border-color:color-mix(in srgb,var(--tertiary) 24%,transparent);background:color-mix(in srgb,var(--tertiary) 16%,transparent);color:var(--tertiary);}
.kg-meal-chip.k1{border-color:color-mix(in srgb,var(--secondary) 24%,transparent);background:color-mix(in srgb,var(--secondary) 16%,transparent);color:var(--secondary);}
.kg-meal-chip.k2{box-shadow:0 0 14px -4px color-mix(in srgb,var(--accent) 60%,transparent);}
/* ---------- Meals: weekly planner (replaces the month grid) ---------- */
.kg-week-card{padding:0;overflow:hidden;}
.kg-week-day{display:flex;gap:14px;padding:13px 16px;border-bottom:1px solid var(--glass-brd);}
.kg-week-day:last-child{border-bottom:none;}
.kg-week-day.is-today{background:color-mix(in srgb,var(--accent-strong) 7%,transparent);}
.kg-week-daycol{flex:0 0 52px;display:flex;flex-direction:column;align-items:center;gap:1px;padding-top:3px;}
.kg-week-dname{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.kg-week-dnum{font-size:20px;font-weight:800;color:var(--ink);line-height:1;}
.kg-week-day.is-today .kg-week-dnum{color:var(--accent);}
.kg-week-today{font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);margin-top:2px;}
.kg-week-meals{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px;}
.kg-week-meal{display:flex;align-items:center;gap:8px;}
.kg-week-meal-open{flex:1;min-width:0;display:flex;align-items:center;gap:11px;text-align:left;padding:8px 10px;border-radius:13px;cursor:pointer;font:inherit;
  border:1px solid var(--glass-brd);background:color-mix(in srgb,var(--accent) 7%,var(--surface-high));color:var(--ink);transition:filter .12s;}
.kg-week-meal-open:hover{filter:brightness(1.05);}
.kg-week-meal-thumb{flex:none;width:38px;height:38px;border-radius:10px;overflow:hidden;background:var(--recess-bg);display:grid;place-items:center;}
.kg-week-meal-thumb img{width:100%;height:100%;object-fit:cover;}
.kg-week-meal-thumb .kg-thumb-mark{font-weight:800;color:var(--accent);}
.kg-week-meal-copy{min-width:0;display:flex;flex-direction:column;gap:1px;}
.kg-week-meal-copy strong{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.kg-week-meal-copy small{font-size:11px;color:var(--muted);}
.kg-week-meal-x{flex:none;width:30px;height:30px;border-radius:9px;border:1px solid var(--glass-brd);background:var(--surface-high);color:var(--muted);font-size:18px;line-height:1;cursor:pointer;}
.kg-week-meal-x:hover{color:var(--error);border-color:color-mix(in srgb,var(--error) 32%,transparent);}
.kg-week-add{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;padding:7px 12px;border-radius:11px;cursor:pointer;font:inherit;font-size:13px;font-weight:600;
  border:1px dashed color-mix(in srgb,var(--accent) 34%,var(--glass-brd));background:transparent;color:var(--muted);transition:color .12s,border-color .12s;}
.kg-week-add:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 55%,transparent);}
.kg-week-add svg{width:15px;height:15px;}
.kg-meal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px;}
.kg-meal-stat{display:flex;align-items:center;gap:14px;}
.kg-meal-stat-ico{width:46px;height:46px;flex:none;border-radius:50%;display:grid;place-items:center;}
.kg-meal-stat-ico svg{width:22px;height:22px;}
.kg-meal-stat-ico.ok{background:color-mix(in srgb,var(--secondary) 14%,transparent);color:var(--secondary);}
.kg-meal-stat-ico.accent{background:color-mix(in srgb,var(--accent-strong) 16%,transparent);color:var(--accent);}
.kg-meal-stat-ico.warn{background:color-mix(in srgb,var(--tertiary) 16%,transparent);color:var(--tertiary);}
.kg-meal-stat small{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);}
.kg-meal-stat b{font-size:22px;font-weight:700;}
.kg-tonight{position:relative;overflow:hidden;}
.kg-tonight-media{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3;margin-bottom:18px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-strong) 45%,var(--surface-c)),var(--surface-c));}
.kg-tonight-media img,.kg-thumb-mark{width:100%;height:100%;object-fit:cover;display:block;}
.kg-thumb-mark{display:grid;place-items:center;font-size:34px;font-weight:800;color:var(--accent);background:linear-gradient(135deg,color-mix(in srgb,var(--accent-strong) 30%,var(--surface-c)),var(--surface-c));}
.kg-tonight-cap{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;padding:16px;
  background:linear-gradient(to top,rgba(0,0,0,.82),transparent 65%);}
.kg-tonight-cap .kg-pill{align-self:flex-start;}
.kg-tonight-cap strong{font-size:20px;font-weight:700;color:#fff;line-height:1.15;}
.kg-tonight-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-size:14px;margin-bottom:16px;}
.kg-tonight-empty{display:flex;flex-direction:column;gap:14px;align-items:flex-start;color:var(--muted);}
.kg-idea-list{display:flex;flex-direction:column;gap:8px;}
.kg-idea-row{display:flex;align-items:center;gap:8px;border-radius:18px;padding:6px;}
.kg-idea-row:hover{background:rgba(255,255,255,.04);}
.kg-idea-open{flex:1;min-width:0;display:flex;align-items:center;gap:14px;border:none;background:transparent;cursor:pointer;font:inherit;text-align:left;padding:6px;}
.kg-idea-thumb{width:60px;height:60px;flex:none;border-radius:14px;overflow:hidden;border:1px solid var(--glass-brd);background:var(--surface-high);}
.kg-idea-thumb img,.kg-idea-thumb .kg-thumb-mark{width:100%;height:100%;object-fit:cover;}
.kg-idea-thumb .kg-thumb-mark{font-size:22px;}
.kg-idea-copy{min-width:0;}
.kg-idea-copy strong{display:block;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.kg-idea-copy small{color:var(--muted);font-size:12px;}
.kg-idea-add{width:38px;height:38px;flex:none;border-radius:12px;border:1px solid var(--glass-brd);background:var(--surface-high);color:var(--muted);cursor:pointer;display:grid;place-items:center;}
.kg-idea-add:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);}
.kg-idea-add svg{width:18px;height:18px;}
@media (max-width:600px){
  .kg-cal-cell{min-height:74px;padding:6px;gap:5px;}
  .kg-cal-add{height:24px;}
  .kg-meal-chip{font-size:10px;padding:4px 6px;}
  .kg-meal-stats{gap:12px;}
  .kg-meal-stat{flex-direction:column;align-items:flex-start;gap:8px;text-align:left;}
  .kg-meal-stat-ico{width:38px;height:38px;}
  .kg-meal-stat b{font-size:18px;}
}

/* ---------- Hub (home) ---------- */
.kg-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.kg-chip-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;border-radius:999px;cursor:pointer;font:inherit;
  font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);
  background:var(--glass-bg);border:1px solid var(--glass-brd);}
.kg-chip-pill .d{width:8px;height:8px;border-radius:50%;}
.d-primary{background:var(--accent);box-shadow:0 0 8px var(--accent);} .d-secondary{background:var(--secondary);} .d-tertiary{background:var(--tertiary);}
.kg-featured{position:relative;overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;gap:6px;cursor:pointer;
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent-strong) 55%,var(--surface-c)),var(--surface-c) 75%);}
.kg-featured::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 85% 10%,color-mix(in srgb,var(--accent) 30%,transparent),transparent 55%);pointer-events:none;}
.kg-badge{position:relative;align-self:flex-start;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 11px;border-radius:8px;background:var(--accent-strong);color:#fff;margin-bottom:6px;}
.kg-featured h2{position:relative;font-size:clamp(24px,3vw,32px);font-weight:800;}
.kg-featured p{position:relative;color:var(--on-variant,var(--muted));max-width:40ch;}
.kg-play{position:absolute;top:24px;right:24px;width:56px;height:56px;border-radius:18px;border:none;cursor:pointer;
  background:var(--glass-bg);border:1px solid var(--glass-brd);color:var(--accent);display:grid;place-items:center;backdrop-filter:blur(8px);}
.kg-play svg{width:30px;height:30px;}
.kg-next-event{padding:14px 16px;border-radius:16px;border-left:4px solid var(--accent);background:var(--recess-bg);margin-bottom:12px;}
.kg-next-event.dim{opacity:.6;border-left-color:var(--outline-variant);}
.kg-next-event .t{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:3px;}
.kg-next-event strong{display:block;font-weight:700;} .kg-next-event small{color:var(--muted);font-size:13px;}
.kg-grab{list-style:none;margin:0 0 18px;padding:0;display:flex;flex-direction:column;gap:13px;}
.kg-grab li{display:flex;align-items:center;gap:12px;}
.kg-grab li.done{color:var(--muted);text-decoration:line-through;}
.kg-grab-box{width:22px;height:22px;flex:none;border-radius:7px;border:1px solid var(--outline-variant);display:grid;place-items:center;
  background:var(--recess-bg);color:var(--secondary);font-size:13px;font-weight:800;}
.kg-grab li.done .kg-grab-box{background:var(--secondary);color:var(--on-secondary);border-color:var(--secondary);}
.kg-dinner{display:flex;flex-direction:column;}
.kg-dinner-art{height:120px;border-radius:18px;margin-bottom:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,color-mix(in srgb,var(--tertiary) 30%,var(--surface-c)),var(--surface-c));color:var(--tertiary);}
.kg-dinner-art svg{width:46px;height:46px;stroke:currentColor;stroke-width:1.6;fill:none;}
.kg-dinner strong{font-size:16px;} .kg-btn-tertiary{background:var(--tertiary)!important;color:var(--on-tertiary)!important;box-shadow:none!important;}
.kg-card-mini{display:flex;flex-direction:column;justify-content:space-between;gap:14px;}
.kg-house.is-warn{border-color:color-mix(in srgb,var(--error) 30%,var(--glass-brd));background:color-mix(in srgb,var(--error) 7%,var(--glass-bg));}
.kg-house strong{display:block;font-weight:700;margin-top:4px;} .kg-house small{display:block;}
.kg-warn{color:var(--error);} .kg-warn svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.kg-house-bar{height:6px;border-radius:999px;background:var(--surface-highest);margin-top:14px;overflow:hidden;}
.kg-house-bar span{display:block;height:100%;width:88%;background:var(--error);border-radius:999px;}
.kg-bars{height:128px;display:flex;align-items:flex-end;gap:10px;padding:14px;border-radius:18px;background:var(--recess-bg);box-shadow:inset 2px 2px 6px rgba(0,0,0,.25);margin-top:8px;}
.kg-bars i{flex:1;border-radius:8px 8px 4px 4px;background:color-mix(in srgb,var(--accent-strong) 28%,transparent);transition:height .2s;}
.kg-bars i.hi{background:var(--accent-strong);box-shadow:0 0 14px -2px color-mix(in srgb,var(--accent) 60%,transparent);}
.kg-pet{display:flex;align-items:center;gap:22px;}
.kg-pet-avatar{width:92px;height:92px;flex:none;border-radius:50%;display:grid;place-items:center;font-size:28px;font-weight:800;
  background:linear-gradient(135deg,var(--secondary),color-mix(in srgb,var(--secondary) 50%,var(--surface-c)));color:var(--on-secondary);
  border:4px solid color-mix(in srgb,var(--secondary) 40%,transparent);}
.kg-pet-body{flex:1;min-width:0;}
.kg-pet-stats{display:flex;gap:18px;margin-top:14px;}
.kg-pet-stats div{text-align:center;color:var(--secondary);} .kg-pet-stats span{display:grid;place-items:center;}
.kg-pet-stats svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.8;fill:none;}
.kg-pet-stats small{display:block;color:var(--muted);font-size:11px;margin-top:2px;}

/* ---------- Pets page (Companion HQ) ---------- */
.kg-two{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);}
.kg-accentbar.ok{background:var(--secondary);}
.kg-pet-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:48px 32px;}
.kg-pet-empty-ico{width:96px;height:96px;border-radius:28px;display:grid;place-items:center;color:var(--accent);
  background:color-mix(in srgb,var(--accent-strong) 14%,var(--surface-c));}
.kg-pet-empty-ico svg{width:48px;height:48px;}
.kg-pet-empty h3{font-size:24px;font-weight:700;}
.kg-pet-empty p{color:var(--muted);max-width:42ch;}
.kg-pet-empty .kg-btn-soft{margin-top:6px;}
.kg-pet-hero{display:flex;align-items:center;gap:22px;flex-wrap:wrap;position:relative;}
.kg-pet-hero-photo{width:104px;height:104px;flex:none;border-radius:28px;overflow:hidden;border:1px solid var(--glass-brd);
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent-strong) 30%,var(--surface-c)),var(--surface-c));display:grid;place-items:center;}
.kg-pet-hero-photo img,.kg-pet-hero-photo .hub-attachment-gallery,.kg-pet-hero-photo .hub-attachment,.kg-pet-hero-photo .item-photo{width:100%;height:100%;}
.kg-pet-hero-photo img{object-fit:cover;}
/* the gallery's fixed 72px thumb size must not shrink the hero photo — make it fill */
.kg-pet-hero-photo .hub-attachment.image .item-photo img{width:100%;height:100%;object-fit:cover;}
.kg-pet-hero-photo .pet-avatar-placeholder{font-size:42px;}
.kg-pet-hero-copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;}
.kg-pet-hero-copy h3{font-size:24px;font-weight:700;}
.kg-pet-hero-copy p{color:var(--muted);} .kg-pet-hero-copy small{color:var(--muted);font-size:13px;}
.kg-pet-hero-actions{display:flex;gap:14px;margin-top:6px;flex-wrap:wrap;}
.kg-pet-switch{display:flex;gap:8px;flex-wrap:wrap;width:100%;}
.kg-pet-chip{border:1px solid var(--glass-brd);background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:13px;padding:7px 15px;border-radius:999px;cursor:pointer;}
.kg-pet-chip.on{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,transparent);background:color-mix(in srgb,var(--accent-strong) 14%,transparent);}
.kg-care-card{display:flex;flex-direction:column;}
.kg-care-list{display:flex;flex-direction:column;gap:10px;}
.kg-care-row{display:flex;align-items:center;gap:6px;border-radius:16px;background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);padding:4px 10px 4px 4px;}
.kg-care-row.next{border-color:color-mix(in srgb,var(--secondary) 30%,transparent);}
.kg-care-open{flex:1;min-width:0;display:flex;align-items:center;gap:12px;border:none;background:transparent;cursor:pointer;font:inherit;text-align:left;padding:10px;}
.kg-care-bar{width:4px;align-self:stretch;border-radius:999px;background:var(--outline-variant);flex:none;}
.kg-care-row.next .kg-care-bar{background:var(--secondary);}
.kg-care-copy{min-width:0;flex:1;} .kg-care-copy strong{display:block;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.kg-care-copy small{color:var(--muted);font-size:12px;}
.kg-care-lock{width:16px;height:16px;color:var(--muted);flex:none;} .kg-care-go{width:18px;height:18px;color:var(--accent);flex:none;}
.kg-care-empty{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:8px 0;}
.kg-adv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.kg-adv-thumb{aspect-ratio:1;border-radius:16px;overflow:hidden;border:1px solid var(--glass-brd);background:var(--surface-high);cursor:pointer;padding:0;display:grid;place-items:center;color:var(--muted);}
.kg-adv-thumb img{width:100%;height:100%;object-fit:cover;}
.kg-adv-thumb.empty{cursor:default;} .kg-adv-thumb svg{width:26px;height:26px;}
.kg-so-row{display:flex;align-items:center;gap:14px;padding:10px 0;}
.kg-so-row+.kg-so-row{border-top:1px solid rgba(255,255,255,.05);}
.kg-so-ico{width:42px;height:42px;flex:none;border-radius:13px;display:grid;place-items:center;}
.kg-so-ico svg{width:20px;height:20px;}
.kg-so-ico.accent{background:color-mix(in srgb,var(--accent-strong) 16%,transparent);color:var(--accent);}
.kg-so-ico.ok{background:color-mix(in srgb,var(--secondary) 14%,transparent);color:var(--secondary);}
.kg-so-ico.warn{background:color-mix(in srgb,var(--tertiary) 16%,transparent);color:var(--tertiary);}
.kg-so-row small{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);}
.kg-so-row b{font-size:16px;font-weight:700;}
.kg-pet-trend{margin-bottom:16px;}
.kg-pet-trend-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:13px;}
.kg-pet-trend-top b{color:var(--accent);}
.kg-pet-trend-bar{height:7px;border-radius:999px;background:var(--surface-highest);overflow:hidden;}
.kg-pet-trend-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent-strong),var(--accent));}
@media (max-width:680px){ .kg-two{grid-template-columns:1fr;} .kg-adv-grid{grid-template-columns:repeat(4,1fr);} }

/* ---------- Recipes ---------- */
.kg-recipe-hero{padding:8px 4px 4px;}
.kg-recipe-hero h2{font-size:clamp(28px,3.4vw,40px);font-weight:800;letter-spacing:-.01em;line-height:1.08;}
.kg-recipe-hero h2 i{color:var(--accent);font-style:italic;}
.kg-recipe-hero p{color:var(--muted);max-width:52ch;margin-top:10px;}
.kg-import-ico{width:44px;height:44px;flex:none;border-radius:13px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent-strong) 16%,transparent);color:var(--accent);}
.kg-import-ico svg{width:22px;height:22px;}
.kg-import-summary{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.kg-import-titles{flex:1;min-width:0;}
/* collapsible "recipe details" — closed by default so only the URL box + Import show */
.kg-import-more{margin-top:14px;border-top:1px solid var(--glass-brd);}
.kg-import-more>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:8px;padding:12px 2px 2px;font-weight:700;color:var(--ink);}
.kg-import-more>summary::-webkit-details-marker{display:none;}
.kg-import-more>summary::after{content:"";flex:none;width:18px;height:18px;margin-left:auto;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/contain no-repeat;background:var(--muted);transition:transform .2s;}
.kg-import-more[open]>summary::after{transform:rotate(180deg);}
.kg-import-more-hint{font-weight:400;font-size:12px;color:var(--muted);}
.kg-import-more>summary+*{margin-top:12px;}
.kg-import-card .genz-recipe-url-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;}
.kg-import-card .genz-recipe-url-row label{flex:1;min-width:220px;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);}
.kg-import-card .genz-recipe-url-row input{width:100%;}
/* import result + status (replaces native confirm/alert popups) */
[data-recipe-import-status].is-error{color:var(--tertiary);}
.recipe-import-card{margin:14px 0 4px;padding:16px;border-radius:16px;border:1px solid var(--glass-brd);background:var(--recess-bg);}
.recipe-import-card>strong{display:block;font-size:16px;}
.recipe-import-card .meta{margin:4px 0 10px;}
.recipe-missing-list{display:flex;flex-direction:column;gap:6px;margin:10px 0;padding:12px;border-radius:12px;background:color-mix(in srgb,var(--tertiary) 12%,transparent);}
.recipe-missing-list.recipe-close-list{background:color-mix(in srgb,var(--c-meals) 12%,transparent);}
.recipe-missing-list strong{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);}
.recipe-missing-list span{font-size:14px;}
.recipe-missing-list em{color:var(--muted);font-style:normal;font-size:12px;}
.recipe-allset{color:var(--accent);font-weight:600;}
.recipe-autoshop{display:flex;align-items:flex-start;gap:10px;margin-top:12px;padding:12px;border-radius:12px;cursor:pointer;
  background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent) 24%,transparent);font-weight:600;font-size:14px;}
.recipe-autoshop input{width:20px;height:20px;flex:none;accent-color:var(--accent-strong);margin-top:1px;}
/* ---------- Recipe detail page ---------- */
.kg-rd{display:flex;flex-direction:column;gap:18px;max-width:1000px;margin:0 auto;}
.kg-rd-empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;text-align:center;}
.kg-rd-hero{position:relative;border-radius:24px;overflow:hidden;min-height:200px;display:flex;align-items:flex-end;
  background:linear-gradient(135deg,color-mix(in srgb,var(--c-meals) 42%,var(--surface)),color-mix(in srgb,var(--accent) 32%,var(--surface)));}
.kg-rd-hero.has-image{min-height:264px;}
.kg-rd-hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.kg-rd-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.74),rgba(0,0,0,.06) 56%,transparent);}
.kg-rd-hero-ico{position:absolute;inset:0;display:grid;place-items:center;color:#fff;opacity:.6;}
.kg-rd-hero-ico svg{width:74px;height:74px;}
.kg-rd-back{position:absolute;top:14px;left:14px;z-index:2;width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;
  display:grid;place-items:center;color:#fff;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);}
.kg-rd-back svg{width:22px;height:22px;} .kg-rd-back:hover{background:rgba(0,0,0,.6);}
.kg-rd-hero-text{position:relative;z-index:1;padding:20px 22px;width:100%;}
.kg-rd-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px;}
.kg-rd-chips span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff;
  padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.22);backdrop-filter:blur(6px);}
.kg-rd-hero-text h1{color:#fff;font-size:clamp(24px,3.6vw,38px);font-weight:800;line-height:1.08;text-shadow:0 2px 18px rgba(0,0,0,.55);}
.kg-rd-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.kg-rd-stat{display:flex;flex-direction:column;align-items:center;gap:3px;padding:14px 8px;border-radius:16px;background:var(--recess-bg);border:1px solid var(--glass-brd);}
.kg-rd-stat b{font-size:24px;font-weight:800;line-height:1;}
.kg-rd-stat span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;text-align:center;}
.kg-rd-stat.ok b{color:var(--accent);} .kg-rd-stat.warn b{color:var(--tertiary);}
.kg-rd-grid{display:grid;grid-template-columns:1fr;gap:16px;}
.kg-rd-panel h3{font-size:18px;font-weight:800;margin-bottom:14px;}
.kg-rd-ings{list-style:none;display:flex;flex-direction:column;gap:2px;margin:0;padding:0;}
.kg-rd-ing{display:flex;align-items:center;gap:12px;padding:11px 2px;border-bottom:1px solid var(--glass-brd);}
.kg-rd-ing:last-child{border-bottom:none;}
.kg-rd-ing-text{flex:1;min-width:0;font-size:15px;}
.kg-rd-tag{flex:none;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;}
.kg-rd-tag.have{color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,transparent);}
.kg-rd-tag.need{color:var(--tertiary);background:color-mix(in srgb,var(--tertiary) 16%,transparent);}
.kg-rd-steps{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0;padding:0;}
.kg-rd-step{display:flex;gap:14px;}
.kg-rd-step-num{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:14px;color:var(--accent-ink,#fff);background:var(--accent-strong);}
.kg-rd-step-body{padding-top:3px;} .kg-rd-step-body strong{display:block;margin-bottom:2px;} .kg-rd-step-body p{margin:0;line-height:1.5;}
.kg-rd-source{display:inline-block;margin-top:14px;color:var(--accent);font-weight:600;font-size:14px;}
.kg-rd-actions{display:flex;flex-wrap:wrap;gap:10px;position:sticky;bottom:12px;padding:12px;border-radius:18px;
  background:color-mix(in srgb,var(--surface) 82%,transparent);backdrop-filter:blur(14px);border:1px solid var(--glass-brd);box-shadow:var(--shadow-soft);}
.kg-rd-primary{flex:1;min-width:160px;padding:13px;border-radius:14px;border:none;cursor:pointer;font:inherit;font-weight:700;color:var(--accent-ink,#fff);background:var(--accent-strong);}
.kg-rd-primary:hover{filter:brightness(1.06);}
.kg-rd-del{padding:13px 18px;border-radius:14px;border:1px solid color-mix(in srgb,var(--tertiary) 30%,transparent);cursor:pointer;font:inherit;font-weight:600;color:var(--tertiary);background:transparent;}
.kg-rd-del:hover{background:color-mix(in srgb,var(--tertiary) 12%,transparent);}
@media (min-width:760px){ .kg-rd-grid{grid-template-columns:0.85fr 1.15fr;align-items:start;} }
.kg-recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;}
.kg-recipe-card{display:flex;flex-direction:column;border-radius:18px;overflow:hidden;background:var(--recess-bg);border:1px solid rgba(255,255,255,.05);}
.kg-recipe-photo{height:130px;border:none;padding:0;cursor:pointer;display:block;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-strong) 30%,var(--surface-c)),var(--surface-c));}
.kg-recipe-photo img{width:100%;height:100%;object-fit:cover;}
.kg-recipe-photo .kg-thumb-mark{width:100%;height:100%;}
.kg-recipe-body{padding:14px;display:flex;flex-direction:column;gap:4px;}
.kg-recipe-body small{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);}
.kg-recipe-body strong{font-weight:700;font-size:15px;overflow-wrap:anywhere;}
.kg-recipe-actions{display:flex;align-items:center;gap:12px;margin-top:10px;}
.kg-recipe-actions .kg-del{margin-left:auto;}
.kg-recipe-blank{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:40px 24px;}
.kg-recipe-blank-ico{width:80px;height:80px;border-radius:24px;display:grid;place-items:center;color:var(--accent);background:color-mix(in srgb,var(--accent-strong) 12%,var(--surface-c));}
.kg-recipe-blank-ico svg{width:38px;height:38px;}
.kg-recipe-blank h3{font-size:20px;font-weight:700;} .kg-recipe-blank p{color:var(--muted);max-width:42ch;}
.kg-featured-soft{background:linear-gradient(150deg,color-mix(in srgb,var(--accent-strong) 22%,var(--surface-c)),var(--surface-c) 70%);}
.kg-sync-rows{display:flex;flex-direction:column;gap:10px;}
.kg-sync-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;}
.kg-sync-row span{color:var(--muted);} .kg-sync-row b.warn{color:var(--tertiary);}
.kg-smart{background:color-mix(in srgb,var(--secondary) 12%,var(--surface-c));border-color:color-mix(in srgb,var(--secondary) 25%,var(--glass-brd));}
.kg-smart-head{display:flex;align-items:center;gap:10px;color:var(--secondary);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;}
.kg-smart-head svg{width:20px;height:20px;}
.kg-smart p{color:var(--on-variant,var(--ink));font-size:14px;line-height:1.5;}

/* ---------- Calendar ---------- */
.calendar-status-grid{display:grid;gap:12px;}
.calendar-status-grid:empty{display:none;}
.kg-cal-event{display:block;width:100%;max-width:100%;text-align:left;font-family:inherit;cursor:pointer;padding:4px 8px;border-radius:8px;font-size:10.5px;font-weight:700;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);background:color-mix(in srgb,var(--accent-strong) 18%,transparent);color:var(--accent);transition:filter .12s;}
.kg-cal-event:hover{filter:brightness(1.12);}
.kg-cal-event:focus-visible{outline:2px solid var(--accent);outline-offset:1px;}
/* calendar event detail popup */
.kg-evd{display:flex;flex-direction:column;gap:10px;}
.kg-evd-row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:11px 14px;border-radius:13px;background:color-mix(in srgb,var(--surface-high) 60%,transparent);border:1px solid var(--glass-brd);}
.kg-evd-row>span{color:var(--muted);font-size:13px;flex:none;}
.kg-evd-row>strong{text-align:right;font-size:14px;}
.kg-evd-actions{display:flex;gap:10px;margin-top:4px;}
.kg-evd-actions>button{flex:1;}
.kg-evd-note{margin:2px 0 0;padding:12px 14px;border-radius:13px;background:color-mix(in srgb,var(--accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--accent) 18%,transparent);color:var(--muted);font-size:13px;line-height:1.5;}
.kg-cal-event+.kg-cal-event{margin-top:4px;}
.kg-cal-event.ev-ok{border-color:color-mix(in srgb,var(--secondary) 24%,transparent);background:color-mix(in srgb,var(--secondary) 16%,transparent);color:var(--secondary);}
.kg-cal-event.ev-warn{border-color:color-mix(in srgb,var(--tertiary) 24%,transparent);background:color-mix(in srgb,var(--tertiary) 16%,transparent);color:var(--tertiary);}
.kg-cal-event.ev-coral{border-color:color-mix(in srgb,var(--error) 24%,transparent);background:color-mix(in srgb,var(--error) 14%,transparent);color:var(--error);}
.kg-cal-event.ev-secondary{border-color:color-mix(in srgb,var(--secondary) 24%,transparent);background:color-mix(in srgb,var(--secondary) 12%,transparent);color:var(--secondary);}
.kg-cal-more{display:block;margin-top:4px;font-size:10px;font-weight:600;color:var(--muted);}
.kg-coming-list{display:flex;flex-direction:column;gap:14px;}
.kg-coming-row{display:flex;align-items:flex-start;gap:12px;}
.kg-coming-dot{width:10px;height:10px;flex:none;border-radius:50%;margin-top:5px;background:var(--accent);}
.kg-coming-dot.ev-ok,.kg-coming-dot.ev-secondary{background:var(--secondary);}.kg-coming-dot.ev-warn{background:var(--tertiary);}.kg-coming-dot.ev-coral{background:var(--error);}.kg-coming-dot.ev-accent{background:var(--accent);}
.kg-coming-row strong{display:block;font-weight:700;font-size:14px;overflow-wrap:anywhere;}
.kg-coming-row small{color:var(--muted);font-size:12px;}
.kg-coming-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:30px 16px;}
.kg-coming-empty-ico{width:72px;height:72px;border-radius:22px;display:grid;place-items:center;color:var(--muted);background:var(--recess-bg);}
.kg-coming-empty-ico svg{width:32px;height:32px;}
.kg-coming-empty strong{font-size:16px;font-weight:700;} .kg-coming-empty p{color:var(--muted);font-size:13px;max-width:34ch;}
.kg-source-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.kg-source-row{display:flex;align-items:center;gap:12px;padding:10px 0;}
.kg-source-row+.kg-source-row{border-top:1px solid rgba(255,255,255,.05);}
.kg-source-row>span:nth-child(2){flex:1;min-width:0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.kg-source-dot{width:10px;height:10px;flex:none;border-radius:50%;background:var(--accent);}
.kg-source-dot.ev-ok{background:var(--secondary);}.kg-source-dot.ev-coral{background:var(--error);}.kg-source-dot.ev-accent{background:var(--accent);}
.kg-source-ok{width:18px;height:18px;color:var(--secondary);flex:none;}

/* ---------- Login / Signup (auth pages) ---------- */
body.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 90% at 12% 8%,color-mix(in srgb,var(--accent-strong) 26%,var(--surface)),var(--surface) 55%);}
.login-shell{width:100%;max-width:980px;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:24px;align-items:stretch;}
.login-panel{background:var(--glass-bg);border:1px solid var(--glass-brd);border-radius:var(--r-card);padding:40px;
  backdrop-filter:blur(20px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:16px;}
.login-panel.hero-panel{justify-content:center;gap:18px;
  background:linear-gradient(150deg,color-mix(in srgb,var(--accent-strong) 40%,var(--surface-c)),var(--surface-c) 72%);}
.login-panel.hero-panel .eyebrow{color:var(--accent);}
.login-panel h1{font-size:clamp(30px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.05;}
.login-panel h2{font-size:26px;font-weight:700;}
.login-panel .eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.login-panel .lead{color:var(--muted);font-size:16px;line-height:1.55;}
.login-panel label{display:flex;flex-direction:column;gap:7px;font-size:13px;font-weight:600;color:var(--muted);}
.login-panel input{width:100%;}
.security-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:8px;}
.security-item{display:flex;flex-direction:column;gap:4px;padding:14px;border-radius:16px;background:var(--recess-bg);border:1px solid var(--glass-brd);}
.security-item b{font-size:14px;color:var(--ink);}
.security-item span{font-size:13px;color:var(--muted);line-height:1.45;}
.login-panel button{min-height:50px;border:none;border-radius:var(--r-ctrl);cursor:pointer;font-weight:700;font-size:16px;
  background:var(--accent-strong);color:#fff;box-shadow:0 10px 26px -10px color-mix(in srgb,var(--accent) 70%,transparent);}
.login-panel button.secondary{background:var(--glass-bg);border:1px solid var(--glass-brd);color:var(--ink);box-shadow:none;}
.login-panel button:active{transform:scale(.98);}
.login-panel .meta{color:var(--muted);font-size:13px;} .login-panel .meta a,.security-note a{color:var(--accent);font-weight:600;}
.security-note{margin-top:8px;padding:16px;border-radius:var(--r-ctrl);background:var(--recess-bg);border:1px solid var(--glass-brd);
  display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);}
.security-note strong{color:var(--ink);font-size:14px;}
.login-panel .error{color:var(--error);font-size:13px;font-weight:600;min-height:0;}
.login-panel .error:empty{display:none;}
.login-signup-cta{display:none;}
@media (max-width:760px){
  .login-shell{grid-template-columns:1fr;max-width:440px;gap:10px;}
  .login-panel{padding:28px;}
  /* Mobile: strip the hero down to just the logo so the sign-in form is front and center,
     not buried under the marketing/security copy. The hidden bits stay for the desktop layout. */
  .login-panel.hero-panel{order:-1;padding:6px 24px 0;background:transparent;border:none;box-shadow:none;
    backdrop-filter:none;-webkit-backdrop-filter:none;text-align:center;gap:0;}
  .hero-panel .eyebrow,.hero-panel h1,.hero-panel .lead,.hero-panel .security-note,.hero-panel .security-grid{display:none;}
  .hero-panel .brand-full{width:150px;max-width:58%;margin:0 auto;}
  .login-signup-cta{display:block;}      /* the signup link lives in the hero on desktop; surface it by the form on mobile */
  .security-grid{grid-template-columns:1fr;}
}

@media (max-width:679px){
  .family-main{padding:18px 14px 104px;}
  .family-topbar{padding-left:14px;padding-right:14px;gap:8px;}
  .topbar-actions{gap:6px;}
  .topbar-avatar{width:38px;height:38px;}
  .family-card,.add-panel.family-card,.account-menu.family-card{padding:18px;}
  .family-bento-card{min-height:120px;}
  .home-bento{grid-template-columns:1fr;}
  .module-head{margin-bottom:18px;}
}

/* ---------- Settings & Admin polish ---------- */
.kg-head-pill{margin-left:auto;align-self:center;}
.kg-ok-text{color:var(--secondary);font-weight:700;letter-spacing:.04em;}
.kg-theme-preview{margin-top:18px;padding:16px;border-radius:16px;border:1px solid var(--glass-brd);
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent-strong) 30%,var(--surface-c)),var(--surface-c));}
.kg-theme-preview-bars{display:flex;gap:8px;margin-bottom:12px;}
.kg-theme-preview-bars i{height:8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 70%,transparent);}
.kg-theme-preview-bars i:nth-child(1){width:46%;} .kg-theme-preview-bars i:nth-child(2){width:28%;background:var(--secondary);} .kg-theme-preview-bars i:nth-child(3){width:18%;background:var(--tertiary);}
.kg-theme-preview small{color:var(--muted);font-size:12px;font-weight:600;}
/* settings: consistent secondary buttons for non-submit actions */
#settings .inline-form button,#settings .notification-actions button,#settings button[type=button]{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--tap);padding:0 18px;
  border-radius:var(--r-ctrl);font-weight:600;font-size:14px;cursor:pointer;white-space:nowrap;
  background:var(--surface-highest);color:var(--ink);border:1px solid var(--glass-brd);box-shadow:none;
  transition:transform .12s,background .15s,border-color .15s,color .15s;}
#settings .inline-form button:hover,#settings .notification-actions button:hover,#settings button[type=button]:hover{
  border-color:color-mix(in srgb,var(--accent) 35%,transparent);color:var(--accent);}
#settings .inline-form button:active,#settings button[type=button]:active{transform:scale(.96);}
/* buttons size to their content (no full-width stretch); inputs still grow */
#settings .inline-form{gap:12px;row-gap:12px;justify-content:flex-start;align-items:center;}
#settings .inline-form button{flex:0 0 auto;}
#settings .inline-form input,#settings .inline-form select{flex:1 1 220px;min-width:180px;}
#settings .notification-actions{flex-wrap:wrap;margin-top:4px;}
/* Reminders: flatten the nested "how it works" card so it isn't cramped */
#settings .notification-guide{margin:14px 0 16px;padding:20px 22px;background:var(--recess-bg);border:1px solid var(--glass-brd);box-shadow:none;}
#settings .notification-guide .family-title{margin-bottom:10px;}
#settings .notification-guide ol{margin:0 0 16px;padding-left:20px;display:flex;flex-direction:column;gap:9px;color:var(--muted);line-height:1.5;}
#settings .notification-guide ol strong{color:var(--ink);}
#settings .notification-guide #notificationStatus{margin-top:12px;}
#settings #notificationsList{margin-top:14px;}
#settings .stack-form>button[type=submit]{align-self:flex-start;padding:0 28px;}
/* roomier theme tiles */
.theme-chip-card{padding:16px 14px;min-height:62px;justify-content:center;}
.theme-chip-card b{font-size:15px;}
#usersList .person{align-items:center;}
.kg-user-main{display:flex;align-items:center;gap:12px;min-width:0;}
.kg-user-right{display:flex;align-items:center;gap:10px;flex:none;}
.kg-user-main .kg-avatar{width:40px;height:40px;flex:none;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;
  background:color-mix(in srgb,var(--accent-strong) 22%,var(--surface-c));color:var(--accent);}
#admin .add-panel>summary{font-weight:600;}
/* Admin action tiles */
.kg-action-tile{display:flex;align-items:flex-start;gap:16px;text-align:left;cursor:pointer;padding:24px;border-radius:var(--r-card);
  background:color-mix(in srgb,var(--surface-c) 90%,transparent);border:1px solid var(--glass-brd);color:var(--ink);font:inherit;transition:border-color .15s,transform .12s;}
#admin .family-card{background:color-mix(in srgb,var(--surface-c) 90%,transparent);}
.kg-action-tile:hover{border-color:color-mix(in srgb,var(--accent) 40%,transparent);}
.kg-action-tile:active{transform:scale(.99);}
.kg-tile-ico{width:48px;height:48px;flex:none;border-radius:14px;display:grid;place-items:center;}
.kg-tile-ico svg{width:24px;height:24px;}
.kg-tile-ico.accent{background:color-mix(in srgb,var(--accent-strong) 18%,transparent);color:var(--accent);}
.kg-tile-ico.ok{background:color-mix(in srgb,var(--secondary) 16%,transparent);color:var(--secondary);}
.kg-tile-copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px;}
.kg-tile-copy strong{font-size:18px;font-weight:700;}
.kg-tile-copy small{color:var(--muted);font-size:13px;line-height:1.45;}
.kg-tile-arrow{flex:none;color:var(--muted);} .kg-tile-arrow svg{width:22px;height:22px;}
.kg-action-tile:hover .kg-tile-arrow{color:var(--accent);}
/* Admin list rows (users / activity / backups) */
#admin .admin-list .person{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:12px 0;border:none;background:transparent;}
#admin .admin-list .person+.person{border-top:1px solid rgba(255,255,255,.06);}
#admin .admin-list .person .title{font-weight:600;}
#admin .admin-list .person .meta{color:var(--muted);font-size:12px;}
#admin .admin-list button:not(.kg-del){border:1px solid var(--glass-brd);background:var(--surface-high);color:var(--ink);
  border-radius:999px;padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;min-height:0;}
.kg-cal-source{display:flex;align-items:center;gap:12px;padding:10px 0;}
.kg-cal-source+.kg-cal-source{border-top:1px solid rgba(255,255,255,.06);}
.kg-cal-source-dot{width:10px;height:10px;flex:none;border-radius:50%;}
.kg-cal-source-copy{flex:1;min-width:0;} .kg-cal-source-copy strong{display:block;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.kg-cal-source-copy small{color:var(--muted);font-size:12px;}
.kg-cal-source-ok{width:18px;height:18px;color:var(--secondary);flex:none;}
.kg-backup-actions{display:flex;align-items:center;gap:14px;}
.kg-backup-actions button[type=submit]{flex:none;}
.kg-head-actions{display:flex;align-items:center;gap:14px;}
.kg-scroll-list{max-height:268px;overflow-y:auto;}
.kg-scroll-list::-webkit-scrollbar{width:6px;}
@media (max-width:680px){ .kg-action-tile{padding:18px;} }

/* ---------- Mobile nav: floating pages-menu button (bottom tab bar removed) ---------- */
.bottom-tabs,.family-bottom-nav{display:none !important;}
.tab-symbol{display:none;}
.nav-scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:59;}
@media (max-width:1023px){
  /* the + (add) button owns the bottom-right corner; the pages-menu button stacks above it when present */
  .kg-fab{bottom:calc(18px + env(safe-area-inset-bottom));right:18px;}
  /* Reserve space at the bottom so the last card clears the floating menu button (and the FAB,
     which stacks the menu button higher). Without this the fixed buttons overlap the last box. */
  .family-main{padding-bottom:calc(100px + env(safe-area-inset-bottom)) !important;}
  body.has-fab .family-main{padding-bottom:calc(168px + env(safe-area-inset-bottom)) !important;}
  .menu-btn{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:120;
    width:56px;height:56px;border-radius:50%;background:var(--accent-strong);color:#fff;
    box-shadow:0 12px 30px -8px color-mix(in srgb,var(--accent) 65%,transparent),0 4px 14px rgba(0,0,0,.45);
    transition:transform .14s,filter .15s;}
  body.has-fab .menu-btn{bottom:calc(84px + env(safe-area-inset-bottom));}
  .menu-btn:hover{color:#fff;filter:brightness(1.06);} .menu-btn:active{transform:scale(.94);}
  .menu-btn svg{width:24px;height:24px;}
  body.menu-open .menu-btn{filter:brightness(.9);}
  /* the pages popover that springs from the menu button — a clean menu, NOT the side panel */
  .family-sidebar.is-mobile-drawer{border:1px solid var(--glass-brd);border-radius:20px;padding:6px;box-shadow:var(--shadow-soft);
    width:min(258px,calc(100vw - 28px));transform-origin:bottom right;animation:kg-menu-pop .16s ease;
    /* the JS sets a max-height; make the panel itself scroll so a tall nav list can't spill past
       the rounded box and collide with the floating buttons */
    overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;}
  .family-sidebar.is-mobile-drawer .sidebar-head,
  .family-sidebar.is-mobile-drawer .sidebar-footer{display:none;}
  .family-sidebar.is-mobile-drawer .family-nav-list-wrap{gap:1px;}
  .family-sidebar.is-mobile-drawer .family-nav-item{padding:6px 10px;gap:12px;font-size:15px;font-weight:600;
    border-radius:14px;color:var(--ink);}
  .family-sidebar.is-mobile-drawer .family-nav-item::before{display:none;}
  .family-sidebar.is-mobile-drawer .nav-tile{display:grid;place-items:center;width:34px;height:34px;flex:none;border-radius:10px;
    background:color-mix(in srgb,var(--menu-cat,var(--accent)) 20%,transparent);color:var(--menu-cat,var(--accent));}
  .family-sidebar.is-mobile-drawer .nav-tile::before{content:"";width:19px;height:19px;background:currentColor;
    -webkit-mask:var(--icon) center/contain no-repeat;mask:var(--icon) center/contain no-repeat;}
  .family-sidebar.is-mobile-drawer .family-nav-item.is-active,
  .family-sidebar.is-mobile-drawer .family-nav-item.active,
  .family-sidebar.is-mobile-drawer .family-nav-item[aria-current=page]{color:var(--ink);box-shadow:none;
    background:color-mix(in srgb,var(--menu-cat,var(--accent)) 14%,transparent);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=shopping]{--menu-cat:var(--c-shopping);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=chores]{--menu-cat:var(--c-chores);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=calendar]{--menu-cat:var(--c-calendar);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=meals],
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=recipes]{--menu-cat:var(--c-meals);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=pantry]{--menu-cat:var(--c-pantry);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=pets]{--menu-cat:var(--c-pets);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=maintenance]{--menu-cat:var(--c-house);}
  .family-sidebar.is-mobile-drawer .family-nav-item[data-view=admin]{--menu-cat:var(--c-admin);}
}
.nav-tile{display:none;}
@keyframes kg-menu-pop{from{opacity:0;transform:translateY(12px) scale(.95);}to{opacity:1;transform:none;}}

/* ---------- Responsive: desktop sidebar ---------- */
@media (min-width:1024px){
  .family-sidebar{display:flex;}
  .family-shell{margin-left:var(--sidebar-w);}
  .menu-btn{display:none;}
  .bottom-tabs,.family-bottom-nav{display:none;}
  .family-main{padding:32px;}
  .family-grid.two-up{grid-template-columns:1fr 1fr;}
  .home-bento{grid-template-columns:repeat(4,1fr);}
  .topbar-titles .family-callout{display:block;font-size:13px;}
}
@media (min-width:680px) and (max-width:1023px){
  .home-bento{grid-template-columns:repeat(3,1fr);}
}
/* hide desktop-only sidebar on mobile; topbar hamburger toggles it */
.family-sidebar.is-mobile-drawer{display:flex;}

/* ---------- Icon glyphs (carried from legacy theme.css; CSP-safe inline-SVG masks) ---------- */
.nav-page[data-view=home],.family-nav-item[data-view=home],.family-icon-tile[data-ico=home]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 10.5 12 3l9 7.5'/%3E%3Cpath d='M5 9.5V21h14V9.5'/%3E%3C/svg%3E")}
.nav-page[data-view=shopping],.family-nav-item[data-view=shopping],.family-icon-tile[data-ico=shopping]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='20' r='1.6'/%3E%3Ccircle cx='17' cy='20' r='1.6'/%3E%3Cpath d='M2 3h3l2.6 12h10.2L21 7H6'/%3E%3C/svg%3E")}
.nav-page[data-view=meals],.family-nav-item[data-view=meals],.family-icon-tile[data-ico=meals]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 3v8M4 3v4a3 3 0 0 0 6 0V3M7 11v10M17 3c-2 2-2 6-2 8h4c0-2 0-6-2-8zM17 11v10'/%3E%3C/svg%3E")}
.nav-page[data-view=pantry],.family-nav-item[data-view=pantry],.family-icon-tile[data-ico=pantry]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 8h16v13H4zM4 8l2-5h12l2 5M12 3v5'/%3E%3C/svg%3E")}
.nav-page[data-view=chores],.family-nav-item[data-view=chores],.family-icon-tile[data-ico=chores]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='m8.5 12 2.5 2.5 4.5-5'/%3E%3C/svg%3E")}
.nav-page[data-view=calendar],.family-nav-item[data-view=calendar],.family-icon-tile[data-ico=calendar]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 10h18'/%3E%3C/svg%3E")}
.nav-page[data-view=notices],.family-nav-item[data-view=notices],.family-icon-tile[data-ico=notices]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 14a3 3 0 0 1-3 3H8l-5 4V6a3 3 0 0 1 3-3h12a3 3 0 0 1 3 3z'/%3E%3C/svg%3E")}
.nav-page[data-view=notifications],.family-nav-item[data-view=notifications],.family-icon-tile[data-ico=notifications]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9a6 6 0 0 1 12 0c0 5 2 6 2 6H4s2-1 2-6'/%3E%3Cpath d='M10 20a2.2 2.2 0 0 0 4 0'/%3E%3C/svg%3E")}
.nav-page[data-view=household],.family-nav-item[data-view=household],.family-icon-tile[data-ico=household]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 5l5 5M9.5 9.5 4 15v5h5l5.5-5.5M13 6l5 5 3-3-5-5z'/%3E%3C/svg%3E")}
.nav-page[data-view=maintenance],.family-nav-item[data-view=maintenance],.family-icon-tile[data-ico=maintenance]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 6.5a4.5 4.5 0 0 0-6 6L3 18v3h3l5.5-5.5a4.5 4.5 0 0 0 6-6L14 13l-3-3z'/%3E%3C/svg%3E")}
.nav-page[data-view=pets],.family-nav-item[data-view=pets],.family-icon-tile[data-ico=pets]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='6' cy='9' r='1.8'/%3E%3Ccircle cx='18' cy='9' r='1.8'/%3E%3Ccircle cx='9.5' cy='5.5' r='1.8'/%3E%3Ccircle cx='14.5' cy='5.5' r='1.8'/%3E%3Cpath d='M12 11c-3 0-5.5 3-5.5 5.3 0 1.5 1.2 2.7 2.7 2.7 1 0 1.9-.5 2.8-.5s1.8.5 2.8.5c1.5 0 2.7-1.2 2.7-2.7C17.5 14 15 11 12 11z'/%3E%3C/svg%3E")}
.nav-page[data-view=settings],.family-nav-item[data-view=settings],.family-icon-tile[data-ico=settings]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19 12a7 7 0 0 0-.15-1.4l2-1.6-2-3.4-2.4 1a7 7 0 0 0-2.4-1.4L13.6 2h-3.2l-.45 2.6a7 7 0 0 0-2.4 1.4l-2.4-1-2 3.4 2 1.6A7 7 0 0 0 5 12c0 .5.05.9.15 1.4l-2 1.6 2 3.4 2.4-1a7 7 0 0 0 2.4 1.4l.45 2.6h3.2l.45-2.6a7 7 0 0 0 2.4-1.4l2.4 1 2-3.4-2-1.6c.1-.5.15-.9.15-1.4z'/%3E%3C/svg%3E")}
.nav-page[data-view=admin],.family-nav-item[data-view=admin],.family-icon-tile[data-ico=admin]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2 4 5v6c0 5 3.5 9 8 11 4.5-2 8-6 8-11V5z'/%3E%3C/svg%3E")}
.nav-page[data-view=recipes],.family-nav-item[data-view=recipes],.family-icon-tile[data-ico=recipes]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 7c-1.8-1.3-4-2-6.5-2H4v13h1.5c2.5 0 4.7.7 6.5 2 1.8-1.3 4-2 6.5-2H20V5h-1.5C16 5 13.8 5.7 12 7z'/%3E%3Cpath d='M12 7v13'/%3E%3C/svg%3E")}
.nav-page[data-view=map],.family-nav-item[data-view=map],.family-icon-tile[data-ico=map]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s-7-5.3-7-11a7 7 0 0 1 14 0c0 5.7-7 11-7 11z'/%3E%3Ccircle cx='12' cy='10' r='2.6'/%3E%3C/svg%3E")}
.nav-page[data-view=vault],.family-nav-item[data-view=vault],.family-icon-tile[data-ico=vault]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='10' width='16' height='11' rx='2'/%3E%3Cpath d='M8 10V7a4 4 0 0 1 8 0v3'/%3E%3Ccircle cx='12' cy='15.5' r='1.3'/%3E%3C/svg%3E")}
.nav-page[data-view=messages],.family-nav-item[data-view=messages],.family-icon-tile[data-ico=messages]{--icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 11.5a7.5 7.5 0 0 1-10.9 6.7L3 20l1.8-7.1A7.5 7.5 0 1 1 21 11.5z'/%3E%3C/svg%3E")}

/* ---------- Overlays / modals (camera scan, image zoom, product facts) ---------- */
.pantry-camera-modal{position:fixed;inset:0;z-index:240;display:grid;place-items:center;padding:16px;
  background:rgba(0,0,0,.8);backdrop-filter:blur(8px);}
.pantry-camera-sheet{width:min(440px,100%);background:var(--surface);border:1px solid var(--glass-brd);
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow-soft);}
.pantry-camera-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px;}
.pantry-camera-head strong{display:block;font-size:18px;font-weight:800;}
.pantry-camera-head p{margin:2px 0 0;color:var(--muted);font-size:13px;}
.pantry-camera-head button{flex:none;border:1px solid var(--glass-brd);background:var(--recess-bg);color:var(--ink);
  border-radius:12px;padding:8px 14px;font:inherit;font-weight:700;cursor:pointer;}
.pantry-camera-preview{position:relative;width:100%;aspect-ratio:4/3;background:#000;overflow:hidden;}
.pantry-camera-preview video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.pantry-camera-frame{position:absolute;inset:20% 14%;border:3px solid rgba(255,255,255,.92);border-radius:16px;
  box-shadow:0 0 0 1000px rgba(0,0,0,.28);pointer-events:none;}
.pantry-camera-help{margin:0;padding:14px 18px 18px;color:var(--muted);font-size:13px;text-align:center;}
.image-modal,.pantry-product-modal{position:fixed;inset:0;z-index:240;display:grid;place-items:center;padding:18px;
  background:rgba(0,0,0,.82);backdrop-filter:blur(8px);}
.image-modal[hidden],.pantry-product-modal[hidden]{display:none;}
.image-modal img{max-width:min(960px,96vw);max-height:88vh;border-radius:18px;object-fit:contain;box-shadow:0 24px 70px rgba(0,0,0,.5);}
.image-modal-close,.pantry-product-modal-close{position:absolute;top:16px;right:18px;width:42px;height:42px;border-radius:50%;
  border:none;cursor:pointer;font-size:22px;line-height:1;color:#fff;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);}
.pantry-product-sheet{position:relative;width:min(520px,100%);max-height:88vh;overflow:auto;background:var(--surface);
  border:1px solid var(--glass-brd);border-radius:24px;padding:24px;box-shadow:var(--shadow-soft);}

/* ---------- Pantry add form: amount controls, UPC row, scan button ---------- */
.pantry-upc-panel{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:16px;background:var(--recess-bg);border:1px solid var(--glass-brd);}
.pantry-upc-row{display:flex;gap:8px;flex-wrap:wrap;align-items:stretch;}
.pantry-upc-row input{flex:1 1 100%;min-width:0;}
.pantry-lookup-btn{flex:1 1 auto;padding:11px 16px;border-radius:13px;border:1px solid var(--glass-brd);background:var(--surface-highest);color:var(--ink);font:inherit;font-weight:700;cursor:pointer;}
.pantry-lookup-btn:hover{background:color-mix(in srgb,var(--accent) 12%,var(--surface-highest));}
.pantry-scan-btn{flex:2 1 auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border:none;border-radius:13px;
  background:var(--accent-strong);color:var(--accent-ink,#fff);font:inherit;font-weight:800;font-size:15px;cursor:pointer;box-shadow:0 8px 22px -10px color-mix(in srgb,var(--accent) 70%,transparent);}
.pantry-scan-btn svg{width:20px;height:20px;}
.pantry-scan-btn:hover{filter:brightness(1.07);} .pantry-scan-btn:active{transform:scale(.98);}
.pantry-product-preview{display:flex;gap:12px;align-items:center;padding:12px;border-radius:14px;background:var(--surface-highest);}
.pantry-product-preview img{width:56px;height:56px;flex:none;border-radius:12px;object-fit:cover;}
.pantry-product-preview strong{display:block;}
.product-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.product-badges span{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);}
.amount-control{display:flex;flex-direction:column;gap:8px;min-width:0;}
.amount-main{display:flex;gap:8px;align-items:stretch;}
.amount-main select{flex:1;min-width:0;}
.amount-custom-btn{flex:none;padding:0 14px;border-radius:12px;border:1px solid var(--glass-brd);background:var(--surface-highest);color:var(--ink);font:inherit;font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap;}
.amount-custom-btn:hover{background:color-mix(in srgb,var(--accent) 12%,var(--surface-highest));}
.amount-custom-input{width:100%;}
.pantry-recipe-conversion-fields{display:flex;gap:12px;flex-wrap:wrap;}
.pantry-recipe-conversion-fields label{flex:1;min-width:150px;display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted);}
/* The add form lives inside a fixed-width modal, so a viewport media query can't tell it's
   narrow. Always stack the main fields one per row — the inner count/recipe rows wrap on their
   own — so nothing overlaps regardless of the container width. */
.pantry-main-fields{flex-direction:column;}
.pantry-main-fields>*{flex:1 1 100%;min-width:0;width:100%;}
.pantry-advanced{border:1px solid var(--glass-brd);border-radius:13px;background:var(--surface-highest);padding:0 14px;}
.pantry-advanced>summary{cursor:pointer;padding:12px 0;font-size:13px;font-weight:600;color:var(--muted);list-style:none;}
.pantry-advanced>summary::-webkit-details-marker{display:none;}
.pantry-advanced>summary::before{content:"+ ";font-weight:800;color:var(--accent);}
.pantry-advanced[open]>summary::before{content:"− ";}
.pantry-advanced[open]>summary{border-bottom:1px solid var(--glass-brd);}
.pantry-advanced .pantry-recipe-conversion-fields{padding:12px 0 14px;}
@media (max-width:560px){
  .pantry-date-status{flex-direction:column;}
  .pantry-date-status>*{min-width:0;width:100%;}
}

/* ---------- Pantry product-facts modal (tap a pantry item) ---------- */
.pantry-product-detail{display:flex;flex-direction:column;gap:20px;}
.pantry-product-detail>header{display:flex;gap:14px;align-items:center;}
.pantry-product-detail-media{width:72px;height:72px;flex:none;border-radius:16px;overflow:hidden;background:var(--recess-bg);display:grid;place-items:center;}
.pantry-product-detail-media img{width:100%;height:100%;object-fit:cover;}
.pantry-product-detail-media .family-icon-tile{width:34px;height:34px;}
.pantry-product-detail .desktop-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:800;margin:0;}
.pantry-product-detail header h2{font-size:22px;font-weight:800;line-height:1.12;margin:3px 0;}
.pantry-product-detail header>div>p{color:var(--muted);margin:0;}
.pantry-product-facts-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.pantry-product-facts-grid>div{display:flex;flex-direction:column;gap:3px;padding:11px 14px;border-radius:14px;background:var(--recess-bg);border:1px solid var(--glass-brd);}
.pantry-product-facts-grid b{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;}
.pantry-product-facts-grid span{font-size:15px;font-weight:600;word-break:break-word;}
.pantry-product-detail section h3{font-size:15px;font-weight:800;margin:0 0 10px;}
.pantry-product-detail section>p{color:var(--ink);line-height:1.55;font-size:14px;margin:0;}
.pantry-product-chips{display:flex;flex-wrap:wrap;gap:8px;}
.pantry-product-chips span{font-size:12px;font-weight:600;padding:5px 11px;border-radius:999px;background:var(--surface-highest);color:var(--ink);}
.pantry-product-chips span.warn{background:color-mix(in srgb,var(--tertiary) 18%,transparent);color:var(--tertiary);}
.pantry-nutrition-table-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--glass-brd);}
.pantry-nutrition-table{width:100%;border-collapse:collapse;font-size:14px;}
.pantry-nutrition-table th,.pantry-nutrition-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--glass-brd);}
.pantry-nutrition-table thead th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--recess-bg);}
.pantry-nutrition-table tbody th{font-weight:600;color:var(--ink);}
.pantry-nutrition-table tbody td{color:var(--muted);}
.pantry-nutrition-table tr:last-child th,.pantry-nutrition-table tr:last-child td{border-bottom:none;}
@media (max-width:480px){ .pantry-product-facts-grid{grid-template-columns:1fr;} }

/* "tap for facts" affordance on pantry rows */
.kg-pan-ico{position:relative;}
.kg-pan-ico .kg-pan-ico-badge{position:absolute;top:-3px;right:-3px;width:17px;height:17px;border-radius:50%;
  background:var(--accent-strong);color:var(--accent-ink,#fff);font-size:11px;font-weight:800;display:grid;place-items:center;font-family:Georgia,serif;font-style:italic;border:2px solid var(--surface);}
.kg-pan-name[role=button]{cursor:pointer;}
.kg-pan-name[role=button]:hover strong,.kg-pan-name[role=button]:focus-visible strong{color:var(--accent);}
.kg-pan-facts-cue{display:inline-flex;align-items:center;gap:2px;margin-left:6px;color:var(--accent);font-weight:700;white-space:nowrap;}

/* Pet profile-complete hint + photo gallery in edit forms */
.kg-pet-hint{font-size:12px;line-height:1.45;margin:-6px 0 2px;color:var(--muted);}
.kg-pet-hint b{color:var(--ink);}
.existing-photos{display:flex;flex-direction:column;gap:8px;}
.existing-photos>.meta{font-size:12px;}
.hub-attachment-gallery{display:flex;flex-wrap:wrap;gap:8px;}
.hub-attachment.image .item-photo{padding:0;border:none;background:none;cursor:pointer;border-radius:12px;overflow:hidden;display:block;}
.hub-attachment.image .item-photo img{width:72px;height:72px;object-fit:cover;display:block;border-radius:12px;}
.hub-attachment a{font-size:13px;color:var(--accent);word-break:break-word;}
.photo-picker small{color:var(--muted);font-size:12px;line-height:1.4;font-weight:400;}
/* shopping item photo thumbnail */
.kg-shop-photo{flex:none;width:46px;height:46px;border-radius:11px;overflow:hidden;border:1px solid var(--glass-brd);background:var(--recess-bg);cursor:pointer;padding:0;margin-right:2px;}
.kg-shop-photo img{width:100%;height:100%;object-fit:cover;display:block;}
/* your support ID display in Settings */
.kg-support-id-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.kg-support-id-row code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:20px;font-weight:700;letter-spacing:.04em;padding:10px 16px;border-radius:12px;background:var(--recess-bg);border:1px solid var(--glass-brd);color:var(--ink);user-select:all;}
.kg-support-id-row button{flex:none;width:auto;}

/* ============================================================================
   Recovered layout for classes orphaned when the legacy stylesheets were removed.
   (Audit sweep: these are rendered by active code but had no CSS rule.)
   ============================================================================ */
/* Recipe save form + Pantry-link picker */
.genz-recipe-save-grid{display:flex;flex-direction:column;gap:12px;}
.genz-recipe-save-grid input,.genz-recipe-save-grid select,.genz-recipe-save-grid textarea{width:100%;}
.genz-recipe-save-grid textarea{min-height:88px;resize:vertical;}
.genz-recipe-save-btn{width:100%;}
.genz-auto-pantry-note{display:flex;flex-direction:column;gap:3px;padding:12px 14px;border-radius:14px;font-size:13px;
  background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);}
.genz-auto-pantry-note strong{font-weight:700;} .genz-auto-pantry-note span{color:var(--muted);}

/* ---------- Family map (server-blind location sharing) ---------- */
.loc-map-card{padding:0;overflow:hidden;}
.loc-map{height:520px;width:100%;border-radius:var(--r-card);background:var(--surface-low);}
@media (max-width:720px){.loc-map{height:60dvh;min-height:320px;}}
.loc-map .leaflet-container{border-radius:var(--r-card);font:inherit;}
.loc-actions{display:flex;gap:10px;}
.loc-actions #locShareBtn{flex:1.7;min-width:0;}
.loc-actions .ghost{flex:1;min-width:0;}
.kg-user-remove{color:var(--error);border-color:color-mix(in srgb,var(--error) 32%,transparent);}
.kg-user-remove:hover{background:color-mix(in srgb,var(--error) 12%,transparent);}
.loc-opts{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;}
.loc-opt{flex:1 1 130px;min-width:0;display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:var(--muted);}
.loc-opt select{width:100%;}
/* ---------- Vault (E2E private notes) ---------- */
.vault-list{display:flex;flex-direction:column;gap:12px;}
.vault-note{background:var(--surface-high);border:1px solid var(--glass-brd);border-radius:14px;padding:13px 15px;}
.vault-note-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.vault-note-head strong{font-size:15px;}
.vault-note>p{margin:7px 0 6px;color:var(--ink);white-space:pre-wrap;font-size:14px;line-height:1.5;}
.vault-note .meta{font-size:11px;}
.vault-setup{display:flex;flex-direction:column;gap:14px;align-items:flex-start;}
#vaultForm textarea{resize:vertical;min-height:96px;}
.vault-photo-pick{display:inline-flex;align-items:center;gap:8px;margin-top:10px;padding:9px 14px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:600;border:1px dashed color-mix(in srgb,var(--accent) 34%,var(--glass-brd));background:transparent;color:var(--muted);transition:color .12s,border-color .12s;}
.vault-photo-pick:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 55%,transparent);}
.vault-photo-pick svg{width:17px;height:17px;}
.vault-photo-thumb{display:block;width:100%;padding:0;border:none;background:none;cursor:zoom-in;border-radius:11px;overflow:hidden;margin:6px 0;}
.vault-photo-thumb img{display:block;width:100%;max-height:240px;object-fit:cover;border-radius:11px;}
.vault-cat-field{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted);}
/* Vault, organized by category */
.vault-list{display:block;}
.vault-tabs{margin-bottom:18px;}
.vault-empty{padding:8px 2px;}
.vault-cat{margin-bottom:22px;}
.vault-cat-head{display:flex;align-items:center;gap:9px;margin:0 0 11px;}
.vault-cat-head h4{margin:0;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.vault-cat-ico{display:grid;place-items:center;width:24px;height:24px;border-radius:7px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);}
.vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px;align-items:start;}
.vault-card{position:relative;background:var(--recess-bg);border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;transition:border-color .15s,transform .15s;}
.vault-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 30%,var(--glass-brd));}
.vault-note-card{display:flex;flex-direction:column;gap:6px;padding:12px 13px 13px;}
.vault-card-top{display:flex;align-items:center;justify-content:space-between;}
.vault-card-ico{color:var(--accent);display:grid;place-items:center;}
.vault-note-card>strong{font-size:14px;line-height:1.3;word-break:break-word;}
.vault-note-card>p{margin:0;color:var(--muted);font-size:13px;line-height:1.5;white-space:pre-wrap;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;}
.vault-note-card .meta{font-size:11px;}
.vault-photo-card .vault-card-thumb{display:block;width:100%;aspect-ratio:1/1;padding:0;border:none;background:var(--surface-high);cursor:zoom-in;}
.vault-photo-card .vault-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.vault-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 11px;}
.vault-card-meta{min-width:0;display:flex;flex-direction:column;}
.vault-card-meta strong{font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.vault-card-meta small{font-size:10.5px;color:var(--muted);}
.vault-card-cap{font-size:11.5px;color:var(--ink);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:1px 0 2px;}
.vault-cat-custom{margin-top:-2px;}
/* Vault item detail + comments (in the modal) */
.vault-detail-photo{display:block;width:100%;padding:0;border:none;background:none;cursor:zoom-in;border-radius:12px;overflow:hidden;margin-bottom:12px;}
.vault-detail-photo img{display:block;width:100%;max-height:46vh;object-fit:contain;background:#000;border-radius:12px;}
.vault-detail-body{white-space:pre-wrap;font-size:14px;line-height:1.6;color:var(--ink);margin:0 0 10px;}
.vault-detail-foot{display:flex;justify-content:flex-end;margin-bottom:6px;}
.vault-detail-del{color:var(--tertiary,#f0758a)!important;font-weight:700;font-size:13px;}
.vault-comments-title{margin:14px 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);}
.vault-comments{display:flex;flex-direction:column;gap:9px;margin-bottom:12px;}
.vault-comment{background:var(--recess-bg);border:1px solid var(--glass-brd);border-radius:11px;padding:9px 11px;}
.vault-comment-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:3px;}
.vault-comment-head strong{font-size:13px;}
.vault-comment-head small{font-size:10.5px;color:var(--muted);}
.vault-comment>p{margin:0;font-size:13.5px;line-height:1.5;white-space:pre-wrap;}
.vault-comment-form{display:flex;gap:8px;align-items:flex-end;}
.vault-comment-form textarea{flex:1;resize:vertical;min-height:42px;}
.vault-comment-form button{flex:0 0 auto;}
.vault-comment-actions{display:flex;align-items:center;gap:6px;}
.vc-act{border:none;background:transparent;color:var(--muted);cursor:pointer;width:24px;height:24px;border-radius:6px;display:grid;place-items:center;font-size:16px;line-height:1;transition:background .12s,color .12s;}
.vc-act:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);}
.vault-comment-edit{display:flex;flex-direction:column;gap:8px;}
.vault-comment-edit textarea{resize:vertical;}
.vault-comment-edit .edit-actions,.vault-item-edit .edit-actions{display:flex;gap:8px;}
.vault-comment-edit .edit-actions button,.vault-item-edit .edit-actions button{flex:1;}
.vault-item-edit label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted);}
.vault-detail-photo-static{display:block;width:100%;max-height:34vh;object-fit:contain;background:#000;border-radius:12px;margin-bottom:12px;}
/* Family messaging (chat) */
.msg-shell{display:flex;flex-direction:column;height:min(68vh,640px);padding:0;overflow:hidden;}
.msg-list{flex:1;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:10px;padding:18px;}
.msg-empty{margin:auto;text-align:center;max-width:34ch;}
.msg-row{display:flex;flex-direction:column;align-items:flex-start;max-width:78%;}
.msg-row.mine{align-self:flex-end;align-items:flex-end;}
.msg-who{font-size:11px;font-weight:700;color:var(--accent);margin:0 0 3px 12px;}
.msg-bubble{background:var(--recess-bg);border:1px solid var(--glass-brd);border-radius:16px 16px 16px 4px;padding:9px 13px;}
.msg-row.mine .msg-bubble{background:color-mix(in srgb,var(--accent-strong) 20%,var(--surface-high));border-color:color-mix(in srgb,var(--accent) 30%,var(--glass-brd));border-radius:16px 16px 4px 16px;}
.msg-bubble>p{margin:0;font-size:14px;line-height:1.45;white-space:pre-wrap;word-break:break-word;}
.msg-time{display:block;margin-top:4px;font-size:10.5px;color:var(--muted);}
.msg-del{background:none;border:none;padding:0;color:var(--muted);font:inherit;font-size:10.5px;cursor:pointer;text-decoration:underline;}
.msg-del:hover{color:var(--tertiary,#f0758a);}
.msg-compose{display:flex;gap:10px;padding:12px 14px;border-top:1px solid var(--glass-brd);background:var(--surface-high);}
.msg-compose input{flex:1;}
.msg-compose button{flex:0 0 auto;}
@media (max-width:600px){.msg-shell{height:calc(100dvh - 220px);min-height:340px;}.msg-row{max-width:86%;}}
.vault-card .kg-del{position:static;width:24px;height:24px;flex:0 0 auto;}
.vault-card-top .kg-del{background:rgba(8,10,14,.45);}
@media (max-width:560px){.vault-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;}}
/* ---------- Meal assistant (AI) ---------- */
.kg-ai-card{background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 11%,var(--surface-high)),var(--surface-high));border:1px solid color-mix(in srgb,var(--accent) 24%,var(--glass-brd));}
.kg-ai-card #aiMealBtn{width:100%;margin-top:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;}
.kg-ai-result:empty{display:none;}
.kg-ai-result{margin-top:12px;}
.kg-ai-bubble{background:var(--surface-high);border:1px solid var(--glass-brd);border-radius:13px;padding:13px 15px;font-size:14px;line-height:1.55;}
.kg-ai-idea{display:flex;align-items:flex-start;gap:10px;padding:11px 0;border-bottom:1px solid var(--glass-brd);}
.kg-ai-idea:first-child{padding-top:0;}
.kg-ai-idea:last-child{border-bottom:none;padding-bottom:0;}
.kg-ai-idea-text{min-width:0;flex:1 1 auto;display:flex;flex-direction:column;gap:3px;}
.kg-ai-idea-text strong{font-size:14px;line-height:1.3;}
.kg-ai-idea-text span{color:var(--muted);font-size:13px;line-height:1.5;}
.kg-ai-save{flex:0 0 auto;border:1px solid color-mix(in srgb,var(--accent) 40%,var(--glass-brd));background:color-mix(in srgb,var(--accent-strong) 12%,transparent);color:var(--accent);font:inherit;font-weight:700;font-size:12px;padding:6px 12px;border-radius:999px;cursor:pointer;white-space:nowrap;transition:background .15s,opacity .15s;}
.kg-ai-save:hover{background:color-mix(in srgb,var(--accent-strong) 22%,transparent);}
.kg-ai-save.is-saved{background:transparent;border-color:var(--glass-brd);color:var(--muted);cursor:default;}
.kg-ai-thinking{font-style:italic;}
.kg-ai-lead{margin:0 0 4px;}
.kg-ai-idea[role="button"]{cursor:pointer;border-radius:10px;margin:0 -8px;padding-left:8px;padding-right:8px;transition:background .12s;}
.kg-ai-idea[role="button"]:hover,.kg-ai-idea[role="button"]:focus-visible{background:color-mix(in srgb,var(--accent) 8%,transparent);outline:none;}
.kg-ai-view{color:var(--accent);font-weight:700;font-size:12px;margin-top:2px;}
.kg-ai-detail .kg-ai-back{border:none;background:transparent;color:var(--accent);font:inherit;font-weight:700;font-size:13px;padding:0 0 8px;cursor:pointer;}
.kg-ai-title{margin:2px 0 2px;font-size:17px;}
.kg-ai-blurb{color:var(--muted);font-size:13px;margin:0 0 10px;}
.kg-ai-sec{margin-top:12px;}
.kg-ai-sec>strong{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px;}
.kg-ai-sec ul,.kg-ai-sec ol{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:5px;}
.kg-ai-sec li{font-size:13.5px;line-height:1.5;}
.kg-ai-save-lg{width:100%;margin-top:16px;text-align:center;padding:10px;font-size:13px;}
.loc-pass-btn{width:100%;margin-top:2px;}
.loc-actions #locShareBtn.is-on{background:var(--error);color:#fff;}
.loc-qr{display:grid;place-items:center;background:#fff;border-radius:14px;padding:14px;margin:14px 0;}
.loc-qr svg{width:206px;height:206px;display:block;}
.loc-or{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;margin:16px 0;}
.loc-or::before,.loc-or::after{content:"";flex:1;height:1px;background:var(--glass-brd);}
.loc-link-btn{background:none;border:none;padding:0;color:var(--accent-strong);font:inherit;font-weight:700;cursor:pointer;text-decoration:underline;}
/* Recovery key panel */
.reckey-created{background:color-mix(in srgb,var(--ok,#34d399) 14%,transparent);border:1px solid color-mix(in srgb,var(--ok,#34d399) 40%,transparent);border-radius:12px;padding:11px 13px;font-size:13.5px;line-height:1.5;margin-bottom:14px;}
.reckey-box{background:var(--recess-bg);border:1px solid var(--glass-brd);border-radius:13px;padding:13px 14px;margin:12px 0;}
.reckey-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;margin-bottom:7px;}
.reckey-code{display:block;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.5;word-break:break-all;color:var(--ink);background:rgba(0,0,0,.18);border-radius:9px;padding:9px 11px;user-select:all;}
.reckey-actions{display:flex;gap:8px;margin-top:10px;}
.reckey-actions button{flex:1;}
.reckey-warn{color:var(--tertiary,#f0a35e);font-size:12.5px;line-height:1.5;margin:10px 0 4px;}
.reckey-share{margin-top:14px;border-top:1px solid var(--glass-brd);padding-top:10px;}
.reckey-share>summary{cursor:pointer;font-weight:700;font-size:13px;color:var(--accent-strong);}
.reckey-reset{margin-top:14px;font-size:12.5px;}
.reckey-saved{color:var(--ok,#34d399);font-size:12.5px;font-weight:600;margin:0 0 10px;}
.reckey-saved:empty{display:none;}
.loc-member-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;}
.loc-member-list li{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid var(--glass-brd);}
.loc-member-list li:last-child{border-bottom:none;}
.loc-member-list li.loc-empty{display:block;color:var(--muted);border:none;padding:10px 4px;}
.loc-who{flex:1;min-width:0;display:flex;flex-direction:column;}
.loc-who strong{font-weight:650;}
.loc-dot{width:11px;height:11px;border-radius:50%;flex:none;background:var(--secondary,#34c759);box-shadow:0 0 0 3px color-mix(in srgb,var(--secondary,#34c759) 22%,transparent);}
.loc-dot.me{background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent);}
.loc-dot.dim{background:var(--muted);box-shadow:none;opacity:.5;}
.loc-pin{display:grid;place-items:center;border-radius:50%;background:var(--secondary,#34c759);color:#fff;font-weight:800;font-size:12px;
  border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.4);}
.loc-pin.me{background:var(--accent);}
.loc-pin span{line-height:1;}

/* ---------- Hearthyn brand lockup (login / signup hero) ---------- */
.topbar-logo{width:24px;height:24px;border-radius:7px;}
.brand-lockup{display:flex;align-items:center;gap:13px;margin-bottom:6px;}
.brand-lockup img{width:48px;height:48px;border-radius:13px;box-shadow:0 6px 18px rgba(239,90,68,.28);}
.brand-lockup .brand-name{font-size:27px;font-weight:800;letter-spacing:-.015em;color:var(--ink);}
.brand-full{width:184px;max-width:62%;height:auto;display:block;margin:0 0 16px;}
@media (max-width:720px){.brand-full{margin-inline:auto;}}

/* Calendar: add-event button + meal-plan chip remove */
.kg-cal-add-btn{height:34px;padding:0 13px;border-radius:10px;border:none;cursor:pointer;font-weight:700;font-size:13px;
  background:color-mix(in srgb,var(--accent-strong) 90%,#000 0%);color:#fff;}
.kg-cal-add-btn:hover{filter:brightness(1.06);}
.kg-meal-chip-row{display:flex;align-items:center;gap:1px;}
.kg-meal-chip-row .kg-meal-chip{flex:1;min-width:0;}
.kg-meal-chip-x{flex:none;width:17px;height:17px;border:none;background:transparent;color:var(--muted);cursor:pointer;
  border-radius:5px;font-size:15px;line-height:1;display:grid;place-items:center;opacity:.55;padding:0;}
.kg-meal-chip-x:hover{background:color-mix(in srgb,var(--error) 22%,transparent);color:var(--error);opacity:1;}
.recipe-search-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);}
.recipe-search-field input{width:100%;}
.recipe-ingredient-list{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto;margin-top:10px;padding-right:2px;}
.recipe-ingredient-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:12px;background:var(--recess-bg);border:1px solid var(--glass-brd);cursor:pointer;}
.recipe-ingredient-row input[type=checkbox]{width:18px;height:18px;flex:none;accent-color:var(--accent-strong);}
.recipe-ingredient-row>span{flex:1;min-width:0;display:flex;flex-direction:column;}
.recipe-ingredient-row>span strong{font-weight:600;font-size:14px;} .recipe-ingredient-row>span small{color:var(--muted);font-size:12px;}
.recipe-ingredient-row [data-recipe-amount]{flex:none;width:120px;}
.recipe-card-stats{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--muted);margin-top:4px;}
/* Inline edit forms (pantry / pet) */
.edit-form-head{display:flex;flex-direction:column;gap:2px;margin-bottom:4px;}
.edit-form-head strong{font-weight:700;font-size:16px;} .edit-form-head .meta{color:var(--muted);font-size:13px;}
.edit-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px;}
.file-row{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);}
.existing-photos-grid{display:flex;flex-wrap:wrap;gap:8px;}
.pantry-photo-detail{margin-top:6px;} .pantry-photo-detail>summary{cursor:pointer;font-weight:600;font-size:13px;color:var(--accent);}
/* Household projects (Maintenance) */
.project-card-list{display:flex;flex-direction:column;gap:12px;}
.app-project-category,.project-category{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;}
.project-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.project-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.project-progress{height:8px;border-radius:999px;background:var(--surface-highest);overflow:hidden;margin-top:8px;}
.project-progress>span{display:block;height:100%;background:var(--accent-strong);border-radius:999px;}
.project-category-delete{margin-left:auto;}
/* Calendar status chips */
.calendar-status-card{display:flex;flex-direction:column;gap:10px;}
.calendar-chip-row{display:flex;flex-wrap:wrap;gap:8px;}
.calendar-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:var(--recess-bg);border:1px solid var(--glass-brd);font-size:13px;font-weight:600;}
/* Notification list chips */
.notification-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);font-size:12px;font-weight:700;}
.notification-meta{color:var(--muted);font-size:12px;}
/* Theme-picker color previews (chips already render; this adds the light/dark/auto hint) */
.theme-chip-light .theme-chip-card{background:linear-gradient(135deg,#ffffff,#e9edf7);color:#1a1d27;}
.theme-chip-dark .theme-chip-card{background:linear-gradient(135deg,#11131a,#1f2433);}
.theme-chip-auto .theme-chip-card{background:linear-gradient(135deg,#ffffff 0 50%,#161a25 50% 100%);}
