/* ═══════════════════════════════════════════════════
   VARDAG — Mobile-First Responsive Stylesheet
   ═══════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F5F0E8;--surface:#FDFAF4;--surface2:#EDE8DE;--surface3:#E4DDD0;
  --text:#2C2820;--text2:#7A7060;--text3:#A89F90;
  --sage:#6B8C6B;--sage-l:#C8D9C0;--sage-d:#3D5C3D;
  --warm:#D4A96A;--warm-l:#F0E0C0;
  --red:#B85C4A;--red-l:#F0DDD8;
  --border:#E0D8C8;--border2:#C8BFB0;
  --r:10px;--r-lg:16px;--r-xl:20px;
  --font:'DM Sans',sans-serif;
  --serif:'Lora',serif;
  --content-max:1100px;
}
html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}
button,a,[role="button"],input,select,textarea{-webkit-tap-highlight-color:transparent}
button:focus:not(:focus-visible),a:focus:not(:focus-visible),[role="button"]:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}
button:focus-visible,a:focus-visible,[role="button"]:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid rgba(107,140,107,.45);outline-offset:2px}
button:active:not(:disabled),[role="button"]:active,.nav-item:active,.qa:active,.chip:active,.stat-link:active{transform:translateY(1px) scale(.985);filter:brightness(.96)}
button:disabled{cursor:not-allowed;opacity:.65}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── LAYOUT ── */
.app{display:flex;height:100vh;overflow:hidden}
.hidden{display:none!important}
.app-loading-overlay{position:fixed;inset:0;z-index:120;background:rgba(245,240,232,.94);display:flex;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(6px);transition:opacity .2s ease}
.app-loading-shell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center}
.app-loading-brand{font-family:var(--serif);font-size:38px;line-height:1;color:var(--text);letter-spacing:-.03em;text-shadow:0 10px 26px rgba(44,40,32,.08)}
.app-loading-brand em{color:var(--sage);font-style:normal}
.app-loading-spinner{position:relative;width:120px;height:120px}
.app-loading-ring{position:absolute;inset:0;animation:app-loading-ring-spin 3s linear infinite}
.app-loading-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--sage);top:50%;left:50%;transform-origin:0 0;opacity:.25}
.app-loading-dot:nth-child(1){transform:rotate(0deg) translate(52px,-4px);opacity:1}
.app-loading-dot:nth-child(2){transform:rotate(45deg) translate(52px,-4px);opacity:.85}
.app-loading-dot:nth-child(3){transform:rotate(90deg) translate(52px,-4px);opacity:.7}
.app-loading-dot:nth-child(4){transform:rotate(135deg) translate(52px,-4px);opacity:.55}
.app-loading-dot:nth-child(5){transform:rotate(180deg) translate(52px,-4px);opacity:.4}
.app-loading-dot:nth-child(6){transform:rotate(225deg) translate(52px,-4px);opacity:.3}
.app-loading-dot:nth-child(7){transform:rotate(270deg) translate(52px,-4px);opacity:.2}
.app-loading-dot:nth-child(8){transform:rotate(315deg) translate(52px,-4px);opacity:.12}
.app-loading-ring2{position:absolute;inset:14px;animation:app-loading-ring-spin 2s linear infinite reverse}
.app-loading-dash{position:absolute;width:10px;height:3px;border-radius:2px;background:var(--warm);top:50%;left:50%;transform-origin:0 0;opacity:.2}
.app-loading-dash:nth-child(1){transform:rotate(0deg) translate(38px,-1.5px);opacity:1}
.app-loading-dash:nth-child(2){transform:rotate(60deg) translate(38px,-1.5px);opacity:.7}
.app-loading-dash:nth-child(3){transform:rotate(120deg) translate(38px,-1.5px);opacity:.5}
.app-loading-dash:nth-child(4){transform:rotate(180deg) translate(38px,-1.5px);opacity:.35}
.app-loading-dash:nth-child(5){transform:rotate(240deg) translate(38px,-1.5px);opacity:.2}
.app-loading-dash:nth-child(6){transform:rotate(300deg) translate(38px,-1.5px);opacity:.1}
.app-loading-centre{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;display:flex;align-items:center;justify-content:center;animation:app-loading-centre-pulse 1.6s ease-in-out infinite}
.app-loading-pan{display:block}
.app-loading-wisp{position:absolute;left:50%;bottom:68px;width:5px;height:5px;border-radius:50%;background:#B8CDB0;opacity:0;animation:app-loading-wisp-up 1.8s ease-out infinite}
.app-loading-wisp-1{margin-left:-8px;animation-delay:0s}
.app-loading-wisp-2{margin-left:0;width:4px;height:4px;animation-delay:.55s}
.app-loading-wisp-3{margin-left:8px;animation-delay:1.1s}

.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.landing.hidden{display:none}
.landing-inner{width:min(100%,440px)}
.landing-brand{font-family:var(--serif);font-size:32px;margin-bottom:18px;color:var(--text)}
.landing-brand em{color:var(--sage);font-style:normal}
.landing h1{font-family:var(--serif);font-size:34px;line-height:1.08;margin-bottom:12px;font-weight:500}
.landing p{font-size:15px;line-height:1.6;color:var(--text2);margin-bottom:22px}
.landing .finput,.landing textarea,.landing select{user-select:text;-webkit-user-select:text;-webkit-touch-callout:default}
.landing-note{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:18px!important}
.landing-form{display:flex;gap:8px;align-items:center}
.landing-form .finput{flex:1}
.landing-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--text3);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.landing-divider::before,.landing-divider::after{content:'';height:1px;flex:1;background:var(--border)}
.landing-divider span{white-space:nowrap}
.landing-invite-card{background:linear-gradient(180deg,rgba(253,250,244,.96) 0%,rgba(237,232,222,.92) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:0 14px 30px rgba(44,40,32,.06)}
.landing-invite-head h2{font-family:var(--serif);font-size:21px;font-weight:500;line-height:1.15;margin-bottom:8px;color:var(--text)}
.landing-invite-head p{margin-bottom:14px;font-size:13.5px;line-height:1.55;color:var(--text2)}
.landing-invite-form{display:grid;gap:10px}
.landing-invite-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.landing-invite-actions .btn{min-width:104px;justify-content:center}
.landing-error{min-height:20px;margin-top:10px;color:var(--red);font-size:12px}
.pin-gate-inner{width:min(100%,360px)}
.pin-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:0 12px 32px rgba(44,40,32,.08)}
.pin-gate{height:100vh;min-height:100dvh;overflow:hidden;padding:22px}
.pin-gate .landing-note{background:transparent;border:0;padding:0;margin-bottom:18px!important}
.pin-gate .pin-card{background:transparent;border:0;border-radius:0;padding:0;box-shadow:none}
.pin-gate-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--text2);font-size:13px}
.pin-gate-footer .btn{white-space:nowrap}

