/* ============================================================
   Our Kitchen — "editorial sage" design system (wireframe 2e / 4a).
   ONE component set; themes change tokens ONLY, never layout.
   Token contract: --bg --surface --line --accent --accent-soft
                   --text --muted  + serif/sans pair.
   Type: Newsreader (serif, italic screen titles) + Hanken Grotesk (UI).
   ============================================================ */
:root{
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',ui-sans-serif,system-ui,sans-serif;
  --radius:18px;
  --maxw:460px;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
  --shadow:0 1px 2px rgba(0,0,0,.04),0 10px 30px -18px rgba(0,0,0,.35);
}

/* ---------- THEMES (tokens only) ---------- */
body[data-theme="sage"]{
  --bg:#f3f1ea; --surface:#ffffff; --line:#e3e0d6; --raise:#faf9f4;
  --accent:#3f9b6f; --accent-2:#2f7d57; --accent-soft:#e4efe7; --on-accent:#ffffff;
  --text:#1f2a24; --muted:#6d7670; --warn:#c2611f; --warn-soft:#f6e7d6;
  --grad:linear-gradient(150deg,#9ec9ae,#6aa985 55%,#3f9b6f);
}
body[data-theme="paper"]{
  --bg:#efece6; --surface:#fbfaf6; --line:#e0dccf; --raise:#f4f1e9;
  --accent:#6c7a3a; --accent-2:#566230; --accent-soft:#e9ead7; --on-accent:#fbfaf6;
  --text:#262219; --muted:#736d5d; --warn:#a8602a; --warn-soft:#f0e4d4;
  --grad:linear-gradient(150deg,#cdb98f,#b59a63 55%,#6c7a3a);
}
body[data-theme="crimson"]{
  --bg:#f4efec; --surface:#ffffff; --line:#e6ddd8; --raise:#faf5f2;
  --accent:#b23a48; --accent-2:#8d2b38; --accent-soft:#f1e0e0; --on-accent:#ffffff;
  --text:#241a1a; --muted:#7a6a68; --warn:#bb5a1c; --warn-soft:#f5e3d2;
  --grad:linear-gradient(150deg,#e1a39a,#cf7468 55%,#b23a48);
}
body[data-theme="botanical"]{
  --bg:#f1f0e8; --surface:#fcfbf4; --line:#dfe0ce; --raise:#f5f4ea;
  --accent:#1f5c4d; --accent-2:#16463b; --accent-soft:#dde9e0; --on-accent:#fdf8e6;
  --text:#1b241f; --muted:#65706a; --warn:#9a7b1e; --warn-soft:#efe6cd;
  --grad:linear-gradient(150deg,#a9c7a3,#5f9277 55%,#1f5c4d);
}
body[data-theme="mono"]{
  --bg:#f4f3f1; --surface:#ffffff; --line:#e2e0dc; --raise:#f8f7f5;
  --accent:#1a1a1a; --accent-2:#000000; --accent-soft:#e8e7e4; --on-accent:#ffffff;
  --text:#161616; --muted:#737170; --warn:#5a5a5a; --warn-soft:#e6e5e3;
  --grad:linear-gradient(150deg,#cfcdc8,#9c9a96 55%,#1a1a1a);
}
body[data-theme="purple"]{
  --bg:#f2f0f6; --surface:#ffffff; --line:#e4dfee; --raise:#f8f6fc;
  --accent:#6b4bb0; --accent-2:#543a8c; --accent-soft:#e8e1f4; --on-accent:#ffffff;
  --text:#211d2b; --muted:#6f6981; --warn:#b06a1f; --warn-soft:#f1e6d4;
  --grad:linear-gradient(150deg,#c4b1e6,#9678cc 55%,#6b4bb0);
}
body[data-theme="pink"]{
  --bg:#f8eef1; --surface:#ffffff; --line:#f0dde3; --raise:#fdf5f7;
  --accent:#c2548a; --accent-2:#9d3f6f; --accent-soft:#f6e0ea; --on-accent:#ffffff;
  --text:#2a1c23; --muted:#806873; --warn:#c06b22; --warn-soft:#f5e5d3;
  --grad:linear-gradient(150deg,#eeb4cf,#dd83ad 55%,#c2548a);
}

*{box-sizing:border-box}
html{color-scheme:light}
html,body{height:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:16px;line-height:1.4;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overscroll-behavior-y:none;-webkit-tap-highlight-color:transparent;
  min-height:100vh;min-height:100dvh;
  display:flex;flex-direction:column;align-items:center;
}
button{font-family:var(--sans);cursor:pointer;color:inherit}
input,textarea,select{font-family:var(--sans);font-size:16px;color:var(--text)}
[data-action],[data-nav],[data-back],[data-tab],[data-change]{cursor:pointer}
.serif{font-family:var(--serif)}
.boot{margin:auto;font-family:var(--serif);font-style:italic;font-size:26px;color:var(--accent)}

/* press feedback */
.btn:active,.ghost:active,.chip:active,.row:active,.slot:active,#tabbar button:active,.card:active{
  transform:translateY(1px);
}
.fadein{animation:fade .22s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- app frame ---------- */
#app{
  width:100%;max-width:var(--maxw);flex:1;
  padding:calc(var(--safe-top) + 8px) 16px 18px;
  position:relative;z-index:1;
}
#app.has-tabs{padding-bottom:calc(64px + var(--safe-bot) + 14px)}

/* status bar (brand + scope switch + members) */
.statusbar{display:flex;align-items:center;gap:10px;padding:6px 2px 10px}
.statusbar .brand{font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.01em}
.statusbar .grow{flex:1}
.sbtn{border:1px solid var(--line);background:var(--surface);border-radius:999px;
  padding:6px 11px;font-size:12.5px;font-weight:600;color:var(--muted);display:inline-flex;gap:6px;align-items:center}
.sbtn.on{color:var(--accent);border-color:var(--accent)}

.appbar{display:flex;align-items:center;gap:8px;padding:4px 0 12px}
.appbar .back{border:none;background:none;font-size:26px;line-height:1;color:var(--text);padding:0 6px 0 0;margin-left:-6px}
.appbar .title{font-family:var(--serif);font-style:italic;font-size:24px;font-weight:600}
.grow{flex:1}

/* section eyebrow + screen title */
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:14px 0 7px}
.screen-title{font-family:var(--serif);font-style:italic;font-size:30px;font-weight:600;line-height:1;margin:0 0 4px}
.dim{color:var(--muted)}
.small{font-size:13px}
.tiny{font-size:11.5px}

/* avatars */
.ava{width:26px;height:26px;border-radius:999px;display:inline-grid;place-items:center;
  font-size:11px;font-weight:800;color:var(--on-accent);background:var(--accent);flex:none;letter-spacing:.02em}
.ava.sm{width:22px;height:22px;font-size:10px}
.ava.lg{width:40px;height:40px;font-size:15px}
.avastack{display:inline-flex;align-items:center}
.avastack .ava{margin-left:-8px;border:2px solid var(--surface)}
.avastack .ava:first-child{margin-left:0}
.plusn{margin-left:-6px;background:var(--accent-soft);color:var(--accent);border:2px solid var(--surface)}

/* cards & surfaces */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pad{padding:16px}
.hero{border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.hero .photo{height:188px;background:var(--grad);position:relative;display:block}
.hero .photo .meta{position:absolute;top:12px;right:12px;background:rgba(20,20,20,.72);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.06em;padding:6px 10px;border-radius:999px}
.hero .body{padding:16px}
.hero h2{font-family:var(--serif);font-style:italic;font-weight:600;font-size:26px;margin:2px 0 8px;line-height:1.05}
.cookline{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13.5px;margin-bottom:14px}
.hero .actions{display:flex;gap:10px;align-items:center}

/* buttons */
.btn{background:var(--accent);color:var(--on-accent);border:1px solid var(--accent);
  border-radius:12px;padding:12px 16px;font-weight:700;font-size:14.5px;line-height:1;display:inline-flex;
  gap:8px;align-items:center;justify-content:center}
.btn.block{width:100%}
.btn.lg{padding:15px 18px;font-size:15.5px}
.ghost{background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:12px;
  padding:12px 16px;font-weight:700;font-size:14px;display:inline-flex;gap:7px;align-items:center;justify-content:center}
.ghost.accent{color:var(--accent);border-color:var(--accent)}
.linkbtn{background:none;border:none;color:var(--accent);font-weight:700;font-size:13.5px;padding:6px 2px}
.fab{position:fixed;right:calc(50% - var(--maxw)/2 + 16px);bottom:calc(64px + var(--safe-bot) + 16px);
  width:54px;height:54px;border-radius:999px;background:var(--accent);color:var(--on-accent);border:none;
  font-size:26px;box-shadow:0 8px 22px -6px rgba(0,0,0,.4);z-index:30;display:grid;place-items:center}
@media(max-width:480px){.fab{right:16px}}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:999px;
  padding:7px 12px;font-size:12.5px;font-weight:600;display:inline-flex;gap:6px;align-items:center}
.chip.on{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.chip.soft{background:var(--accent-soft);color:var(--accent-2);border-color:transparent}
.chip.warn{background:var(--warn-soft);color:var(--warn);border-color:transparent}
.chip.sm{padding:4px 9px;font-size:11px}

/* coming-up cards / recipe cards */
.scroller{display:flex;gap:10px;overflow-x:auto;padding:2px 0 6px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.scroller::-webkit-scrollbar{display:none}
.minicard{flex:none;width:110px;scroll-snap-align:start}
.minicard .thumb{height:74px;border-radius:14px;background:var(--grad);opacity:.9;border:1px solid var(--line)}
.minicard .cap{font-size:12px;margin-top:6px;font-weight:600;line-height:1.2}
.minicard .cap span{color:var(--muted);font-weight:500}

.rcard{display:flex;gap:12px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}
.rcard .thumb{width:64px;height:64px;border-radius:12px;background:var(--grad);flex:none;opacity:.92;border:1px solid var(--line)}
.rcard .rt{flex:1;min-width:0}
.rcard .rt h3{margin:0 0 3px;font-size:15px;font-weight:700;font-family:var(--serif);font-style:italic}
.rcard .rt .sub{font-size:12px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap}

/* generic rows (list, pantry, members, settings) */
.rows{display:flex;flex-direction:column;gap:8px}
.row{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:12px 13px}
.row .main{flex:1;min-width:0}
.row .main .t{font-weight:600;font-size:14.5px}
.row .main .s{font-size:12px;color:var(--muted);margin-top:2px}
.row.checked .t{text-decoration:line-through;color:var(--muted)}
.row.checked{opacity:.6}
.check{width:24px;height:24px;border-radius:7px;border:1.5px solid var(--line);background:var(--raise);
  display:grid;place-items:center;font-size:14px;color:var(--on-accent);flex:none}
.check.on{background:var(--accent);border-color:var(--accent)}
.qty{font-size:12.5px;color:var(--muted);font-weight:600;white-space:nowrap}

/* group header (aisles, pantry locations) */
.grouphd{display:flex;align-items:center;gap:8px;margin:16px 2px 8px}
.grouphd .h{font-size:12.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}
.grouphd .n{font-size:11px;color:var(--muted);background:var(--accent-soft);border-radius:999px;padding:1px 8px;font-weight:700}

/* week plan grid */
.weekstrip{display:flex;gap:6px;margin:6px 0 14px}
.daycol{flex:1;text-align:center;padding:8px 0;border:1px solid transparent;border-radius:12px}
.daycol .dow{font-size:10.5px;font-weight:700;color:var(--muted);letter-spacing:.04em}
.daycol .dnum{font-size:15px;font-weight:700;font-family:var(--serif);margin-top:3px}
.daycol.on{background:var(--accent);border-color:var(--accent)}
.daycol.on .dow,.daycol.on .dnum{color:var(--on-accent)}
.daycol.today:not(.on){border-color:var(--accent)}

.dayblock{margin-bottom:14px}
.dayblock .dlabel{font-size:11.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 2px 7px}
.dayblock .dlabel.is-today{color:var(--accent)}
.slotrow{display:grid;grid-template-columns:30px 1fr;gap:9px;align-items:stretch;margin-bottom:7px}
.slotrow .sl{font-size:10px;font-weight:800;color:var(--muted);padding-top:13px;letter-spacing:.06em}
.slot{border:1px solid var(--line);border-radius:13px;background:var(--surface);padding:11px 12px;min-height:46px;
  display:flex;align-items:center;gap:9px}
.slot.empty{border-style:dashed;color:var(--muted);justify-content:center;font-weight:600;font-size:13px;background:var(--raise)}
.slot .st{flex:1;font-weight:600;font-size:14px}
.slot .st .tag{font-size:11px;color:var(--muted);font-weight:500;display:block;margin-top:1px}
.slot.left{background:var(--accent-soft);border-color:transparent}

/* recipe detail */
.tabbar2{display:flex;gap:6px;background:var(--raise);border:1px solid var(--line);border-radius:12px;padding:4px;margin:14px 0}
.tabbar2 button{flex:1;border:none;background:none;padding:9px;border-radius:9px;font-weight:700;font-size:13.5px;color:var(--muted)}
.tabbar2 button.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}
.stepper{display:inline-flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.stepper button{border:none;background:var(--surface);width:34px;height:34px;font-size:18px;color:var(--accent)}
.stepper .v{min-width:34px;text-align:center;font-weight:700}
.ing{display:flex;align-items:center;gap:10px;padding:11px 2px;border-bottom:1px solid var(--line)}
.ing .nm{flex:1;font-weight:600;font-size:14.5px}
.ing .st{font-size:11.5px;font-weight:700;border-radius:999px;padding:2px 9px}
.ing .st.have{background:var(--accent-soft);color:var(--accent-2)}
.ing .st.need{background:var(--warn-soft);color:var(--warn)}
.step{display:flex;gap:12px;padding:14px 2px;border-bottom:1px solid var(--line)}
.step .no{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--accent);font-weight:600;flex:none;width:26px}
.step .tx{font-size:16px;line-height:1.5}
.cookmode .step .tx{font-size:19px}
.timer{display:inline-block;margin-top:8px;background:var(--accent-soft);color:var(--accent-2);border:none;
  border-radius:999px;padding:6px 13px;font-weight:700;font-size:13px}

/* AI plan suggestions */
.aibox{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow)}
.aibox textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px;resize:vertical;min-height:60px;background:var(--raise)}
.sugg{display:flex;align-items:center;gap:10px;padding:11px;border:1px solid var(--line);border-radius:14px;background:var(--surface);margin-bottom:8px}
.sugg.locked{border-color:var(--accent)}
.sugg .info{flex:1;min-width:0}
.sugg .info .t{font-weight:700;font-size:14px;font-family:var(--serif);font-style:italic}
.sugg .info .s{font-size:12px;color:var(--muted)}
.iconbtn{border:1px solid var(--line);background:var(--surface);border-radius:10px;width:36px;height:36px;
  display:grid;place-items:center;font-size:15px;color:var(--muted)}
.iconbtn.on{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}

/* inputs */
.field{display:block;margin:10px 0}
.field label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:5px;letter-spacing:.02em}
.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:12px;
  padding:12px;background:var(--surface)}
.search{width:100%;border:1px solid var(--line);border-radius:999px;padding:12px 16px;background:var(--surface)}

/* settings / sheet rows */
.setrow{display:flex;align-items:center;gap:12px;padding:14px 14px;background:var(--surface);border:1px solid var(--line);border-radius:14px}
.setrow+.setrow{margin-top:8px}
.setrow .lab{flex:1}
.setrow .lab .t{font-weight:600}
.setrow .lab .s{font-size:12px;color:var(--muted);margin-top:2px}
.setrow .val{color:var(--muted);font-weight:600;font-size:13.5px}
.switch{width:46px;height:28px;border-radius:999px;background:var(--line);border:none;position:relative;flex:none;transition:background .15s}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:999px;background:#fff;transition:left .15s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch.on{background:var(--accent)}
.switch.on::after{left:21px}

/* code box */
.codebox{font-family:ui-monospace,Menlo,monospace;background:var(--raise);border:1px dashed var(--line);
  border-radius:12px;padding:12px 14px;font-size:15px;letter-spacing:.04em;word-break:break-all;text-align:center}

/* banner / callout */
.callout{display:flex;gap:10px;align-items:flex-start;background:var(--accent-soft);border-radius:14px;padding:12px 14px;font-size:13.5px;color:var(--accent-2)}
.callout.warn{background:var(--warn-soft);color:var(--warn)}

/* tab bar */
#tabbar{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;justify-content:center;
  background:var(--surface);border-top:1px solid var(--line);padding-bottom:var(--safe-bot)}
#tabbar .inner{width:100%;max-width:var(--maxw);display:flex;justify-content:space-around;align-items:center;height:64px;padding:0 4px}
#tabbar button{flex:1;border:none;background:none;display:flex;flex-direction:column;align-items:center;gap:3px;
  font-size:10.5px;font-weight:700;color:var(--muted);padding:8px 0}