/* ── SIDEBAR (mobile: off-canvas) ── */
.sidebar-overlay{position:fixed;inset:0;background:rgba(44,40,32,.4);z-index:49;opacity:0;pointer-events:none;transition:opacity .25s}
.sidebar-overlay.open{opacity:1;pointer-events:all}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;z-index:50;transform:translateX(-100%);transition:transform .25s ease}
.sidebar.open{transform:translateX(0)}
.logo{padding:22px 20px 18px;border-bottom:1px solid var(--border)}
.logo{cursor:pointer}
.logo-word{font-family:var(--serif);font-size:23px;letter-spacing:-.3px;color:var(--text)}
.logo-word em{color:var(--sage);font-style:normal}
.logo-sub{font-size:10.5px;color:var(--text3);letter-spacing:.5px;margin-top:2px}
.nav{padding:10px 0;flex:1;overflow-y:auto}
.nav-sec{font-size:10px;letter-spacing:1.2px;color:var(--text3);padding:12px 20px 4px;text-transform:uppercase;font-weight:500}
.nav-item{display:flex;align-items:center;gap:10px;padding:11px 20px;cursor:pointer;color:var(--text2);font-size:14px;transition:all .15s;border-left:3px solid transparent;user-select:none}
.nav-item i{font-size:18px;width:22px;flex-shrink:0}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:var(--sage-l);color:var(--sage-d);border-left-color:var(--sage);font-weight:500}
.sidebar-foot{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .15s}
.sidebar-foot:hover,.sidebar-foot:focus-visible{background:var(--surface2);outline:none}
.hh-av{width:30px;height:30px;border-radius:50%;background:var(--sage-l);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--sage-d);font-weight:600;flex-shrink:0}
.hh-name{font-size:12px;font-weight:500}
.hh-sub{font-size:10.5px;color:var(--text3)}

/* ── MAIN ── */
.main{flex:1;overflow-y:auto;background:var(--bg);display:flex;flex-direction:column;width:100%}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:48;flex-shrink:0;box-shadow:0 2px 14px rgba(44,40,32,.06)}
.hamburger{font-size:20px;width:34px;height:34px}
.topbar-actions{display:flex;gap:7px;margin-left:auto}
.page-title{font-family:var(--serif);font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-brand{display:none;font-family:var(--serif);font-size:20px;color:var(--text);white-space:nowrap;cursor:pointer}
.mobile-brand em{color:var(--sage);font-style:normal}
.content{padding:16px;flex:1;width:100%;max-width:var(--content-max);margin:0 auto}
.page{display:none}.page.active{display:block}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:13px;cursor:pointer;font-family:var(--font);font-weight:400;transition:all .15s;white-space:nowrap;line-height:1.4}
.btn:hover{background:var(--surface2);color:var(--text)}
.btn-primary{background:var(--sage);color:#fff;border-color:var(--sage-d)}
.btn-primary:hover{background:var(--sage-d)}
.btn-danger{color:var(--red);border-color:var(--red-l)}
.btn-danger:hover{background:var(--red-l)}
.btn-saved{background:var(--surface2);color:var(--text3);border-color:var(--border);pointer-events:none}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-xs{padding:3px 8px;font-size:11px}
.ibtn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--text3);font-size:16px;transition:all .15s;font-family:inherit;flex-shrink:0}
.ibtn:hover{background:var(--surface2);color:var(--text2)}
.ibtn.d:hover{background:var(--red-l);color:var(--red)}