#tabbar button.on{color:var(--accent)}
#tabbar .ic{font-size:19px;line-height:1}

/* toast */
#toast{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(76px + var(--safe-bot));z-index:60;
  background:var(--text);color:var(--bg);padding:11px 16px;border-radius:12px;font-weight:600;font-size:13.5px;
  max-width:90vw;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:var(--shadow)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}

/* modal sheet */
#fx{position:fixed;inset:0;z-index:50;pointer-events:none}
.sheet-wrap{position:fixed;inset:0;background:rgba(20,18,14,.42);display:flex;align-items:flex-end;justify-content:center;z-index:55;pointer-events:auto;animation:fade .18s ease}
.sheet{width:100%;max-width:var(--maxw);background:var(--bg);border-radius:22px 22px 0 0;padding:18px 16px calc(20px + var(--safe-bot));
  max-height:86vh;overflow-y:auto;box-shadow:0 -10px 40px -10px rgba(0,0,0,.4);animation:slideup .24s cubic-bezier(.2,.8,.2,1)}
@keyframes slideup{from{transform:translateY(100%)}to{transform:none}}
.sheet h3{font-family:var(--serif);font-style:italic;font-size:21px;font-weight:600;margin:2px 0 12px}
.sheet .grab{width:38px;height:4px;border-radius:999px;background:var(--line);margin:0 auto 14px}

/* misc layout helpers */
.row-gap{display:flex;gap:10px}
.row-gap>*{flex:1}
.between{display:flex;align-items:center;justify-content:space-between;gap:10px}
.stat{flex:1;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 6px}
.stat .n{font-family:var(--serif);font-size:24px;font-weight:600}
.stat .l{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-top:2px}
.empty-state{text-align:center;color:var(--muted);padding:40px 18px}
.empty-state .big{font-size:40px}
.spinner{width:22px;height:22px;border:2.5px solid var(--line);border-top-color:var(--accent);border-radius:999px;animation:spin .7s linear infinite;display:inline-block;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
hr.rule{border:none;border-top:1px solid var(--line);margin:16px 0}