/* ── FORMS ── */
.fg{margin-bottom:16px}
.fg:last-child{margin-bottom:0}
.fg-no-mb{margin-bottom:0}
.fg-span2{grid-column:span 2}
.fg-row-compact{margin-bottom:14px}
.flabel{display:block;font-size:11.5px;font-weight:500;color:var(--text2);margin-bottom:6px;letter-spacing:.2px}
.flabel .opt{font-weight:400;color:var(--text3);font-size:10.5px;margin-left:4px}
.finput{width:100%;padding:10px 12px;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);font-size:14px;font-family:var(--font);color:var(--text);outline:none;transition:border-color .15s;line-height:1.4}
.finput:focus{border-color:var(--sage)}
.finput::placeholder{color:var(--text3)}
textarea.finput{resize:vertical;min-height:72px;line-height:1.5}
select.finput{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23A89F90' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.frow{display:grid;gap:16px}
.frow-2{grid-template-columns:1fr}
.frow-3{grid-template-columns:1fr}
.frow-4{grid-template-columns:1fr 1fr}
.fhint{font-size:11px;color:var(--text3);margin-top:3px}
.input-pair{display:flex;gap:5px}
.input-pair .finput{flex:1}
.input-pair #g-qty{flex:1.35}
.input-pair #g-unit{flex:.8}
.settings-input{width:100%}
.settings-select{width:100%}
.start-date-input{width:100%}
.recurring-dom-input{width:90px}
.hidden-input{display:none}

/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(44,40,32,.38);z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .2s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;border:1px solid var(--border);border-bottom:none;width:100%;max-width:100%;max-height:92vh;display:flex;flex-direction:column;transform:translateY(20px);transition:transform .2s;overflow:hidden;box-shadow:0 -4px 32px rgba(44,40,32,.14)}
.overlay.open .modal{transform:none}
.modal.wide{max-width:100%}
.recipe-view-loading-modal{max-width:min(100%,420px);max-height:none;border-radius:var(--r-xl);border-bottom:1px solid var(--border);transform:translateY(12px)}
.recipe-view-loading-body{display:flex;align-items:center;justify-content:center;min-height:220px;padding:40px 24px}
.recipe-view-spinner{transform:scale(.9)}
.mhead{padding:16px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.mtitle{font-family:var(--font);font-size:16px}
.mbody{padding:16px 18px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.mfoot{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}
.modal-note{font-size:13px;line-height:1.55;color:var(--text2);margin-bottom:16px}

/* ── TOGGLE ── */
.toggle{width:44px;height:24px;border-radius:12px;background:var(--sage);border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .2s}
.toggle::after{content:'';position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:2px;right:2px;transition:all .2s}
.toggle.off{background:var(--border2)}
.toggle.off::after{right:auto;left:2px}

/* ── CARDS / GRIDS ── */
.g4{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.g2{display:grid;grid-template-columns:1fr;gap:14px}
.g3{display:grid;grid-template-columns:1fr;gap:12px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px}
.stat-link{cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.stat-link:hover,.stat-link:focus-visible{border-color:var(--sage);box-shadow:0 4px 14px rgba(44,40,32,.09);transform:translateY(-1px);outline:none}
.stat-main{display:flex;align-items:center;gap:10px}
.stat-icon{width:34px;height:34px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.ic-sage{background:var(--sage-l);color:var(--sage-d)}
.ic-warm{background:var(--warm-l);color:#7A5010}
.ic-red{background:var(--red-l);color:var(--red)}
.ic-blue{background:#E8EFF5;color:#4A7090}
.stat-label{font-size:10.5px;color:var(--text3);letter-spacing:.3px;margin-bottom:3px}
.stat-val{font-family:var(--font);font-size:24px;line-height:1}
.sec-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.sec-title{font-family:var(--font);font-size:15px}
.divider{height:1px;background:var(--border);margin:14px 0}

/* ── DASHBOARD ── */
.dash-intro{margin-bottom:16px}
.dash-date{font-family:var(--font);font-size:13px;color:var(--text3);font-style:italic;margin-bottom:3px}
.dash-summary{font-size:13px;color:var(--text2)}
.dash-progress{display:flex;flex-direction:column;gap:13px;margin-top:2px}
.prog-row{}
.prog-labels{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px}
.prog-lbl{color:var(--text2)}
.inspire-recipe{display:flex;gap:12px;align-items:stretch;cursor:pointer;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;background:var(--surface);transition:border-color .15s,box-shadow .15s,transform .15s}
.inspire-recipe:hover,.inspire-recipe:focus-visible{border-color:var(--sage);box-shadow:0 4px 14px rgba(44,40,32,.09);transform:translateY(-1px);outline:none}
.inspire-recipe .rec-thumb{width:96px;height:auto;min-height:96px;flex-shrink:0}
.inspire-body{padding:12px 12px 12px 0;min-width:0;flex:1}

/* ── QUICK ACTIONS ── */
.qa-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-bottom:18px}
.qa{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 10px;text-align:center;cursor:pointer;transition:all .15s}
.qa:hover{border-color:var(--sage);background:var(--sage-l)}
.qa-ic{font-size:22px;margin-bottom:6px;color:var(--sage)}
.qa-lbl{font-size:11px;color:var(--text2)}

/* ── FILTER ── */
.filter-bar{display:flex;gap:5px;flex-wrap:wrap}
.chip{padding:5px 13px;border-radius:20px;border:1px solid var(--border2);background:var(--surface);font-size:12px;color:var(--text2);cursor:pointer;transition:all .15s;user-select:none}
.chip.active{background:var(--sage);border-color:var(--sage-d);color:#fff}
.chip:hover:not(.active){background:var(--surface2)}

/* ── QUICK ADD ── */
.qadd{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.qadd input{flex:1;min-width:0;padding:10px 14px;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);font-size:14px;font-family:var(--font);color:var(--text);outline:none;transition:border-color .15s}
.qadd input:focus{border-color:var(--sage)}
.qadd input::placeholder{color:var(--text3)}

/* ── GROCERY LIST ── */
.grocery-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:13px;flex-wrap:wrap;gap:8px}
.glist{display:flex;flex-direction:column;gap:4px}
.cat-head{font-size:10.5px;color:var(--text3);letter-spacing:.9px;text-transform:uppercase;padding:13px 8px 4px;font-weight:500;display:flex;align-items:center;justify-content:space-between;gap:8px}
.pantry-cat-head{color:#7A5010}
.bought-cat-head{color:var(--sage-d)}
.cat-add-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--sage-d);background:var(--sage);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:all .15s;flex-shrink:0}
.cat-add-btn:hover,.cat-add-btn:focus-visible{background:var(--sage-d);outline:none;box-shadow:0 2px 8px rgba(61,92,61,.22)}
.cat-add-btn:active{transform:scale(.94)}
.cat-clear-btn{min-height:26px;border-radius:var(--r);border:1px solid var(--red-l);background:var(--surface);color:var(--red);display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:4px 8px;font-size:11px;font-family:var(--font);cursor:pointer;transition:all .15s;flex-shrink:0;text-transform:none;letter-spacing:0}
.cat-clear-btn:hover,.cat-clear-btn:focus-visible{background:var(--red-l);outline:none;box-shadow:0 2px 8px rgba(184,92,74,.16)}
.cat-clear-btn:active{transform:scale(.96)}
.gitem{display:flex;align-items:center;gap:10px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);transition:all .25s ease;cursor:pointer;animation:slideIn .3s ease}
.gitem:hover{border-color:var(--border2)}
.gitem.pantry-likely{background:#FFF9EA;border-color:#E7D4A8}
.gitem.done{opacity:.55}
.gitem.done .iname{text-decoration:line-through;color:var(--text3)}
.gitem.checking{animation:checkPop .35s ease}
.gitem.unchecking{animation:uncheckPop .3s ease}
.gitem.removing{animation:slideOut .3s ease forwards}
.checkbox{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}
.checkbox.on{background:var(--sage);border-color:var(--sage)}
.gitem-inner{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 10px}
.iname{font-size:14px;min-width:0}
.inotes{font-size:11px;color:var(--text3);width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.imeta{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.iqty{font-size:11.5px;color:var(--text2);white-space:nowrap}
.icat{font-size:10px;color:var(--text3);background:var(--surface2);padding:2px 7px;border-radius:10px;white-space:nowrap}
.isrc-r{font-size:10px;color:var(--sage-d);background:var(--sage-l);padding:2px 7px;border-radius:10px}
.isrc-rc{font-size:10px;color:#7A5010;background:var(--warm-l);padding:2px 7px;border-radius:10px}
.iactions{display:flex;gap:2px;opacity:1;flex-shrink:0}

/* ── PROGRESS ── */
.prog-bar{height:5px;background:var(--surface2);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;background:var(--sage);border-radius:3px;transition:width .4s}

/* ── TAGS ── */
.tag{font-size:10px;padding:2px 7px;border-radius:10px;background:var(--surface2);color:var(--text2)}
.tv{background:#E8F0E4;color:#3D6030}
.tq{background:#F0EAD8;color:#6B5020}
.tc{background:#F0E4E4;color:#6B2020}
.ts{background:#F5E8DC;color:#8C4010}
.tch{background:#EAF0E8;color:#3D5C30}
.tf{background:#EAE8F0;color:#3D3060}
.tb{background:#FFF1D8;color:#7A4A12}
.tl{background:#E3F0F1;color:#245760}
.tn{background:#F1E6D8;color:#6A4424}
.tba{background:#F3E3EC;color:#6B2C55}
.td{background:#F4E1E1;color:#7A2D3A}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;font-size:10px;padding:2px 7px;border-radius:10px}
.bs{background:var(--sage-l);color:var(--sage-d)}
.bw{background:var(--warm-l);color:#6B4A10}

/* ── RECIPE GRID ── */
.rec-grid{display:grid;grid-template-columns:1fr;gap:12px}
.rec-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .2s;position:relative}
#r-list .rec-card[data-id],#explore-list .rec-card[data-explore-id]{cursor:pointer}
.rec-card:hover{border-color:var(--border2);box-shadow:0 4px 14px rgba(44,40,32,.09)}
.rec-card:active,.rec-card.rec-card-loading{transform:scale(.97);filter:brightness(.97)}
.rec-card.rec-card-loading{pointer-events:none;opacity:.85;transition:all .15s}
.rec-thumb{height:80px;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative}
.rec-thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.rec-thumb.has-photo .rec-thumb-fallback{display:none}
.rec-thumb.image-failed .rec-thumb-img{display:none}
.rec-thumb.image-failed .rec-thumb-fallback{display:inline}
.rec-fav{position:absolute;top:8px;right:8px;background:rgba(253,250,244,.88);border:none;border-radius:50%;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text3);transition:all .15s}
.rec-fav.on{color:var(--red)}
.rec-body{padding:12px}
.rec-name{font-family:var(--font);font-size:14px;margin-bottom:4px}
.rec-meta{font-size:11px;color:var(--text3);display:flex;gap:9px;margin-bottom:8px}
.inspire-source{font-size:11px;color:var(--text3);margin:-2px 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-tags{display:flex;gap:4px;flex-wrap:wrap}
.rec-actions{display:flex;gap:5px;padding:0 12px 12px;flex-wrap:wrap}
.rec-actions .btn:first-child{flex:1;justify-content:center}

/* ── RECIPES TOOLBAR ── */
.recipes-toolbar{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.recipe-filter-row{margin-bottom:16px}
.recipe-search-line{display:grid;grid-template-columns:minmax(0,1fr) 38px;gap:8px;align-items:center}
.recipe-fav-filter{width:38px;height:38px;border:1px solid var(--border2);background:var(--surface)}
.recipe-fav-filter.active{background:var(--red-l);border-color:#E2B7AE;color:var(--red)}
.recipe-fav-filter.active i::before{content:"\eb10"}
.explore-toolbar{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.explore-title{font-family:var(--font);font-size:17px;margin-bottom:2px}
.explore-sub{font-size:12.5px;color:var(--text2);line-height:1.4}
.explore-filter-row{display:grid;grid-template-columns:1fr;gap:8px}
.explore-search-wrap{position:relative}
.explore-search-wrap i{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--text3);pointer-events:none}
.explore-search{height:38px;padding-left:34px}
.explore-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 16px 32px;user-select:none}
.explore-loader-inner{display:flex;align-items:center;gap:10px}
.explore-loader-spinner{width:22px;height:22px;border:2.5px solid var(--sage-l);border-top-color:var(--sage);border-radius:50%;animation:spin .7s linear infinite}
.explore-loader-text{font-size:13px;color:var(--text2);font-family:var(--font)}
.explore-load-more{margin-top:4px;gap:6px;font-size:13px;padding:9px 20px}
.multi-filter{position:relative}
.multi-filter summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;min-height:38px;padding:8px 12px;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);cursor:pointer;font-size:12px;color:var(--text2);user-select:none}
.multi-filter summary::-webkit-details-marker{display:none}
.multi-filter summary::after{content:'v';font-size:11px;color:var(--text3);transition:transform .15s}
.multi-filter[open] summary::after{transform:rotate(180deg)}
.multi-filter summary strong{font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;margin-left:auto;display:inline-flex;align-items:center;gap:6px;min-width:0}
.multi-menu{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:15;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 12px 32px rgba(44,40,32,.14);padding:8px;display:flex;flex-direction:column;gap:2px;max-height:260px;overflow:auto}
.multi-option{display:flex;align-items:center;gap:8px;padding:8px;border-radius:var(--r);font-size:13px;color:var(--text2);cursor:pointer}
.multi-option:hover{background:var(--surface2)}
.multi-option input{accent-color:var(--sage);width:15px;height:15px}
.multi-option span:last-child{margin-left:auto;color:var(--text3);font-size:11px}
.settings-dropdown{width:100%;max-width:150px}
.settings-dropdown summary > span:first-child{display:none}
.single-filter .multi-menu{min-width:100%}
.single-option{width:100%;border:0;background:transparent;border-radius:var(--r);padding:8px;text-align:left;font:inherit;font-size:13px;color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:8px}
.single-option:hover,.single-option.active{background:var(--surface2);color:var(--text)}
.vardag-flag{width:22px;line-height:15px;border-radius:2px;box-shadow:0 0 0 1px rgba(44,40,32,.16) inset;vertical-align:-2px;flex-shrink:0}
.recipe-import{border:1px solid var(--border);border-radius:var(--r);background:var(--surface2);padding:12px;margin-bottom:12px}
.recipe-import-row{display:flex;gap:7px;align-items:center}
.recipe-import-row .finput{flex:1;min-width:0;background:var(--surface)}
.recipe-import-status{display:flex;align-items:center;gap:7px;margin-top:9px;font-size:12px;color:var(--text2)}
.recipe-import-error{font-size:12px;color:var(--red)}
.recipe-photo-sub.error{color:var(--red)}
.recipe-import-error:not(:empty){margin-top:7px}
.recipe-photo-preview{position:relative;display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);padding:10px;margin-bottom:12px}
.recipe-photo-frame{width:72px;height:54px;border-radius:var(--r);background:var(--surface2);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;border:1px solid var(--border2);box-shadow:0 1px 0 rgba(255,255,255,.7) inset;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;padding:0;color:inherit}
.recipe-photo-frame:hover,.recipe-photo-frame:focus-visible{border-color:var(--sage-d);box-shadow:0 0 0 3px rgba(107,140,107,.16);outline:none}
.recipe-photo-frame:active{transform:translateY(1px)}
.recipe-photo-frame img{width:100%;height:100%;object-fit:cover;display:block}
.recipe-photo-preview.no-photo .recipe-photo-frame img{display:none}
.recipe-photo-preview.has-photo #recipe-photo-icon{display:none}
.recipe-photo-copy{min-width:0;flex:1}
.recipe-photo-title{font-size:13px;font-weight:500;margin-bottom:2px}
.recipe-photo-sub{font-size:11.5px;color:var(--text3);line-height:1.35}
.recipe-photo-preview.no-photo #recipe-use-icon-btn{display:none}
.r-upload-actions{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:0 0 9px;border-bottom:1px solid var(--border);margin-bottom:8px;flex-basis:100%}
.r-upload-actions button{min-width:0;height:38px;border:1px solid var(--border);background:var(--surface2);padding:0 9px;color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;border-radius:var(--r);display:flex;align-items:center;justify-content:center;gap:6px;transition:border-color .15s,background .15s,color .15s,transform .15s}
.r-upload-actions button i{font-size:16px;line-height:1;flex-shrink:0}
.r-upload-actions button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.r-upload-actions button:hover,.r-upload-actions button:focus-visible{background:var(--surface);border-color:var(--sage-d);color:var(--text);outline:none}
.r-upload-actions button:active{transform:translateY(1px)}
.rec-language-flag{position:absolute;top:8px;left:8px;background:rgba(253,250,244,.92);border:1px solid rgba(224,216,200,.8);border-radius:14px;min-width:30px;height:28px;padding:0 7px;display:flex;align-items:center;justify-content:center;font-size:15px;box-shadow:0 1px 4px rgba(44,40,32,.08);z-index:3}
/* ── RECIPE IMPORT LOADER ── */
.overlay.centered-overlay{align-items:center;padding:20px}
.recipe-loading-modal{max-width:340px;border-radius:20px;border:1px solid var(--border);box-shadow:0 18px 50px rgba(44,40,32,.18);transform:scale(.98);max-height:none}
.overlay.open .recipe-loading-modal{transform:scale(1)}
.vd-loader-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:38px 24px 34px;background:var(--surface2);user-select:none;text-align:center}
.vd-loader-scene{position:relative;width:220px;height:220px;margin-bottom:26px}
.vd-pan-group{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);animation:vd-pan-rock 2.6s ease-in-out infinite;transform-origin:60px 90px}
.vd-pan-group svg,.vd-spoon-group svg{display:block;overflow:visible}
.vd-steam{position:absolute;border-radius:50%;background:#B8CDB0;opacity:0;animation:vd-steam-up 2s ease-out infinite}
.vd-s1{left:72px;bottom:118px;width:9px;height:9px;animation-delay:0s}
.vd-s2{left:95px;bottom:124px;width:7px;height:7px;animation-delay:.55s}
.vd-s3{left:118px;bottom:118px;width:8px;height:8px;animation-delay:1.1s}
.vd-orbit-ring{position:absolute;inset:0;width:220px;height:220px;animation:vd-orbit 7s linear infinite;transform-origin:110px 110px}
.vd-ing{position:absolute;width:38px;height:38px;border-radius:50%;background:var(--surface);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:19px;animation:vd-counter-orbit 7s linear infinite;transform-origin:19px 19px;box-shadow:0 1px 3px rgba(44,40,32,.07)}
.vd-i1{top:5px;left:91px}
.vd-i2{top:91px;left:177px}
.vd-i3{top:177px;left:91px}
.vd-i4{top:91px;left:5px}
.vd-spoon-group{position:absolute;top:28px;left:118px;animation:vd-stir 1.4s ease-in-out infinite;transform-origin:14px 8px}
.vd-loader-title{font-family:var(--font);font-size:18px;color:var(--text);margin-bottom:6px}
.vd-dots span{animation:vd-blink 1.4s ease-in-out infinite;opacity:0}
.vd-dots span:nth-child(2){animation-delay:.22s}
.vd-dots span:nth-child(3){animation-delay:.44s}
.vd-loader-subtitle{font-size:13px;color:var(--text3)}
.vd-prog-track{width:190px;height:4px;background:var(--border);border-radius:2px;margin-top:18px;overflow:hidden}
.vd-prog-fill{height:100%;background:var(--sage);border-radius:2px;animation:vd-prog 3.8s ease-in-out infinite}
.vd-loader-msg{font-size:12px;color:var(--text2);margin-top:10px;height:18px;overflow:hidden}
.vd-msg-inner{transition:transform .45s ease,opacity .45s ease}
@keyframes vd-pan-rock{0%,100%{transform:translateX(-50%) rotate(-2.5deg)}50%{transform:translateX(-50%) rotate(2.5deg)}}
@keyframes vd-steam-up{0%{transform:translateY(0) translateX(0) scale(.5);opacity:0}15%{opacity:.65}60%{opacity:.3}100%{transform:translateY(-44px) translateX(4px) scale(1.6);opacity:0}}
@keyframes vd-orbit{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes vd-counter-orbit{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
@keyframes vd-stir{0%{transform:rotate(-28deg)}50%{transform:rotate(28deg)}100%{transform:rotate(-28deg)}}
@keyframes vd-blink{0%,80%,100%{opacity:0}40%{opacity:1}}
@keyframes vd-prog{0%{width:0;margin-left:0}50%{width:65%;margin-left:18%}100%{width:0;margin-left:100%}}
.spin{width:14px;height:14px;border-radius:50%;border:2px solid var(--border2);border-top-color:var(--sage);animation:spin .8s linear infinite;display:inline-block;flex-shrink:0}

/* ── RECURRING ── */
.recurring-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;flex-wrap:wrap;gap:8px}
.recurring-desc{font-size:13px;color:var(--text2)}
.support-wrap{max-width:920px;display:grid;gap:16px}
.support-hero-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#F6F1E7 0%,#FFFDF9 52%,#EEF4EE 100%)}
.support-hero-card::after{content:'';position:absolute;right:-36px;top:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(107,140,107,.18) 0%,rgba(107,140,107,0) 70%)}
.support-logo{font-family:var(--serif);font-size:34px;line-height:1;margin-bottom:14px;color:var(--text)}
.support-logo em{color:var(--sage);font-style:normal}
.support-grid{display:grid;grid-template-columns:1fr;gap:16px}
.support-copy{font-size:14px;line-height:1.7;color:var(--text2);margin:0}
.support-copy + .support-copy{margin-top:12px}
.support-copy-muted{color:var(--text3)}
.support-form{margin-top:14px}
.support-form-actions{display:flex;justify-content:flex-start}
.pantry-card{margin-bottom:16px}
.pantry-head-actions{display:flex;align-items:center;gap:7px}
.pantry-count{font-size:11px;color:var(--text3)}
.pantry-add-small{width:28px;height:28px;background:var(--sage);border:1px solid var(--sage-d);color:#fff}
.pantry-add-small:hover,.pantry-add-small:focus-visible{background:var(--sage-d);color:#fff}
.pantry-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:7px;margin-bottom:11px;max-height:240px;overflow:auto;padding-right:2px}
.pantry-entry{min-width:0}
.pantry-chip{display:flex;align-items:center;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:7px 8px;font-size:12px;min-width:0}
.pantry-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.pantry-variants-toggle,.pantry-tag-remove{width:24px;height:24px;border-radius:7px;background:transparent;border:none;cursor:pointer;color:var(--text3);font-size:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.pantry-variants-toggle:hover,.pantry-variants-toggle.on{background:var(--sage-l);color:var(--sage-d)}
.pantry-tag-remove:hover{background:var(--red-l);color:var(--red)}
.pantry-variants{display:flex;flex-direction:column;gap:7px;margin-top:5px;padding:7px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);font-size:10.5px;color:var(--text2)}
.pantry-variant-tags{display:flex;flex-wrap:wrap;gap:4px;min-width:0}
.pantry-variant-pill{border:1px solid transparent;background:var(--surface2);border-radius:9px;padding:2px 6px;overflow-wrap:anywhere;color:var(--text2);font:inherit;font-size:10.5px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;max-width:100%;min-height:22px}
.pantry-variant-pill:hover,.pantry-variant-pill:focus-visible{border-color:var(--border2);outline:none}
.pantry-variant-pill.delete-ready{background:var(--red-l);border-color:rgba(190,82,82,.3);color:var(--red)}
.pantry-variant-pill.delete-ready .pantry-variant-label{display:none}
.pantry-variant-delete{display:none;font-weight:600}
.pantry-variant-pill.delete-ready .pantry-variant-delete{display:inline}
.pantry-variant-tags .pantry-variant-empty{background:transparent;color:var(--text3);padding-left:0}
.pantry-variant-add{display:flex;gap:5px;align-items:center}
.pantry-variant-input{height:30px;padding:5px 8px;font-size:12px}
.pantry-variant-add-btn{width:30px;height:30px;background:var(--sage);color:#fff;border:1px solid var(--sage-d)}
.pantry-variant-add-btn:hover{background:var(--sage-d);color:#fff}
.pantry-modal-variants{display:flex;flex-direction:column;gap:8px;padding:9px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface2)}
.pantry-empty{font-size:12px;color:var(--text3);margin-bottom:4px}
.recurring-toggle-section{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-top:1px solid var(--border);margin-top:4px}
.recurring-toggle-title{font-size:13px;font-weight:500}
.recurring-toggle-sub{font-size:11px;color:var(--text3)}
.recurring-opts{background:var(--surface2);border-radius:var(--r);padding:13px;margin-top:4px}
.recurring-sub-opts{margin-top:11px}
.rc-list{display:flex;flex-direction:column;gap:9px}
.rc-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;display:flex;align-items:flex-start;gap:12px;transition:all .15s;flex-wrap:wrap}
.rc-item:hover{border-color:var(--border2)}
.rc-item.disabled{opacity:.5}
.rc-icon{width:40px;height:40px;border-radius:var(--r);background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rc-info{flex:1;min-width:0}
.rc-name{font-size:14px;font-weight:500;margin-bottom:2px}
.rc-interval{font-size:12px;color:var(--text2)}
.rc-next{font-size:11px;color:var(--text3);margin-top:2px}
.rc-actions{display:flex;gap:5px;align-items:center}

/* ── WEEK MENU ── */
.weekmenu-header{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.weekmenu-label{font-size:13px;color:var(--text2)}
.weekmenu-actions{display:flex;gap:7px}
.wk-grid{display:grid;grid-template-columns:1fr;gap:9px;margin-bottom:18px}
.day-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px;min-height:86px;display:grid;grid-template-columns:46px minmax(0,1fr) auto;align-items:center;gap:10px;transition:all .15s}
.day-card.day-open{cursor:pointer}
.day-card.day-open:hover,.day-card.day-open:focus-visible{border-color:var(--sage-d);box-shadow:0 6px 18px rgba(44,40,32,.08);outline:none}
.day-card.locked{border-color:var(--warm);background:#FDFAF0}
.day-media{width:46px;min-width:0}
.day-main{min-width:0;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:7px;align-items:center}
.day-side{display:grid;grid-template-rows:auto auto;justify-items:end;align-items:center;gap:8px;min-width:84px}
.day-name{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:24px;padding:0 8px;border-radius:999px;background:var(--surface2);font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--text2);font-weight:600}
.day-emoji{width:46px;height:46px;border-radius:var(--r);background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--text3)}
.day-thumb{width:46px;height:46px;border-radius:var(--r);background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;position:relative;overflow:hidden}
.day-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.day-thumb.has-photo .rec-thumb-fallback{display:none}
.day-thumb.image-failed img{display:none}
.day-thumb.image-failed .rec-thumb-fallback{display:inline}
.day-meal{font-size:13px;font-family:var(--font);line-height:1.3;color:var(--text);min-width:0;overflow:hidden;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.day-meal-empty{color:var(--text3);font-size:12px;font-style:italic}
.day-acts{display:flex;gap:2px;margin-left:0}
.day-acts .ibtn{width:27px;height:27px}
.day-tag-select{width:100%;min-width:0;font-size:11.5px;padding-top:5px;padding-bottom:5px;margin-top:0}
.gen-opts{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;margin-bottom:20px}
.opt-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px;gap:10px}
.opt-row:last-child{border-bottom:none}
.opt-lbl{color:var(--text2)}
.wk-exclude-filter{width:min(210px,60%)}
.wk-exclude-filter .multi-menu{left:auto;width:230px}
.gsel{padding:6px 28px 6px 10px;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);font-size:13px;color:var(--text);font-family:var(--font);outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23A89F90' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}

/* ── INGREDIENT / STEP ROWS ── */
.ing-header{display:none}
.ing-row{display:grid;grid-template-columns:2fr 1fr 1fr 28px;gap:6px;align-items:center;margin-bottom:7px}
.ing-header-col{font-size:10.5px;color:var(--text3)}
.step-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:7px}
.step-num{width:22px;height:22px;border-radius:50%;background:var(--sage-l);color:var(--sage-d);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;flex-shrink:0;margin-top:7px}
.add-row{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--sage);cursor:pointer;background:none;border:none;font-family:var(--font);padding:5px 0}
.add-row:hover{color:var(--sage-d)}
.add-row i{font-size:13px}

/* ── DAY CHECKBOXES ── */
.day-checks{display:flex;gap:6px;flex-wrap:wrap}
.day-cb{cursor:pointer}
.day-cb input{display:none}
.day-cb span{width:36px;height:36px;border-radius:50%;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--text2);transition:all .15s}
.day-cb input:checked+span{background:var(--sage);border-color:var(--sage-d);color:#fff}

/* ── EMOJI PICKER ── */
.recipe-name-wrap{position:relative}
.emoji-opts{display:flex;gap:7px;flex-wrap:wrap}
.recipe-icon-menu{position:absolute;left:10px;top:calc(100% + 7px);width:min(262px,calc(100vw - 56px));padding:10px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);box-shadow:0 12px 32px rgba(44,40,32,.14);z-index:5}
.emoji-opt{width:34px;height:34px;border-radius:var(--r);border:1.5px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .15s;background:var(--surface2)}
.emoji-opt:hover,.emoji-opt.on{border-color:var(--sage-d);background:var(--surface)}
.recipe-meta-row{grid-template-columns:minmax(0,1fr) minmax(0,2fr)}
.recipe-time-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:520px){
  .recipe-meta-row{grid-template-columns:1fr;gap:16px}
  #m-recipe .frow{gap:0;margin-bottom:16px}
  #m-recipe .frow:last-child{margin-bottom:0}
  #m-recipe .fg{margin-bottom:16px}
  #m-recipe .fg-no-mb{margin-bottom:16px}
  #m-recipe .fg:last-child{margin-bottom:0}
  #m-recipe .recipe-meta-row>.fg{margin-bottom:0}
  #m-recipe .tag-picks{row-gap:12px}
}

/* ── TAG PICKS ── */
.tag-picks{display:flex;column-gap:6px;row-gap:14px;flex-wrap:wrap}
.tag-pick{cursor:pointer;user-select:none}
.tag-pick input{display:none}
.tag-pick .tp{padding:5px 12px;border-radius:12px;font-size:12px;border:1.5px solid transparent;transition:all .15s;background:var(--surface2);color:var(--text2)}
.tag-pick input:checked+.tp{border-color:var(--sage-d);outline:none}

/* ── SETTINGS ── */
.settings-wrap{max-width:520px}
.settings-card{margin-bottom:16px}
.settings-sec-title{margin-bottom:14px}
.cats-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:11px}
.cats-add{display:flex;gap:7px}
.cat-tag{display:inline-flex;align-items:center;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:12px}
.cat-tag-remove{background:none;border:none;cursor:pointer;color:var(--text3);font-size:13px;padding:0 0 0 2px;line-height:1}
.set-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;gap:10px}
.set-row:last-child{border-bottom:none}
.set-row label{color:var(--text2);white-space:nowrap}
.set-row-stack{align-items:flex-start;flex-direction:column}
.set-row-inline{width:100%;padding:4px 0;border-bottom:none}
.settings-toggle-line{display:flex;align-items:center;justify-content:space-between;width:100%;gap:10px}
.settings-time{max-width:132px}
.settings-days{padding-top:4px}
.settings-note{font-size:12.5px;line-height:1.55;color:var(--text2)}
.pin-settings-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.pin-settings-actions{display:flex;gap:7px;flex-wrap:wrap}
.link-actions{display:flex;gap:7px;flex-wrap:wrap;width:100%;align-items:center}
.invite-input{flex:1;min-width:200px;font-size:12px}
.install-hint{font-size:11.5px;color:var(--text3);line-height:1.4;flex:1;min-width:180px}
.seg-control{display:inline-flex;border:1px solid var(--border2);border-radius:var(--r);overflow:hidden;background:var(--surface);flex-shrink:0}
.seg-control button{border:0;border-right:1px solid var(--border);background:transparent;color:var(--text2);padding:7px 11px;font:inherit;font-size:12px;cursor:pointer}
.seg-control button:last-child{border-right:0}
.seg-control button.active{background:var(--sage);color:#fff}
.settings-language-select{min-width:148px}
.pin-modal{max-width:340px}
.pin-dots{display:flex;justify-content:center;gap:10px;margin:16px 0 8px}
.pin-dots span{width:13px;height:13px;border-radius:50%;border:1.5px solid var(--border2);background:var(--surface2)}
.pin-dots span.filled{background:var(--sage);border-color:var(--sage-d)}
.pin-dots.error span{background:var(--red-l);border-color:var(--red);animation:pinShake .26s ease}
.pin-trust-row{display:flex;align-items:center;gap:8px;justify-content:center;margin:10px 0 2px;font-size:12px;color:var(--text2)}
.pin-trust-row input{accent-color:var(--sage);width:15px;height:15px}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}
.pin-pad button{height:48px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface2);font:inherit;font-size:17px;color:var(--text);cursor:pointer}
.pin-pad button:hover,.pin-pad button:focus-visible{background:var(--surface);border-color:var(--sage-d);outline:none}
.pin-pad button[data-pin-action]{font-size:12px;color:var(--text2)}
@keyframes pinShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}
.mobile-fab{display:none}

@media (max-width:599px) {
  .landing-form{flex-direction:column;align-items:stretch}
  .landing-invite-actions{display:grid;grid-template-columns:1fr 1fr}
  .landing-invite-actions .btn{width:100%}
  .mobile-brand{display:block}
  .page-title{display:none}
  .main{padding-top:60px}
  .topbar{gap:8px;position:fixed;top:0;left:0;right:0;z-index:48}
  #topbar-install-btn{padding:7px 9px;font-size:11.5px}
  .page-add-btn,.mobile-hidden-add{display:none}
  .content{padding-bottom:96px}
  .mobile-fab{position:fixed;right:18px;bottom:18px;width:58px;height:58px;border-radius:50%;border:1px solid var(--sage-d);background:var(--sage);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:28px;z-index:90;box-shadow:0 10px 24px rgba(61,92,61,.28);cursor:pointer;animation:fabIn .24s ease, fabPulse 2.8s ease-in-out infinite}
  .mobile-fab.hidden{display:none!important}
  .mobile-fab:active{transform:scale(.94)}
}

@media (hover:none) and (pointer:coarse) {
  .btn:hover{background:var(--surface);color:var(--text2)}
  .btn-primary:hover{background:var(--sage);color:#fff}
  .btn-danger:hover{background:var(--surface);color:var(--red)}
  .ibtn:hover{background:transparent;color:var(--text3)}
  .ibtn.d:hover{background:transparent;color:var(--text3)}
  .nav-item:hover{background:transparent;color:var(--text2)}
  .nav-item.active:hover{background:var(--sage-l);color:var(--sage-d)}
  .sidebar-foot:hover{background:transparent}
  .stat-link:hover{border-color:var(--border);box-shadow:none;transform:none}
  .qa:hover{border-color:var(--border);background:var(--surface)}
  .chip:hover:not(.active){background:var(--surface)}
  .cat-add-btn:hover{background:var(--sage);box-shadow:none}
  .cat-clear-btn:hover{background:var(--surface);box-shadow:none}
  .gitem:hover{border-color:var(--border)}
  .rec-card:hover{border-color:var(--border);box-shadow:none;transform:none}
  .multi-option:hover{background:transparent}
  .recipe-photo-frame:hover{box-shadow:none}
  .pantry-add-small:hover{background:var(--sage);color:#fff}
  .pantry-variants-toggle:hover{background:transparent;color:var(--text3)}
  .pantry-variants-toggle.on:hover{background:var(--sage-l);color:var(--sage-d)}
  .pantry-tag-remove:hover{background:transparent;color:var(--text3)}
  .pantry-variant-pill:hover{border-color:transparent}
  .pantry-variant-add-btn:hover{background:var(--sage);color:#fff}
  .rc-item:hover{border-color:var(--border)}
  .day-card.day-open:hover{border-color:var(--border);box-shadow:none}
  .add-row:hover{color:var(--sage)}
  .emoji-opt:hover{border-color:transparent;background:var(--surface2)}
  .emoji-opt.on:hover{border-color:var(--sage-d);background:var(--surface)}
  .rv-icon.rv-image-open:hover{box-shadow:none}
}

/* ── EMPTY ── */
.empty{text-align:center;padding:40px 20px;color:var(--text3)}
.empty > i{font-size:38px;display:block;margin-bottom:10px;color:var(--border2)}
.empty p{font-size:13px;margin-bottom:14px}
.empty .btn{min-height:32px;align-items:center;justify-content:center;line-height:1}
.empty .btn i{font-size:14px;display:inline-flex;margin:0;color:currentColor;line-height:1}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--text);color:#fff;padding:10px 18px;border-radius:var(--r);font-size:13px;opacity:0;transition:opacity .25s ease,transform .25s ease;pointer-events:none;z-index:999;display:flex;align-items:center;gap:7px;white-space:nowrap;box-shadow:0 4px 16px rgba(44,40,32,.2);max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast i{font-size:14px}

/* ── INLINE SECTION STYLE ── */
.inl-row{display:grid;grid-template-columns:3fr 1fr;gap:8px;align-items:center;font-size:13px;padding:7px 0;border-bottom:1px solid var(--border)}
.inl-row:last-child{border-bottom:none}
.inl-row-meta{color:var(--text3);font-size:12px;text-align:right}

/* ── RECIPE VIEW ── */
.rv-header{display:flex;gap:14px;align-items:center;margin-bottom:18px}
.rv-icon{font-size:40px;width:60px;height:60px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden;border:0;padding:0;color:inherit}
.rv-icon.rv-image-open{cursor:pointer}
.rv-icon.rv-image-open:hover,.rv-icon.rv-image-open:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(107,140,107,.2)}
.rv-photo-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.rv-icon.has-photo .rec-thumb-fallback{display:none}
.rv-icon.image-failed .rv-photo-img{display:none}
.rv-icon.image-failed .rec-thumb-fallback{display:inline}
.rv-main{min-width:0}
.rv-title{font-family:var(--serif);font-size:16px;margin-bottom:5px}
.rv-meta{font-size:11.5px;color:var(--text3);display:flex;gap:10px}
.rv-meta i{font-size:12px;vertical-align:-1px}
.rv-tags{display:flex;gap:5px;margin-top:7px;flex-wrap:wrap}
.rv-source{margin-top:10px}
.rv-desc{font-size:13px;color:var(--text2);font-style:italic;margin-bottom:16px}
.image-viewer-overlay{align-items:center;justify-content:center;padding:18px}
.image-viewer{position:relative;max-width:min(920px,96vw);max-height:90vh}
.image-viewer img{display:block;max-width:100%;max-height:90vh;border-radius:var(--r-lg);box-shadow:0 18px 50px rgba(44,40,32,.26);background:var(--surface)}
.image-viewer-close{position:absolute;top:10px;right:10px;background:rgba(253,250,244,.94);box-shadow:0 4px 16px rgba(44,40,32,.18);z-index:1}
.rv-section-title{font-family:var(--font);font-size:14px;margin-bottom:9px}
.converted-measure{border:0;background:transparent;color:var(--text2);font:inherit;font-size:12px;padding:0;text-decoration:underline;text-decoration-style:dotted;text-decoration-thickness:1.5px;text-underline-offset:3px;cursor:pointer}
.measure-tooltip{position:absolute;z-index:1000;max-width:min(240px,calc(100vw - 16px));padding:7px 10px;border-radius:var(--r);background:var(--text);color:#fff;font-size:12px;line-height:1.35;box-shadow:0 8px 22px rgba(44,40,32,.22);opacity:0;pointer-events:none;transform:translateY(3px);transition:opacity .14s ease,transform .14s ease}
.measure-tooltip.open{opacity:1;transform:translateY(0)}
.rv-steps{display:flex;flex-direction:column;gap:9px}
.rv-step{display:flex;gap:11px}
.rv-step-num{margin-top:0;flex-shrink:0}
.rv-step-text{font-size:13px;color:var(--text2);line-height:1.55}
.rv-spacer{height:16px}

/* ── ANIMATIONS ── */
@keyframes slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideOut{to{opacity:0;transform:translateX(30px);max-height:0;padding-top:0;padding-bottom:0;margin-bottom:0;border-width:0}}
@keyframes checkPop{0%{transform:scale(1)}30%{transform:scale(.97)}60%{transform:scale(1.01)}100%{transform:scale(1)}}
@keyframes uncheckPop{0%{transform:scale(1)}40%{transform:scale(1.02)}100%{transform:scale(1)}}
@keyframes fadeIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes popIn{0%{opacity:0;transform:scale(.9)}70%{transform:scale(1.03)}100%{opacity:1;transform:scale(1)}}
@keyframes fabIn{from{opacity:0;transform:translateY(12px) scale(.88)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes fabPulse{0%,100%{box-shadow:0 10px 24px rgba(61,92,61,.28)}50%{box-shadow:0 12px 30px rgba(61,92,61,.42)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes app-loading-ring-spin{to{transform:rotate(360deg)}}
@keyframes app-loading-centre-pulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.12)}}
@keyframes app-loading-wisp-up{0%{transform:translateY(0) scale(.5);opacity:0}20%{opacity:.65}100%{transform:translateY(-28px) scale(1.5);opacity:0}}

.rec-card{animation:fadeIn .3s ease}
.rc-item{animation:slideIn .3s ease}
.day-card{animation:fadeIn .25s ease}
.stat-card{animation:fadeIn .3s ease}

/* ── MISC ── */
.dash-more{font-size:11px;color:var(--text3);margin-top:7px}
.rc-next-icon{font-size:11px;vertical-align:-1px;margin-right:2px}
.lock-active{color:var(--warm)}


/* ═══════════════════════════════════════════════════
   TABLET (≥600px)
   ═══════════════════════════════════════════════════ */
@media (min-width:600px) {
  .content{padding:20px 24px}
  .g4{grid-template-columns:repeat(2,1fr);gap:12px}
  .qa-grid{grid-template-columns:repeat(4,1fr)}
  .rec-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .wk-grid{grid-template-columns:repeat(2,1fr)}
  .frow-2{grid-template-columns:1fr 1fr}
  .frow-3{grid-template-columns:1fr 1fr 1fr}
  .frow-4{grid-template-columns:1fr 1fr 1fr 1fr}
  .gitem-inner{gap:6px 14px}
  .ing-header{display:grid;grid-template-columns:1fr 86px 66px 28px;gap:7px;margin-bottom:5px;padding:0 0 4px}
  .ing-row{grid-template-columns:2fr 1fr 1fr 28px;gap:7px}
  .weekmenu-header{flex-direction:row;align-items:center;justify-content:space-between}
  .recipes-toolbar{flex-direction:row;align-items:center;justify-content:space-between}
  .explore-toolbar{flex-direction:row;align-items:flex-start;justify-content:space-between}
  .explore-intro{max-width:360px}
  .explore-filter-row{grid-template-columns:minmax(220px,280px) 180px 180px}
  .overlay{align-items:center;padding:20px}
  .modal{border-radius:var(--r-xl);border-bottom:1px solid var(--border);max-width:520px}
  .modal.wide{max-width:660px}
  .settings-input{width:170px}
  .settings-select{width:130px}
  .start-date-input{width:180px}
  .set-row-stack{flex-direction:column}
}

/* ═══════════════════════════════════════════════════
   DESKTOP (≥900px)
   ═══════════════════════════════════════════════════ */
@media (min-width:900px) {
  .support-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr)}
  .sidebar-overlay{display:none}
  .sidebar{position:static;width:228px;transform:none;transition:none}
  .hamburger{display:none}
  .topbar{padding:13px 28px}
  .content{padding:24px 32px}
  .g4{grid-template-columns:repeat(4,1fr);gap:13px}
  .g2{grid-template-columns:1fr 1fr}
  .recipe-filter-row{grid-template-columns:minmax(210px,.8fr) minmax(160px,.45fr) minmax(160px,.45fr)}
  .explore-filter-row{grid-template-columns:minmax(220px,1fr) minmax(160px,.42fr) minmax(160px,.42fr)}
  .rec-grid{grid-template-columns:repeat(3,1fr)}
  .wk-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}
  .day-card{min-height:90px}
  .day-meal{-webkit-line-clamp:2}
  .iactions{opacity:0;transition:opacity .15s}
  .gitem:hover .iactions{opacity:1}
  .nav-item{font-size:13px;padding:9px 20px}
  .nav-item i{font-size:17px;width:20px}
  .rec-card:hover{transform:translateY(-2px)}
  .input-pair #g-qty{flex:1.45}
  .input-pair #g-unit{flex:.75}
  .ing-header{grid-template-columns:1fr 90px 68px 28px}
  .ing-row{grid-template-columns:2fr 1fr 1fr 28px;gap:7px}
}

/* ═══════════════════════════════════════════════════
   LARGE DESKTOP (≥1400px)
   ═══════════════════════════════════════════════════ */
@media (min-width:1400px) {
  .content{padding:28px 40px}
}
