:root{
  --cream:#FDFBF7;--warm:#F5EFE4;--tc:#D35400;--tcl:#E8845A;
  --green:#6B8E23;--dark:#1E1C18;--mid:#5C5547;--light:#9E9183;
  --border:#E5E7EB;--sh:0 2px 20px rgba(30,28,24,.08);--shl:0 8px 40px rgba(30,28,24,.14);
  --card-bg:#fff;--page-bg:var(--cream);
  --sg:#6B8E23;--cy:#EAB308;--cg:#4B5563;--bg:#FDFBF7;
}
/* ── DARK ── */
[data-theme="dark"]{
  --cream:#1A1A1F;--warm:#23232A;--tc:#E8845A;--tcl:#F0A07A;
  --green:#5A8F50;--dark:#F0EDE8;--mid:#B0A898;--light:#6B6460;
  --border:#3A3840;--sh:0 2px 20px rgba(0,0,0,.3);--shl:0 8px 40px rgba(0,0,0,.5);
  --card-bg:#2A2A32;--page-bg:#1A1A1F;
  --sg:#5A8F50;--cy:#D97706;--cg:#9CA3AF;--bg:#1A1A1F;
}
/* ── OCEAN ── */
[data-theme="ocean"]{
  --cream:#EFF6FF;--warm:#DBEAFE;--tc:#1D4ED8;--tcl:#3B82F6;
  --green:#0F766E;--dark:#0F172A;--mid:#475569;--light:#94A3B8;
  --border:#BFDBFE;--sh:0 2px 20px rgba(15,23,42,.08);--shl:0 8px 40px rgba(15,23,42,.14);
  --card-bg:#fff;--page-bg:#EFF6FF;
  --sg:#0F766E;--cy:#EAB308;--cg:#475569;--bg:#EFF6FF;
}
/* ── FOREST ── */
[data-theme="forest"]{
  --cream:#F0FDF4;--warm:#DCFCE7;--tc:#166534;--tcl:#22C55E;
  --green:#15803D;--dark:#14532D;--mid:#4B7A55;--light:#86A48C;
  --border:#BBF7D0;--sh:0 2px 20px rgba(20,83,45,.08);--shl:0 8px 40px rgba(20,83,45,.14);
  --card-bg:#fff;--page-bg:#F0FDF4;
  --sg:#15803D;--cy:#EAB308;--cg:#4B7A55;--bg:#F0FDF4;
}
/* ── MIDNIGHT ── */
[data-theme="midnight"]{
  --cream:#0F0F14;--warm:#18181F;--tc:#A78BFA;--tcl:#C4B5FD;
  --green:#34D399;--dark:#F5F3FF;--mid:#A0A0B0;--light:#555568;
  --border:#2E2E40;--sh:0 2px 20px rgba(0,0,0,.4);--shl:0 8px 40px rgba(0,0,0,.6);
  --card-bg:#1C1C26;--page-bg:#0F0F14;
  --sg:#34D399;--cy:#FBBF24;--cg:#9CA3AF;--bg:#0F0F14;
}
/* cards & body use theme vars */
body{background:var(--page-bg)!important;}
.card,.modal,.modal-card,.recipe-card,.shopping-item,.nutrdb-row,.planner-day{background:var(--card-bg)!important;}
/* Dark themes — fix hardcoded whites */
[data-theme="dark"],[data-theme="midnight"]{
  color-scheme:dark;
}
[data-theme="dark"] .card,[data-theme="midnight"] .card,
[data-theme="dark"] .modal,[data-theme="midnight"] .modal,
[data-theme="dark"] .modal-card,[data-theme="midnight"] .modal-card{color:var(--dark);}
[data-theme="dark"] input,[data-theme="midnight"] input,
[data-theme="dark"] select,[data-theme="midnight"] select,
[data-theme="dark"] textarea,[data-theme="midnight"] textarea{
  background:var(--warm);color:var(--dark);border-color:var(--border);
}
[data-theme="dark"] .shopping-item,[data-theme="midnight"] .shopping-item,
[data-theme="dark"] .nutrdb-row,[data-theme="midnight"] .nutrdb-row,
[data-theme="dark"] .recipe-card,[data-theme="midnight"] .recipe-card,
[data-theme="dark"] .planner-slot,[data-theme="midnight"] .planner-slot{color:var(--dark);}
[data-theme="dark"] .login-card,[data-theme="midnight"] .login-card{background:var(--card-bg);color:var(--dark);}
[data-theme="dark"] .login-field-col input,[data-theme="midnight"] .login-field-col input{background:var(--warm);color:var(--dark);}
/* Theme picker dropdown */
.theme-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--dark);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.35rem 0;z-index:999;min-width:130px;box-shadow:0 8px 24px rgba(0,0,0,.3);}
.theme-menu-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .85rem;cursor:pointer;font-size:.8rem;color:var(--light);font-family:'Inter',sans-serif;transition:background .15s;white-space:nowrap;}
.theme-menu-item:hover{background:rgba(255,255,255,.08);color:#fff;}
.theme-menu-item.active{color:#fff;font-weight:600;}
.theme-menu-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--dark);min-height:100vh;overflow-x:hidden;}
/* Native app: use flex layout so bottom nav never disappears behind content */
.native-app body{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;width:100vw;max-width:100vw;}
.native-app header{flex-shrink:0;}
.native-app main{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;order:1;width:100%;max-width:100vw;}
.native-app .bottom-nav{flex-shrink:0;position:static;order:2;width:100%;max-width:100vw;overflow-x:hidden;}

/* ── INLINE SVG ICONS ── */
.ico{display:inline-block;width:1em;height:1em;vertical-align:-0.125em;flex-shrink:0;}
button .ico,a .ico,.btn .ico{width:.9em;height:.9em;}
.edit-btn .ico,.del-btn .ico{width:1em;height:1em;}
.fetch-price-btn .ico{width:.9em;height:.9em;}
.sub-card-icon .ico{width:1.6em;height:1.6em;}
.planner-allergy-dot .ico{width:.7em;height:.7em;}
@keyframes ico-spin{to{transform:rotate(360deg)}}
.ico-spin{animation:ico-spin .8s linear infinite;}

/* ── HEADER ── */
header{background:var(--cream);border-bottom:1px solid var(--border);padding:0 1rem;display:flex;align-items:center;height:56px;position:sticky;top:0;z-index:100;gap:0.75rem;}
.logo{font-family:'Outfit',sans-serif;color:var(--dark);font-size:1.2rem;white-space:nowrap;flex-shrink:0;}
.logo span{color:var(--tcl);font-style:italic;}
.header-spacer{flex:1;}
.lang-switch{display:flex;gap:0.15rem;background:rgba(0,0,0,.04);border-radius:7px;padding:3px;flex-shrink:0;}
.lang-btn{background:none;border:none;color:var(--mid);padding:.25rem .6rem;border-radius:5px;cursor:pointer;font-size:.75rem;font-weight:700;font-family:'Inter',sans-serif;transition:all .2s;}
.lang-btn.active{background:var(--tc);color:#fff;}

/* ── BOTTOM NAV (mobile) ── */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--cream);border-top:1px solid var(--border);z-index:100;padding:0.25rem 0 env(safe-area-inset-bottom, 0.25rem);}
.bottom-nav-inner{display:flex;position:relative;}
.bottom-nav-pill{position:absolute;top:4px;height:calc(100% - 8px);border-radius:16px;background:rgba(211,84,0,0.1);transition:left .35s cubic-bezier(.4,0,.2,1),width .35s cubic-bezier(.4,0,.2,1);pointer-events:none;z-index:0;}
.bnav-btn{flex:1;background:none;border:none;color:#4B5563;padding:.55rem .25rem .35rem;cursor:pointer;font-family:'Inter',sans-serif;font-size:.75rem;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:2px;transition:color .25s,transform .2s;position:relative;z-index:1;-webkit-tap-highlight-color:transparent;touch-action:none;}
.bnav-btn .bicon{display:flex;align-items:center;justify-content:center;margin-bottom:2px;transition:transform .25s;}
.bnav-btn .bicon svg{width:22px;height:22px;stroke-width:2;stroke:currentColor;fill:none;transition:stroke .25s;}
.bnav-btn.active{color:var(--tc);}
.bnav-btn.active .bicon{transform:translateY(-1px);}
.bnav-btn.active .bicon svg{stroke:var(--tc);stroke-width:2.4;}
.bnav-btn.bnav-hover{color:var(--tc);transform:scale(1.1);}
.bnav-btn.bnav-hover .bicon svg{stroke:var(--tc);stroke-width:2.3;}
.bottom-nav-pill.scrubbing{transition:left .12s ease-out,width .12s ease-out,transform .12s ease-out;transform:scaleY(1.08);}

/* ── DESKTOP NAV ── */
.desk-nav{display:flex;gap:0.15rem;align-items:center;}
.desk-nav button{background:none;border:none;color:#4B5563;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:500;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:6px;}
.desk-nav button svg{width:18px;height:18px;stroke-width:2;stroke:currentColor;fill:none;}
.desk-nav button:hover{background:rgba(0,0,0,.04);color:var(--dark);}
.desk-nav button.active{background:var(--tc);color:#fff;}
/* Premium-locked nav tabs */

/* ── MAIN ── */
main{max-width:1200px;margin:0 auto;padding:1.25rem 1rem 5rem;overflow-x:hidden;}

/* ── PAGES ── */
.page{display:none;}.page.active{display:block;}
.page-header{margin-bottom:1.5rem;padding-top:.5rem;}
.page-header h1{font-family:'Outfit',sans-serif;font-size:1.7rem;margin-bottom:.2rem;}
.page-header p{color:var(--mid);font-size:.875rem;}

/* ── CARD ── */
.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1.25rem;box-shadow:var(--sh);}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem 1.1rem;border-radius:8px;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:.85rem;font-weight:500;transition:all .2s;white-space:nowrap;}
.btn-primary{background:var(--tc);color:#fff;}.btn-primary:hover{background:#b05828;}
.btn-green{background:var(--green);color:#fff;}.btn-green:hover{background:#3a5332;}
.btn-outline{background:none;border:1.5px solid var(--border);color:var(--mid);}.btn-outline:hover{border-color:var(--tc);color:var(--tc);}
.btn-sm{padding:.3rem .75rem;font-size:.78rem;}
.btn-danger{background:#dc3545;color:#fff;}.btn-danger:hover{background:#c82333;}
.btn-block{width:100%;justify-content:center;}

/* ── FORMS ── */
.form-group{margin-bottom:.9rem;}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
.form-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;}
label{display:block;font-size:.82rem;font-weight:600;color:var(--mid);margin-bottom:.3rem;}
input,textarea,select{width:100%;padding:.6rem .85rem;border:1.5px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;font-size:.875rem;color:var(--dark);background:#fff;transition:border .2s;-webkit-appearance:none;}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--tc);}
textarea{resize:vertical;min-height:90px;}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239E9183' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem;}

/* ── TAGS ── */
.tag{display:inline-block;padding:.18rem .55rem;border-radius:20px;font-size:.72rem;font-weight:600;}
.tag-green{background:#E8F5E4;color:var(--green);}.tag-orange{background:#FEF0E7;color:var(--tc);}.tag-blue{background:#E7F0FE;color:#2A5FBF;}
.allergy-badge{display:inline-flex;align-items:center;gap:.2rem;background:#FEE7E7;color:#c0392b;padding:.18rem .55rem;border-radius:20px;font-size:.7rem;font-weight:700;}
.allergen-checkboxes{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem;}
.allergen-check{display:flex;align-items:center;gap:.3rem;background:var(--warm);border:1.5px solid var(--border);border-radius:20px;padding:.3rem .7rem;font-size:.78rem;cursor:pointer;transition:all .15s;user-select:none;}
.allergen-check input{display:none;}
.allergen-check.active{background:#FEE7E7;border-color:#f5a5a5;color:#c0392b;font-weight:600;}
.member-allergies{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.35rem;}
.member-allergy-chip{background:#FEE7E7;color:#c0392b;border-radius:12px;padding:.1rem .45rem;font-size:.68rem;font-weight:600;}

/* ── DASHBOARD ── */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem;}
.stat-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1rem;box-shadow:0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.stat-card svg{position:absolute;top:12px;left:12px;}
.section-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1.25rem;}
.stat-card .num{font-family:'Outfit',sans-serif;font-size:2rem;color:var(--tc);line-height:1;margin-top:.3rem;}
.stat-card .lbl{color:var(--mid);font-family:'Inter',sans-serif;font-size:.75rem;margin-top:.2rem;}
.family-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:1.25rem;color:var(--dark);margin-bottom:1.25rem;box-shadow:0 4px 6px -1px rgba(0, 0, 0, 0.05);}
.family-card h3{font-family:'Outfit',sans-serif;margin-bottom:.9rem;color:var(--dark);font-size:1rem;display:flex;align-items:center;justify-content:space-between;}
.family-card h3 button{background:rgba(0,0,0,.05);border:none;color:var(--dark);padding:.3rem .7rem;border-radius:6px;cursor:pointer;font-size:.75rem;font-family:'Inter',sans-serif;}
.family-members{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;}
.member{background:#FDFBF7;border:1px solid #E5E7EB;border-radius:10px;padding:.75rem;cursor:pointer;transition:background .2s;}
.member:hover{background:#F5EFE4;}
.member .mname{font-weight:600;font-size:1.1rem;font-family:'Outfit',sans-serif;color:var(--dark);}
.member .mdetail{color:#6B7280;font-size:.875rem;margin-top:.15rem;}
.member .mkcal{color:#6B7280;font-size:.875rem;margin-top:.15rem;}
.member .mmacros{color:#6B7280;font-size:.875rem;margin-top:.15rem;}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
.week-preview h3{font-family:'Outfit',sans-serif;font-size:1rem;margin-bottom:.75rem;}
.day-row{display:flex;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border);gap:.75rem;}
.day-row:last-child{border-bottom:none;}
.day-name{width:70px;font-size:.75rem;font-weight:600;color:var(--mid);text-transform:uppercase;}
.day-meal{flex:1;font-size:.83rem;}.day-meal.empty{color:var(--mid);font-style:italic;}

/* ── RECIPES ── */
.search-mode-wrap{display:flex;align-items:center;gap:.3rem;flex:1;min-width:180px;max-width:320px;}
.search-mode-wrap input{flex:1;min-width:0;}
.search-mode-toggle{display:flex;border:1.5px solid var(--border);border-radius:8px;overflow:hidden;flex-shrink:0;}
.search-mode-btn{padding:.4rem .55rem;border:none;background:#fff;cursor:pointer;font-size:.9rem;transition:background .15s;line-height:1;}
.search-mode-btn.active{background:var(--tc);color:#fff;}
.search-mode-btn:not(.active):hover{background:var(--warm);}
.ing-match-list{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.3rem;}
.ing-match-chip{display:inline-flex;align-items:center;gap:.2rem;background:#FEF0E7;border:1px solid #f5c9a8;border-radius:12px;padding:.15rem .5rem;font-size:.7rem;color:var(--tc);font-weight:500;}
.ing-match-chip mark{background:none;color:var(--tc);font-weight:700;}
.recipes-toolbar input{flex:1;min-width:140px;max-width:260px;}
.recipes-toolbar select{max-width:145px;}
.recipes-toolbar .spacer{flex:1;}
.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.9rem;}
.recipe-card {
  background-color: #FDFBF7; /* Warm Cream */
  border-radius: 12px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  width: 100%;
  max-width: 320px;
  font-family: 'Inter', sans-serif;
  border: 1px solid #E5E7EB;
  cursor: pointer;
  display: flex;
  flex-direction: column;
}

.recipe-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(0, 0, 0, 0.04);
}

.recipe-card-allergy{border:1.5px solid #f5a5a5;background:#fffafa;}
.recipe-card-allergy:hover{box-shadow:0 4px 16px rgba(192,57,43,.15);}
.allergy-strip{background:#FEE7E7;color:#c0392b;font-size:.72rem;font-weight:600;padding:.3rem .65rem;border-radius:6px;margin-bottom:.4rem;line-height:1.4;}
.library-badge{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.9);border-radius:20px;padding:.15rem .45rem;font-size:.7rem;}

/* Image formatting */
.recipe-image {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  background: var(--warm);
  font-size: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

/* Content Padding */
.recipe-content {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Title */
.recipe-title {
  font-family: 'Outfit', sans-serif;
  font-size: 1.25rem;
  color: #262626;
  margin: 0 0 12px 0;
  line-height: 1.3;
}

/* Metadata (Time & Portions) */
.recipe-meta {
  display: flex;
  gap: 16px;
  color: #6B7280;
  font-size: 0.875rem;
  margin-bottom: 16px;
  align-items: center;
}

.recipe-meta span {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Tags */
.recipe-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 24px;
}

.tag {
  background-color: rgba(107, 142, 35, 0.15); /* Light Sage */
  color: #4A6317; /* Darker Sage for contrast */
  padding: 4px 12px;
  border-radius: 99px;
  font-size: 0.75rem;
  font-weight: 500;
}
.tag-orange{background:#FEF0E7;color:var(--tc);}
.tag-green{background:#E8F5E4;color:var(--green);}
.tag-blue{background:#E7F0FE;color:#2A5FBF;}
.tag-library{background:rgba(255,255,255,.9);color:var(--dark);border:1px solid var(--border);}


/* Macros Grid */
.recipe-macros {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  border-top: 1px solid #E5E7EB;
  padding-top: 16px;
  text-align: center;
  margin-top: auto;
}

.macro-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Colored Top Bars for Macros */
.macro-bar {
  width: 100%;
  height: 3px;
  border-radius: 3px;
  margin-bottom: 8px;
}

.kcal-bar { background-color: #D35400; } /* Terracotta */
.prot-bar { background-color: #6B8E23; } /* Sage */
.carb-bar { background-color: #F59E0B; } /* Warm Yellow */
.fat-bar  { background-color: #D1D5DB; } /* Neutral Gray */

.macro-value {
  font-weight: 600;
  color: #262626;
  font-size: 0.95rem;
}

.macro-label {
  font-size: 0.7rem;
  color: #6B7280;
  text-transform: uppercase;
  margin-top: 2px;
}

/* ── MODALS ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(30,28,24,.65);z-index:200;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(4px);}
.modal-overlay.open{display:flex;}
.modal{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:660px;max-height:92vh;overflow-y:auto;box-shadow:var(--shl);margin:0 auto;}
.modal-header{padding:1.1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1;border-radius:16px 16px 0 0;}
.modal-header h2{font-family:'Outfit',sans-serif;font-size:1.2rem;}
.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--mid);padding:.25rem .5rem;}
.modal-body{padding:1.25rem;}
.modal-footer{padding:.9rem 1.25rem;border-top:1px solid var(--border);display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap;}

/* ── TABS ── */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:1.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.tab-btn{background:none;border:none;padding:.65rem 1rem;cursor:pointer;font-family:'Inter',sans-serif;font-size:.83rem;font-weight:500;color:var(--mid);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap;flex-shrink:0;}
.tab-btn.active{color:var(--tc);border-bottom-color:var(--tc);}
.tab-content{display:none;}.tab-content.active{display:block;}

/* ── INGREDIENTS ── */
.ingredients-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.65rem;}
.ingredient-row{display:flex;gap:.4rem;align-items:center;}
.ingredient-row input{flex:1;min-width:0;}
.ingredient-row input.qty{max-width:70px;flex:none;}
.ingredient-row input.unit,.ingredient-row select.unit{max-width:100px;flex:none;font-family:'DM Sans',sans-serif;font-size:.82rem;padding:.35rem .3rem;border:1.5px solid var(--border);border-radius:8px;background:#fff;}
.ingredient-row.unrecognised input[type="text"]:first-child{border-color:#e74c3c;background:#fff8f8;}
.ingredient-row.unrecognised::after{content:'?';flex-shrink:0;width:18px;height:18px;border-radius:50%;background:#e74c3c;color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:-.1rem;}
.ingredient-row.recognised input[type="text"]:first-child{border-color:#4A6741;background:#f8fff7;}
.ingredient-row.recognised::after{content:'✓';flex-shrink:0;width:18px;height:18px;border-radius:50%;background:#4A6741;color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:-.1rem;}
.rm-btn{background:none;border:none;color:var(--mid);cursor:pointer;font-size:1.1rem;padding:.25rem;border-radius:4px;flex-shrink:0;line-height:1;}.rm-btn:hover{color:#dc3545;}

/* ── PLANNER ── */
.week-nav{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap;}
.week-nav h2{font-family:'Outfit',sans-serif;font-size:1.1rem;flex:1;text-align:center;min-width:160px;}
.planner-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1.25rem;}
.planner-day{background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;min-height:160px;transition:all .2s;}
.planner-day.today{border-color:var(--tc);box-shadow:0 0 0 1px var(--tc),var(--sh);background:#fff;}
.planner-day-header{background:#fff;color:var(--dark);padding:.4rem;text-align:center;font-size:.8rem;font-weight:700;font-family:'Outfit',sans-serif;border-bottom:1px solid var(--border);}
.planner-day-header.today{color:var(--tc);}
.planner-day-content{padding:.5rem;}
.planner-slot{background:#fff;border:1px solid var(--border);border-radius:8px;padding:.5rem;margin-bottom:.5rem;font-size:.7rem;position:relative;transition:box-shadow .2s;display:flex;flex-direction:column;gap:6px;}
.planner-slot:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,0.05),0 2px 4px -1px rgba(0,0,0,0.03);}
.planner-slot-label{font-size:.65rem;text-transform:uppercase;color:var(--mid);font-weight:700;}
.planner-slot-name{font-size:.75rem;color:var(--dark);font-weight:500;line-height:1.3;display:flex;align-items:center;}
.planner-slot-name span{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-width:0;word-break:break-word;}
.planner-slot.planner-allergy{border-color:var(--tc)!important;background:rgba(211,84,0,0.02);}
.planner-allergy-dot{color:var(--tc);font-size:.7rem;cursor:help;}
.planner-accomp{display:flex;flex-direction:column;gap:6px;margin-top:.2rem;padding-top:.4rem;border-top:1px dashed var(--border);position:relative;}
.accomp-label{color:var(--mid);flex-shrink:0;white-space:nowrap;}
.accomp-name{font-size:.75rem;color:var(--dark);font-weight:500;line-height:1.3;display:flex;align-items:center;}
.accomp-name span{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-width:0;word-break:break-word;}
.accomp-rm{position:absolute!important;top:4px!important;right:0px!important;font-size:.65rem!important;opacity:.8;flex-shrink:0;}
.planner-add-accomp{font-size:.6rem;color:var(--tc);background:none;border:none;padding:0;cursor:pointer;margin-top:.4rem;font-weight:600;text-transform:uppercase;font-family:'Inter',sans-serif;}
.planner-add-accomp:hover{text-decoration:underline;}
/* Weekend day highlight */
.planner-day.weekend .planner-day-header{background:#fff;}
.planner-day.weekend .planner-day-header.today{color:var(--tc);}
.native-app .recipe-image{height:220px;}
.native-app .planner-slot-label{font-weight:600;}
.native-app .planner-slot-name{font-weight:600;margin-top:.1rem;line-height:1.25;font-size:.78rem;}
.planner-add-btn{width:100%;background:none;border:1.5px dashed var(--border);border-radius:6px;padding:.3rem;font-size:.68rem;color:var(--mid);cursor:pointer;transition:all .2s;margin-bottom:.3rem;font-family:'Inter',sans-serif;}
.planner-add-btn:hover{border-color:var(--tc);color:var(--tc);background:#FEF0E7;}
.ai-bar{background:linear-gradient(135deg,var(--dark) 0%,#2d2a24 100%);border-radius:12px;padding:1rem 1.25rem;display:flex;align-items:center;gap:.9rem;margin-bottom:1.25rem;flex-wrap:wrap;}
.ai-bar-text{flex:1;min-width:180px;}
.ai-bar-title{color:#fff;font-weight:600;margin-bottom:.2rem;font-size:.9rem;}
.ai-bar-text p{color:rgba(255,255,255,.7);font-size:.82rem;}

/* ── NUTRITION ── */
.nutrition-panel h3{font-family:'Outfit',sans-serif;font-size:1rem;margin-bottom:.9rem;}
.nutr-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--mid);margin:0 0 .5rem;}
.nutr-section-title span{font-weight:400;text-transform:none;letter-spacing:0;margin-left:.35rem;}
.nutr-meal-chips{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.75rem;}
.nutr-chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--warm);border-radius:20px;padding:.2rem .6rem;font-size:.72rem;color:var(--mid);}
.nutr-chip.dinner{background:#FEF0E7;color:var(--tc);}
.nutr-chip.lunch{background:#E7F0FE;color:#2A5FBF;}
.nutr-chip.snack{background:#E8F5E4;color:var(--green);}
.nutr-gap-box{background:var(--warm);border-radius:10px;padding:.75rem 1rem;margin-top:.75rem;}
.nutr-gap-title{font-size:.72rem;font-weight:700;color:var(--mid);margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem;}
.nutr-legend-item{display:flex;align-items:center;gap:.3rem;font-size:.7rem;color:var(--mid);}
.nutr-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.nutr-stacked-bar{height:12px;border-radius:6px;background:var(--border);overflow:hidden;display:flex;margin:.2rem 0 .15rem;}
.nutr-stacked-seg{height:100%;transition:width .5s ease;}
.nutr-row-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.1rem;}
.nutr-row-name{font-size:.78rem;font-weight:600;color:var(--dark);}
.nutr-row-vals{font-size:.72rem;color:var(--mid);}
.nutr-row-vals strong{color:var(--dark);}
.nutr-row-vals .gap{color:#e67e22;font-weight:600;}
.nutr-row-vals .met{color:var(--green);font-weight:600;}
.nutr-row-vals .over{color:#dc3545;font-weight:600;}
.nutr-no-data{text-align:center;padding:1.5rem;color:var(--mid);font-size:.83rem;}
.nutrition-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem;}
.nutr-name{width:120px;font-size:.75rem;color:var(--mid);flex-shrink:0;}
.nutr-bar-bg{flex:1;height:7px;background:var(--border);border-radius:4px;overflow:hidden;}
.nutr-bar{height:100%;border-radius:4px;background:var(--tc);transition:width .5s ease;}
.nutr-bar.good{background:var(--green);}.nutr-bar.over{background:#dc3545;}
.nutr-val{width:72px;font-size:.73rem;text-align:right;color:var(--mid);flex-shrink:0;}

/* ── SHOPPING ── */
.shopping-header{display:flex;gap:.75rem;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;}
.shopping-category{margin-bottom:1.25rem;}.shopping-category h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--mid);font-weight:600;}
.shopping-category h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--mid);font-weight:600;margin-bottom:.65rem;display:flex;align-items:center;gap:.5rem;}
.shopping-category h3::after{content:'';flex:1;height:1px;background:var(--border);}
.shopping-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.75rem;}
.shopping-item{display:flex;flex-direction:column;gap:0;padding:0;background:#fff;border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;overflow:hidden;}
.shopping-item:active{background:var(--warm);}
.shopping-item.checked{opacity:.5;}.shopping-item.checked .item-name{text-decoration:line-through;}
.item-check{width:18px;height:18px;border-radius:4px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.7rem;}
.shopping-item.checked .item-check{background:var(--green);border-color:var(--green);color:#fff;}
/* Card top bar */
.item-card-top{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem 0;}
.item-qty-badge{font-size:.82rem;color:var(--mid);font-weight:500;white-space:nowrap;}
.custom-item-del{background:none;border:none;cursor:pointer;color:var(--light);padding:.1rem .25rem;border-radius:4px;line-height:1;opacity:.6;transition:all .15s;}
.custom-item-del:hover{opacity:1;color:#dc3545;background:rgba(220,53,69,.08);}
/* Hero: photo + name/price side by side */
.item-hero{display:flex;align-items:center;gap:.6rem;padding:.4rem .75rem .6rem;}
.item-hero-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem;}
/* Photo area */
.item-photo-area{display:flex;justify-content:center;align-items:center;flex-shrink:0;}
/* Name + TOTAL row */
.item-name-total-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.3rem;}
.item-name{font-size:.92rem;font-weight:600;line-height:1.3;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;}
.item-total-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--mid);white-space:nowrap;padding-top:.2rem;flex-shrink:0;}
/* Price row */
.item-price-row{display:flex;align-items:center;justify-content:space-between;gap:.3rem;min-width:0;}
.item-cost-display{font-size:1rem;font-weight:700;color:var(--green);white-space:nowrap;}
/* Stepper */
.item-stepper{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-top:auto;padding:.5rem .75rem;border-top:1px solid var(--border);}
.stepper-btn{width:26px;height:26px;border-radius:7px;border:none;background:var(--warm);color:var(--tc);font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;transition:background .15s;flex-shrink:0;}
.stepper-btn:hover{background:#e0dbd4;}
.stepper-val{font-size:.9rem;font-weight:600;min-width:22px;text-align:center;color:var(--tc);}
.stepper-unit{font-size:.82rem;font-weight:500;opacity:.7;}
.stepper-input{font-size:1rem;font-weight:600;width:48px;text-align:center;border:1px solid var(--border);border-radius:6px;padding:.1rem .2rem;background:var(--warm);color:var(--tc);-moz-appearance:textfield;}
.stepper-input::-webkit-outer-spin-button,.stepper-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.stepper-input:focus{outline:none;border-color:var(--green);}
.item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0;}
.postal-code-wrap{display:flex;align-items:center;gap:.3rem;background:var(--warm);border:1px solid var(--border);border-radius:8px;padding:.25rem .5rem;}
.fetch-price-btn{background:var(--tc);color:#fff;border:none;cursor:pointer;font-size:.72rem;padding:.3rem .5rem;border-radius:6px;opacity:.9;transition:opacity .15s,background .15s;display:inline-flex;align-items:center;gap:.2rem;margin-left:.25rem;white-space:nowrap;font-weight:600;}
.fetch-price-btn:hover{opacity:1;}
.fetch-price-btn:active{opacity:.75;}
.fetch-price-btn.loading{opacity:.4;cursor:wait;}
.item-price-wrap{display:flex;align-items:center;gap:1px;background:var(--warm);border-radius:6px;padding:.15rem .35rem;cursor:text;}
.price-currency{font-size:.8rem;color:var(--mid);}
.item-price-input{width:46px;border:none;background:transparent;font-size:.85rem;font-family:'Inter',sans-serif;color:var(--tc);text-align:right;outline:none;padding:0;}
.item-price-input::placeholder{color:var(--mid);}
.price-unit-lbl{font-size:.78rem;color:var(--mid);white-space:nowrap;}
.item-cost-display{font-weight:700;color:var(--green);}
.price-recipe-hint{font-size:.61rem;color:var(--mid);padding:.05rem .75rem;margin-top:0;min-height:1.1em;}
.item-coverage-hint{font-size:.63rem;text-align:center;padding:.25rem .75rem;font-weight:600;}
.item-coverage-hint.covered{color:#16a34a;background:#dcfce7;}
.item-coverage-hint.short{color:#b45309;background:#fef3c7;}
.cat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;}
.cat-header h3{margin:0;font-size:1rem;}
.cat-cost-total{font-size:.88rem;font-weight:600;color:var(--green);background:#E8F5E4;padding:.2rem .55rem;border-radius:10px;}
.shopping-grand-total{background:linear-gradient(135deg,var(--tc) 0%,#3a3529 100%);color:#fff;border-radius:12px;padding:.75rem 1rem;margin-bottom:.75rem;font-size:.88rem;display:flex;align-items:center;gap:.5rem;}
.store-pill-cost{font-size:.68rem;font-weight:700;margin-left:.1rem;opacity:.85;}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--mid);}
.empty-state .icon{font-size:2.5rem;margin-bottom:.75rem;}.empty-state p{font-size:.875rem;}

/* ── PRICE COMPARISON TABLE (per item) ── */
.price-cmp-section{margin-top:0;border-top:1px solid var(--border);padding:.45rem .75rem;background:var(--cream);}
.price-cmp-toggle{display:flex;align-items:center;gap:.3rem;cursor:pointer;user-select:none;font-size:.75rem;color:var(--mid);padding:.05rem 0;}
.price-cmp-toggle:hover{color:var(--dark);}
.price-cmp-toggle-arrow{font-size:.6rem;transition:transform .15s;}
.price-cmp-section.open .price-cmp-toggle-arrow{transform:scaleY(-1);}
.price-cmp-table{display:flex;flex-direction:column;gap:2px;margin-top:.25rem;display:none;}
.price-cmp-section.open .price-cmp-table{display:flex;}
.price-cmp-row{display:flex;align-items:center;gap:.2rem;font-size:.72rem;line-height:1.3;padding:.1rem 0;}
.price-cmp-row.best{background:rgba(74,103,65,.08);border-radius:4px;padding:.1rem .3rem;margin:0 -.3rem;}
.price-cmp-store{font-weight:600;min-width:0;max-width:5.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;}
.price-cmp-ref{color:var(--light);font-size:.68rem;text-align:right;white-space:nowrap;flex-shrink:0;margin-left:auto;}
.price-cmp-price{color:var(--mid);text-align:right;white-space:nowrap;flex-shrink:0;}
.price-cmp-row.best .price-cmp-ref{color:var(--green);opacity:.7;}
.price-cmp-row.best .price-cmp-price{color:var(--green);font-weight:700;}
.price-cmp-star{color:#f59e0b;flex-shrink:0;font-size:.7rem;}
.price-cmp-del{background:none;border:none;cursor:pointer;color:var(--light);font-size:.6rem;padding:.1rem .2rem;line-height:1;border-radius:3px;flex-shrink:0;opacity:.6;}
.price-cmp-del:hover{opacity:1;color:#dc3545;}
.price-cmp-row.chosen{outline:2.5px solid var(--tc);outline-offset:1px;border-radius:6px;}
.price-cmp-cheaper-hint{font-size:.6rem;font-weight:600;color:#e65100;background:#fff8e1;padding:.05rem .3rem;border-radius:6px;white-space:nowrap;cursor:pointer;flex-shrink:0;}

/* ── PRICE SUMMARY SECTION ── */
.price-summary-section{border:1px solid var(--border);border-radius:12px;margin-bottom:.85rem;overflow:hidden;background:var(--card-bg);}
.psm-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;background:var(--warm);cursor:pointer;user-select:none;}
.psm-title{font-size:.85rem;font-weight:700;color:var(--dark);}
.psm-toggle{background:none;border:none;font-size:.78rem;color:var(--mid);cursor:pointer;padding:.15rem .35rem;border-radius:5px;transition:background .15s;}
.psm-toggle:hover{background:var(--border);}
.psm-body{display:none;padding:.75rem 1rem 1rem;}
.price-summary-section.expanded .psm-body{display:block;}
.price-summary-section.expanded .psm-toggle{transform:scaleY(-1);}
.psm-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-bottom:.6rem;}
.psm-table th{text-align:left;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mid);padding:.3rem .4rem;border-bottom:1px solid var(--border);}
.psm-table td{padding:.35rem .4rem;border-bottom:1px solid rgba(0,0,0,.04);}
.psm-store-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:.4rem;vertical-align:middle;flex-shrink:0;}
.psm-amount{font-weight:700;color:var(--dark);text-align:right;white-space:nowrap;}
.psm-coverage{text-align:right;color:var(--mid);font-size:.72rem;}
.psm-optimized-row td{background:rgba(74,103,65,.07);font-weight:700;}
.psm-optimized-row .psm-amount{color:var(--green);}
.psm-savings{margin-top:.5rem;padding:.55rem .75rem;background:linear-gradient(135deg,rgba(74,103,65,.12) 0%,rgba(74,103,65,.05) 100%);border:1px solid rgba(74,103,65,.2);border-radius:8px;font-size:.82rem;color:var(--dark);line-height:1.5;}
.psm-savings strong{color:var(--green);}
.psm-hint{margin-top:.45rem;font-size:.65rem;color:var(--light);font-style:italic;}
.psm-no-data{padding:1rem;text-align:center;color:var(--mid);font-size:.82rem;}

/* ── CATEGORY SUMMARY TABLE ── */
.category-summary-section{border:1px solid var(--border);border-radius:12px;margin-bottom:.85rem;overflow:hidden;background:var(--card-bg);}
.cst-header{display:flex;align-items:center;gap:.5rem;padding:.65rem 1rem;background:var(--warm);cursor:pointer;user-select:none;}
.cst-title{font-size:.85rem;font-weight:700;color:var(--dark);flex:1;}
.cst-grand-total{font-size:.95rem;font-weight:700;color:var(--green);white-space:nowrap;}
.cst-toggle{background:none;border:none;font-size:.78rem;color:var(--mid);cursor:pointer;padding:.15rem .35rem;border-radius:5px;transition:background .15s;}
.cst-toggle:hover{background:var(--border);}
.cst-body{display:none;padding:.5rem 1rem .75rem;}
.category-summary-section.expanded .cst-body{display:block;}
.category-summary-section.expanded .cst-toggle{transform:scaleY(-1);}
.cst-table{width:100%;border-collapse:collapse;font-size:.82rem;}
.cst-table th{text-align:left;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mid);padding:.3rem .4rem;border-bottom:1px solid var(--border);}
.cst-table td{padding:.35rem .4rem;border-bottom:1px solid rgba(0,0,0,.04);}
.cst-cat-name{font-weight:600;white-space:nowrap;}
.cst-cat-count{text-align:center;color:var(--mid);font-size:.75rem;}
.cst-cat-amount{text-align:right;font-weight:600;color:var(--dark);white-space:nowrap;}
.cst-total-row td{border-top:2px solid var(--border);border-bottom:none;padding-top:.5rem;}
.cst-total-row .cst-cat-amount{font-weight:700;color:var(--green);font-size:.9rem;}

/* ── ADD CUSTOM ITEM SECTION ── */
.add-item-section{border:1px solid var(--border);border-radius:12px;margin-top:1rem;overflow:hidden;background:var(--card-bg);}
.add-item-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;background:var(--warm);cursor:pointer;user-select:none;}
.add-item-title{font-size:.85rem;font-weight:700;color:var(--dark);}
.add-item-toggle{background:none;border:none;font-size:.78rem;color:var(--mid);cursor:pointer;padding:.15rem .35rem;border-radius:5px;}
.add-item-toggle:hover{background:var(--border);}
.add-item-body{display:none;padding:.75rem 1rem;}
.add-item-section.expanded .add-item-body{display:block;}
.add-item-section.expanded .add-item-toggle{transform:scaleY(-1);}
.add-item-row{display:flex;gap:.4rem;margin-bottom:.5rem;align-items:center;}
.add-item-input{flex:2;font-size:.85rem;padding:.4rem .6rem;border:1.5px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;background:#fff;min-width:120px;color:var(--dark);}
.add-item-input::placeholder{color:var(--mid);}
.add-item-input:focus{outline:none;border-color:var(--green);}
.add-item-qty{width:60px;font-size:.85rem;padding:.4rem .5rem;border:1px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;text-align:center;-moz-appearance:textfield;}
.add-item-qty::-webkit-outer-spin-button,.add-item-qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.add-item-unit{width:60px;font-size:.85rem;padding:.4rem .5rem;border:1px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;text-align:center;}
.add-item-select{font-size:.78rem;padding:.35rem .4rem;border:1.5px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;background:#fff;color:var(--dark);cursor:pointer;min-width:90px;width:auto;flex-shrink:0;}
.add-item-cat-select{flex:1;min-width:0;}
.add-item-actions{display:flex;gap:.5rem;margin-bottom:.5rem;}
.add-item-search-btn{font-size:.78rem!important;padding:.35rem .6rem!important;}
.add-item-add-btn{font-size:.78rem!important;padding:.35rem .6rem!important;}
.add-item-results{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto;}
.add-item-result-card{display:flex;align-items:center;gap:.5rem;padding:.45rem .5rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;background:#fff;}
.add-item-result-card:hover{background:var(--warm);}
.add-item-result-card.selected{border-color:var(--green);background:rgba(74,103,65,.08);}
.add-item-result-img{width:40px;height:40px;object-fit:contain;border-radius:6px;flex-shrink:0;}
.add-item-result-info{flex:1;min-width:0;}
.add-item-result-name{font-size:.8rem;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.add-item-result-meta{font-size:.7rem;color:var(--mid);}

/* ── SEARCH ALL SUPERMARKETS BUTTON STATE ── */
#btn-search-all:disabled{opacity:.6;cursor:wait;}
#btn-search-all .search-all-progress{font-size:.7rem;opacity:.8;}

/* ── RECIPE VIEW ── */
.macros-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-bottom:1rem;}
.macro-box{background:var(--warm);border-radius:10px;padding:.75rem;text-align:center;}
.macro-box .val{font-family:'Outfit',sans-serif;font-size:1.3rem;color:var(--tc);}
.macro-box .lbl{font-size:.7rem;color:var(--mid);}
.ingr-chip{display:inline-flex;background:var(--warm);border-radius:6px;padding:.28rem .65rem;font-size:.78rem;margin:.18rem;}
.ingr-scaled{background:#E8F5E4;color:#2d6a2d;font-weight:600;}
.step-item{display:flex;gap:.65rem;margin-bottom:.65rem;align-items:flex-start;}
.step-num{width:24px;height:24px;border-radius:50%;background:var(--tc);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;flex-shrink:0;margin-top:.1rem;}
.step-text{font-size:.85rem;line-height:1.55;}

/* ── PHOTOS ── */
.photo-upload-area{border:2px dashed var(--border);border-radius:12px;padding:1.25rem;text-align:center;cursor:pointer;transition:all .2s;position:relative;background:var(--warm);}
.photo-upload-area:hover,.photo-upload-area.drag-over{border-color:var(--tc);background:#FEF0E7;}
.photo-upload-area input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.photo-upload-icon{font-size:1.75rem;margin-bottom:.35rem;}
.photo-upload-text{font-size:.85rem;color:var(--mid);font-weight:500;}
.photo-upload-hint{font-size:.72rem;color:var(--mid);margin-top:.2rem;}
.photo-actions{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap;}
.photo-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem;margin-top:.65rem;}
.photo-thumb{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid var(--border);}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-thumb .photo-remove{position:absolute;top:3px;right:3px;background:rgba(30,28,24,.75);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.photo-thumb .photo-primary-badge{position:absolute;bottom:3px;left:3px;background:var(--tc);color:#fff;font-size:.55rem;font-weight:700;padding:.1rem .35rem;border-radius:3px;text-transform:uppercase;}
.photo-thumb .set-primary-btn{position:absolute;bottom:3px;right:3px;background:rgba(255,255,255,.9);color:var(--mid);font-size:.55rem;font-weight:700;padding:.1rem .35rem;border-radius:3px;border:none;cursor:pointer;text-transform:uppercase;}
.photo-uploading{background:var(--warm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;}
.photo-upload-spinner{font-size:1.4rem;animation:spin 1.2s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.photo-error{background:#fff0f0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.3rem;}
.recipe-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.4rem;margin-bottom:1rem;}
.recipe-gallery-img{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;}
.recipe-gallery-img img{width:100%;height:100%;object-fit:cover;transition:transform .2s;}
.recipe-gallery-img:hover img{transform:scale(1.04);}

/* ── VIEW RECIPE: DIGITAL COOKBOOK LAYOUT ── */
.view-recipe-modal .modal-body{padding:0;}
.view-hero{width:100%;aspect-ratio:4.5/1;overflow:hidden;flex-shrink:0;border-radius:16px 16px 0 0;}
.view-hero img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.view-hero-placeholder{width:100%;aspect-ratio:4.5/1;background:var(--warm);display:flex;align-items:center;justify-content:center;font-size:5rem;border-radius:16px 16px 0 0;}
.view-header-section{padding:1rem 1.25rem .85rem;border-bottom:1px solid var(--border);}
.view-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.5rem;}
.view-recipe-title{font-family:'Outfit',sans-serif;font-size:1.4rem;font-weight:700;color:var(--dark);line-height:1.3;margin:0;}
.view-meta-row{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;}
.view-time-info{color:var(--mid);font-size:.78rem;margin-left:auto;}
.view-macro-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;border-top:1px solid var(--border);margin-top:.85rem;padding-top:.85rem;text-align:center;}
.view-macro-strip .macro-item{display:flex;flex-direction:column;align-items:center;}
.view-macro-strip .macro-bar{width:100%;height:3px;border-radius:3px;margin-bottom:6px;}
.view-macro-strip .macro-value{font-family:'Outfit',sans-serif;font-weight:700;color:var(--dark);font-size:.95rem;}
.view-macro-strip .macro-label{font-size:.68rem;color:var(--mid);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;}
.view-split{display:grid;grid-template-columns:1fr 2fr;gap:0;}
.view-ingredients{padding:1rem 1rem 1rem 1.25rem;border-right:1px solid var(--border);}
.view-preparation{padding:1rem 1.25rem 1rem 1rem;}
.view-section-title{font-family:'Outfit',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:.7rem;}
.view-ingr-list{list-style:none;padding:0;margin:0;}
.view-ingr-list li{display:flex;gap:.45rem;padding:.3rem 0;font-size:.82rem;color:var(--dark);border-bottom:1px solid var(--border);line-height:1.4;}
.view-ingr-list li:last-child{border-bottom:none;}
.view-ingr-list li::before{content:"•";color:var(--tc);font-weight:700;flex-shrink:0;}
.view-ingr-scaled{color:#2d6a2d;font-weight:600;}
.view-step-item{display:flex;gap:.6rem;margin-bottom:.6rem;align-items:flex-start;}
.view-step-num{font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:700;color:var(--tc);flex-shrink:0;min-width:1.4rem;line-height:1.45;}
.view-step-text{font-size:.84rem;line-height:1.55;color:var(--dark);}
.view-tip-box{background:#E8F5E4;border-radius:8px;padding:.65rem .85rem;margin-top:1rem;font-size:.82rem;color:#2d6a2d;border-left:3px solid #4A6741;line-height:1.45;}
.view-source-box{padding:.65rem 1.25rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--mid);}
@media(max-width:580px){
  .view-hero{aspect-ratio:3/1;}
  .view-split{grid-template-columns:1fr;}
  .view-ingredients{padding:1rem 1.25rem;border-right:none;border-bottom:1px solid var(--border);}
  .view-preparation{padding:1rem 1.25rem;}
  .view-macro-strip{grid-template-columns:repeat(2,1fr);}
}

/* ══════════ LANDING PAGE ══════════ */
/* ── LANDING PAGE ── */
#landing-panel{font-family:'Inter',sans-serif;color:#1E1C18;overflow-x:hidden;}
/* Nav */
.lp-nav{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:64px;position:sticky;top:0;background:rgba(250,247,242,.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:50;border-bottom:1px solid #E2D9CC;}
.lp-nav-left{display:flex;align-items:center;gap:.65rem;}
.lp-logo{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:700;color:#1E1C18;}
.lp-logo span{color:#A85228;font-style:italic;}
.lp-brand-name{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:700;color:#1E1C18;line-height:1;}
.lp-brand-name span{color:#A85228;font-style:italic;}
.lp-nav-actions{display:flex;gap:.6rem;align-items:center;}
.lp-btn-ghost{background:none;border:1.5px solid #D1C5B4;color:#5C5547;padding:.45rem 1rem;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;font-size:.85rem;font-weight:500;transition:all .2s;}
.lp-btn-ghost:hover{border-color:#C4622D;color:#C4622D;background:rgba(196,98,45,.05);}
.lp-btn-cta{background:#C4622D;color:#fff;border:none;padding:.5rem 1.25rem;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;transition:all .2s;}
.lp-btn-cta:hover{background:#b05828;transform:translateY(-1px);box-shadow:0 4px 14px rgba(196,98,45,.3);}
.lp-btn-lg{padding:.85rem 1.5rem;font-size:1rem;border-radius:8px;}
/* Hero */
.lp-hero{display:flex;align-items:center;gap:3.5rem;padding:5rem 2rem 3.5rem;max-width:1100px;margin:0 auto;}
.lp-hero-inner{flex:1;min-width:0;}
.lp-hero-tag{display:inline-flex;align-items:center;gap:.4rem;background:#F5EFE4;color:#A85228;font-size:.78rem;font-weight:700;padding:.35rem .85rem;border-radius:20px;margin-bottom:1.4rem;letter-spacing:.03em;border:1px solid #EDE3D4;}
.lp-hero-tag svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.lp-hero-title{font-family:'Outfit',sans-serif;font-size:clamp(2.1rem,5vw,3.3rem);line-height:1.1;color:#1E1C18;margin-bottom:1.25rem;font-weight:700;}
.lp-hero-title em{font-style:italic;color:#A85228;}
.lp-hero-sub{font-size:1.05rem;color:#5C5547;line-height:1.7;max-width:500px;margin-bottom:2rem;}
.lp-hero-btns{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.85rem;}
.lp-hero-note{font-size:.78rem;color:#5C5547;}
/* Mockup */
.lp-hero-visual{flex:0 0 390px;position:relative;}
.lp-mockup{background:#fff;border-radius:18px;box-shadow:0 24px 64px rgba(30,28,24,.15);overflow:hidden;border:1px solid #E2D9CC;}
.lp-mockup-bar{background:#1E1C18;padding:.6rem .9rem;display:flex;gap:.4rem;align-items:center;}
.lp-mockup-bar span{width:10px;height:10px;border-radius:50%;background:#555;}
.lp-mockup-bar span:first-child{background:#A85228;}
.lp-mockup-content{padding:1.25rem;}
.lp-mock-week{display:flex;gap:.4rem;margin-bottom:1rem;}
.lp-mock-day{flex:1;background:#FAF7F2;border-radius:9px;padding:.55rem .35rem;text-align:center;}
.lp-mock-label{font-size:.58rem;color:#5C5547;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;}
.lp-mock-meal{font-size:.72rem;color:#1E1C18;font-weight:500;line-height:1.3;display:flex;flex-direction:column;align-items:center;gap:.2rem;}
.lp-mock-meal svg{width:16px;height:16px;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.lp-mock-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;}
.lp-mock-stat{background:#F5EFE4;border-radius:8px;padding:.65rem;text-align:center;}
.lp-mock-stat-val{font-family:'Outfit',sans-serif;font-size:1.4rem;color:#A85228;font-weight:700;line-height:1;}
.lp-mock-stat-lbl{font-size:.6rem;color:#5C5547;margin-top:.15rem;}
.lp-mockup-float{position:absolute;top:-12px;right:-12px;background:#4A6741;color:#fff;font-size:.72rem;font-weight:700;padding:.4rem .8rem;border-radius:20px;box-shadow:0 4px 14px rgba(74,103,65,.35);}
/* Features */
.lp-features{background:#FAF7F2;padding:5rem 2rem;text-align:center;}
.lp-section-tag{display:inline-block;background:#F5EFE4;color:#C4622D;font-size:.7rem;font-weight:700;padding:.28rem .7rem;border-radius:20px;letter-spacing:.06em;margin-bottom:1.25rem;}
.lp-section-title{font-family:'Outfit',sans-serif;font-size:clamp(1.5rem,3vw,2.1rem);color:#1E1C18;margin-bottom:.75rem;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.25;}
.lp-section-sub{color:#5C5547;font-size:.92rem;margin-bottom:2.5rem;}
.lp-features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:1.25rem;max-width:1000px;margin:0 auto;text-align:left;}
.lp-feature-card{background:#fff;border:1px solid #E2D9CC;border-radius:14px;padding:1.6rem;transition:box-shadow .2s,transform .2s;}
.lp-feature-card:hover{box-shadow:0 8px 32px rgba(30,28,24,.1);transform:translateY(-2px);}
.lp-feature-icon{width:46px;height:46px;border-radius:12px;background:#F5EFE4;display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:1rem;color:#A85228;}
.lp-feature-icon svg{width:24px;height:24px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.lp-feature-card h3{font-size:.95rem;font-weight:700;color:#1E1C18;margin-bottom:.45rem;}
.lp-feature-card p{font-size:.83rem;color:#5C5547;line-height:1.65;}
/* Values strip */
.lp-values{background:#1E1C18;padding:2.75rem 2rem;}
.lp-values-inner{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;max-width:900px;margin:0 auto;}
.lp-value{text-align:center;flex:1;min-width:150px;max-width:200px;}
.lp-value-icon{font-size:1.5rem;display:flex;justify-content:center;margin-bottom:.5rem;color:#E8845A;}
.lp-value-icon svg{width:28px;height:28px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.lp-value strong{display:block;color:#FAF7F2;font-size:.88rem;margin-bottom:.25rem;}
.lp-value p{color:#9E9183;font-size:.78rem;line-height:1.5;}
/* Editorial split */
.lp-editorial{background:#F5EFE4;padding:5rem 2rem;}
.lp-editorial-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1000px;margin:0 auto;}
.lp-editorial-text h2{font-family:'Outfit',sans-serif;font-size:clamp(1.5rem,2.8vw,2rem);color:#1E1C18;line-height:1.25;margin-bottom:1rem;}
.lp-editorial-text h2 em{font-style:italic;color:#A85228;}
.lp-editorial-text p{color:#5C5547;font-size:.95rem;line-height:1.7;margin-bottom:1.1rem;}
.lp-checks{display:flex;flex-direction:column;gap:.6rem;margin-top:1.25rem;}
.lp-check{display:flex;align-items:flex-start;gap:.6rem;font-size:.875rem;color:#5C5547;}
.lp-check-icon{width:22px;height:22px;border-radius:50%;background:#A85228;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;flex-shrink:0;margin-top:.1rem;}
.lp-ed-card{background:#fff;border-radius:16px;box-shadow:0 12px 40px rgba(30,28,24,.12);overflow:hidden;border:1px solid #E2D9CC;}
.lp-ed-card-header{background:#1E1C18;padding:.75rem 1rem;display:flex;align-items:center;gap:.6rem;}
.lp-ed-card-title{color:#FAF7F2;font-size:.82rem;font-weight:600;}
.lp-ed-card-body{padding:1rem;}
.lp-member-list{display:flex;flex-direction:column;gap:.55rem;}
.lp-member-row{display:flex;align-items:center;gap:.7rem;padding:.55rem .7rem;border-radius:10px;background:#FAF7F2;}
.lp-member-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;}
.lp-member-info{flex:1;}
.lp-member-name{font-size:.83rem;font-weight:600;color:#1E1C18;}
.lp-member-detail{font-size:.68rem;color:#5C5547;}
.lp-member-kcal{font-size:.78rem;font-weight:700;color:#A85228;white-space:nowrap;}
/* CTA bottom */
.lp-cta-bottom{background:#1E1C18;padding:5rem 2rem;text-align:center;position:relative;overflow:hidden;}
.lp-cta-bottom::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center bottom,rgba(196,98,45,.15) 0%,transparent 65%);}
.lp-cta-bottom-inner{position:relative;max-width:560px;margin:0 auto;}
.lp-cta-bottom h2{font-family:'Outfit',sans-serif;font-size:clamp(1.75rem,3.5vw,2.5rem);color:#FAF7F2;line-height:1.2;margin-bottom:.85rem;}
.lp-cta-bottom h2 em{font-style:italic;color:#E8845A;}
.lp-cta-bottom p{color:#9E9183;font-size:.95rem;margin-bottom:2rem;line-height:1.6;}
.lp-cta-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;}
.lp-btn-ghost-light{background:none;border:1.5px solid rgba(255,255,255,.2);color:#FAF7F2;padding:.8rem 1.75rem;border-radius:10px;cursor:pointer;font-family:'Inter',sans-serif;font-size:1rem;font-weight:500;transition:all .2s;}
.lp-btn-ghost-light:hover{border-color:rgba(255,255,255,.4);}
/* Age-adapted nutrition */
.lp-age-nutrition{background:#FAF7F2;padding:5rem 2rem;text-align:center;}
.lp-age-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:900px;margin:0 auto;}
.lp-age-card{background:#fff;border:1px solid #E2D9CC;border-radius:14px;padding:2rem 1.5rem;transition:box-shadow .2s,transform .2s;}
.lp-age-card:hover{box-shadow:0 8px 32px rgba(30,28,24,.1);transform:translateY(-2px);}
.lp-age-card-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;}
.lp-age-card-icon svg{width:26px;height:26px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.lp-age-card:nth-child(1) .lp-age-card-icon{background:#FDE8D8;color:#A85228;}
.lp-age-card:nth-child(2) .lp-age-card-icon{background:#E8F5E4;color:#4A6741;}
.lp-age-card:nth-child(3) .lp-age-card-icon{background:#E4EDF5;color:#3B5998;}
.lp-age-card h3{font-family:'Outfit',sans-serif;font-size:1.05rem;font-weight:700;color:#1E1C18;margin-bottom:.35rem;}
.lp-age-card .lp-age-range{font-size:.78rem;color:#9E9183;margin-bottom:.75rem;}
.lp-age-card p{font-size:.83rem;color:#5C5547;line-height:1.65;}
@media(max-width:768px){.lp-age-nutrition{padding:3rem 1.25rem;}.lp-age-cards{grid-template-columns:1fr;max-width:360px;}}
/* Pricing */
.lp-pricing{background:#fff;padding:5rem 2rem;text-align:center;}
.lp-pricing-sub{color:#5C5547;font-size:.95rem;margin-top:-.5rem;margin-bottom:2rem;}
.lp-plan-toggle{display:inline-flex;background:#FAF7F2;border:1.5px solid #E2D9CC;border-radius:12px;padding:.25rem;margin-bottom:2.5rem;gap:.25rem;}
.lp-toggle-btn{background:none;border:none;padding:.45rem 1.1rem;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;font-size:.85rem;font-weight:500;color:#5C5547;transition:all .2s;display:flex;align-items:center;gap:.4rem;}
.lp-toggle-btn.active{background:#fff;color:#1E1C18;font-weight:700;box-shadow:0 1px 6px rgba(30,28,24,.1);}
.lp-save-badge{background:#A85228;color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .45rem;border-radius:20px;}
.lp-pricing-card{max-width:420px;margin:0 auto;background:#FAF7F2;border:2px solid #E2D9CC;border-radius:20px;padding:2.5rem 2rem;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;}
.lp-pricing-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#A85228,#E8845A);}
.lp-pricing-icon{font-size:2.5rem;margin-bottom:.75rem;}
.lp-plan-name{font-size:.85rem;font-weight:700;color:#5C5547;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;}
.lp-plan-price{display:flex;align-items:baseline;justify-content:center;gap:.2rem;margin-bottom:.5rem;}
.lp-price-amount{font-family:'Outfit',sans-serif;font-size:3rem;font-weight:700;color:#1E1C18;}
.lp-price-period{font-size:1rem;color:#5C5547;}
.lp-price-annual-note{font-size:.8rem;color:#4A6741;font-weight:600;margin-bottom:1.25rem;background:#E8F5E4;padding:.3rem .75rem;border-radius:20px;display:inline-block;}
.lp-plan-features{list-style:none;text-align:left;margin:1.5rem 0;display:flex;flex-direction:column;gap:.65rem;flex:1;width:100%;}
.lp-plan-features li{font-size:.88rem;color:#5C5547;display:flex;align-items:flex-start;gap:.6rem;}
.lp-plan-features li::before{content:'✓';color:#A85228;font-weight:700;flex-shrink:0;margin-top:.05rem;}
.lp-checkout-btn{width:100%;justify-content:center;font-size:1rem;padding:.85rem 1.5rem;margin-bottom:.75rem;}
.lp-plan-note{font-size:.75rem;color:#5C5547;margin-top:.6rem;text-align:center;}
.lp-plans-wrap{display:flex;gap:1.5rem;max-width:1050px;margin:2rem auto 0;align-items:stretch;}
.lp-plans-wrap .lp-pricing-card{flex:1;max-width:none;margin:0;}
.lp-pricing-card.lp-card-premium{border-color:#A85228;border-width:2px;transform:scale(1.04);background:#FDF5ED;box-shadow:0 8px 30px rgba(168,82,40,.18);}
.lp-pricing-card.lp-card-premium::before{height:6px;}
.lp-plan-features li.excluded{opacity:.45;}
.lp-plan-features li.excluded::before{content:'—';color:#9E9183;}
@media(max-width:768px){
  .lp-pricing{padding:3rem 1.25rem;}
  .lp-pricing-card{padding:2rem 1.5rem;}
  .lp-plans-wrap{flex-direction:column;}
  .lp-pricing-card.lp-card-premium{transform:none;}
  .lp-editorial-inner{grid-template-columns:1fr;}
  .lp-editorial .lp-ed-card{order:-1;}
  .lp-hero{flex-direction:column;padding:3rem 1.25rem 2.5rem;gap:2.5rem;}
  .lp-hero-visual{width:100%;}
  .lp-mockup-float{display:none;}
}
/* Trial card */
.lp-trial-card{background:linear-gradient(135deg,#FDF6EE,#FAF0E2);border:1.5px solid #E8D5B0;border-radius:20px;padding:2.5rem 2rem;margin:2.5rem auto 0;max-width:750px;text-align:center;}
.lp-trial-steps{display:flex;align-items:flex-start;justify-content:center;gap:1rem;flex-wrap:wrap;}
.lp-trial-step{display:flex;align-items:flex-start;gap:.75rem;max-width:180px;text-align:left;}
.lp-trial-step-num{width:32px;height:32px;border-radius:50%;background:#A85228;color:#fff;font-weight:800;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem;}
.lp-trial-step-body strong{display:block;font-size:.88rem;color:#1E1C18;margin-bottom:.2rem;}
.lp-trial-step-body p{font-size:.78rem;color:#6B6460;margin:0;line-height:1.4;}
.lp-trial-arrow{font-size:1.25rem;color:#A85228;opacity:.5;margin-top:.5rem;flex-shrink:0;}
@media(max-width:600px){.lp-trial-arrow{display:none;}.lp-trial-steps{gap:1.25rem;}.lp-trial-step{max-width:100%;}}
/* Compare table */
.lp-compare-wrap{overflow-x:auto;margin-top:2rem;}
.lp-compare-table{width:100%;max-width:700px;margin:0 auto;border-collapse:separate;border-spacing:0;font-size:.88rem;}
.lp-cth-feat{width:48%;text-align:left;padding:.5rem 1rem .5rem 0;color:var(--mid,#5C5547);vertical-align:bottom;}
.lp-cth-free,.lp-cth-premium{width:26%;text-align:center;padding:1.5rem 1rem 1rem;vertical-align:top;}
.lp-cth-premium{background:linear-gradient(160deg,#FDF6EE,#FAF0E2);border:2px solid #A85228;border-radius:16px 16px 0 0;}
.lp-cth-popular{font-size:.68rem;font-weight:700;color:#A85228;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem;}
.lp-cth-popular svg{width:14px;height:14px;stroke:#A85228;stroke-width:2;fill:#A85228;stroke-linecap:round;stroke-linejoin:round;}
.lp-cth-label{font-size:.8rem;font-weight:700;color:#5C5547;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.35rem;}
.lp-cth-price{font-family:'Outfit',sans-serif;font-size:1.9rem;font-weight:700;color:#1E1C18;line-height:1.1;}
.lp-cth-period{font-size:.78rem;color:#5C5547;margin:.2rem 0 .75rem;}
.lp-cth-btn{width:100%;justify-content:center;font-size:.8rem;padding:.5rem .6rem;margin-bottom:.5rem;display:block;}
.lp-compare-table tbody tr td{padding:.6rem 1rem;border-bottom:1px solid #E2D9CC;}
.lp-compare-table tbody tr:last-child td{border-bottom:none;}
.lp-ctd-feat{text-align:left;color:#1E1C18;font-weight:500;}
.lp-ctd-free,.lp-ctd-premium{text-align:center;color:#5C5547;}
.lp-ctd-premium{background:rgba(168,82,40,.04);border-left:2px solid #A85228;border-right:2px solid #A85228;}
.lp-compare-table tbody tr:last-child .lp-ctd-premium{border-bottom:2px solid #A85228;border-radius:0 0 14px 14px;}
.lp-ctd-check{color:#4A6741;font-weight:700;}
.lp-ctd-cross{color:#C8BDB4;}
.lp-ctd-val{font-size:.82rem;font-weight:600;color:#5C5547;}
.lp-ctd-val-prem{font-size:.82rem;font-weight:700;color:#A85228;}
@media(max-width:580px){
  .lp-compare-table{font-size:.8rem;}
  .lp-cth-free,.lp-cth-premium{padding:1rem .5rem .75rem;}
  .lp-cth-price{font-size:1.5rem;}
  .lp-compare-table tbody tr td{padding:.5rem .4rem;}
  .lp-cth-btn{font-size:.72rem;padding:.45rem .4rem;}
}
.lp-lang-switch{display:flex;gap:.15rem;background:#EDE8E0;border-radius:6px;padding:.2rem;}
.lp-lang-btn{background:none;border:none;cursor:pointer;font-size:.75rem;font-weight:700;font-family:'Inter',sans-serif;padding:.2rem .55rem;border-radius:4px;color:#6B6460;transition:all .15s;}
.lp-lang-btn.active{background:#fff;color:#1E1C18;box-shadow:0 1px 3px rgba(0,0,0,.1);}
.lp-logo-img{height:38px;width:auto;display:block;}
.app-logo-img{height:30px;width:auto;display:block;}
.lp-footer{background:#161411;color:#9E9183;text-align:center;padding:1.25rem;font-size:.78rem;}
/* ── RATINGS SECTION ── */
.lp-ratings{background:#FAF7F2;padding:5rem 2rem;text-align:center;}
.lp-rating-aggregate{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin:2rem 0;}
.lp-rating-score{font-family:'Outfit',sans-serif;font-size:3.5rem;font-weight:700;color:#1E1C18;line-height:1;}
.lp-rating-stars-display{font-size:1.6rem;color:#E8845A;letter-spacing:.1rem;}
.lp-rating-count{font-size:.85rem;color:#9E9183;}
.lp-rating-input{margin-top:1.5rem;}
.lp-rating-prompt{font-size:.9rem;color:#5C5547;margin-bottom:.75rem;}
.lp-stars-picker{display:inline-flex;gap:.35rem;cursor:pointer;}
.lp-star{font-size:2.4rem;color:#E2D9CC;transition:color .12s;cursor:pointer;user-select:none;line-height:1;}
.lp-star.hovered,.lp-star.selected{color:#E8845A;}
.lp-rating-thanks{margin-top:1rem;color:#4A6741;font-size:.92rem;font-weight:600;}
/* ── REVIEW CARDS ── */
.lp-reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.25rem;margin:2.5rem auto 0;max-width:960px;text-align:left;}
.lp-review-card{background:#fff;border-radius:1rem;padding:1.25rem 1.5rem;box-shadow:0 2px 14px rgba(30,28,24,.08);display:flex;flex-direction:column;gap:.65rem;}
.lp-review-card-top{display:flex;align-items:center;gap:.75rem;}
.lp-review-avatar{width:40px;height:40px;border-radius:50%;color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Outfit',sans-serif;}
.lp-review-meta{flex:1;min-width:0;}
.lp-review-name{font-weight:700;font-size:.9rem;color:#1E1C18;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lp-review-stars{font-size:.95rem;color:#E8845A;letter-spacing:.05rem;line-height:1;}
.lp-review-date{font-size:.75rem;color:#9E9183;white-space:nowrap;}
.lp-review-body{font-size:.87rem;color:#5C5547;line-height:1.6;margin:0;}
.lp-write-review-btn{margin-top:1.75rem;display:inline-block;padding:.55rem 1.35rem;border-radius:2rem;border:1.5px solid var(--tc);color:var(--tc);background:transparent;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;font-family:inherit;}
.lp-write-review-btn:hover{background:var(--tc);color:#fff;}
.lp-review-form{background:#fff;border-radius:1rem;padding:1.5rem;max-width:520px;margin:1rem auto 0;box-shadow:0 2px 14px rgba(30,28,24,.08);text-align:left;display:none;}
.lp-review-form.open{display:block;}
.lp-review-form h3{font-family:'Outfit',sans-serif;margin:0 0 1rem;font-size:1rem;color:#1E1C18;}
.lp-review-form input,.lp-review-form textarea{width:100%;box-sizing:border-box;padding:.6rem .85rem;border:1.5px solid #E2D9CC;border-radius:.5rem;font-size:.9rem;color:#1E1C18;background:#FAF7F2;font-family:inherit;margin-bottom:.75rem;outline:none;transition:border-color .15s;}
.lp-review-form textarea{min-height:90px;resize:vertical;}
.lp-review-form input:focus,.lp-review-form textarea:focus{border-color:var(--tc);}
.lp-review-form-stars{display:inline-flex;gap:.35rem;cursor:pointer;margin-bottom:.75rem;}
/* ── FAQ SECTION ── */
.lp-faq{background:#F5EFE4;padding:5rem 2rem;text-align:center;}
.lp-faq-list{max-width:680px;margin:2.5rem auto 0;display:flex;flex-direction:column;gap:.75rem;}
.lp-faq-item{background:#fff;border-radius:12px;border:1px solid #E2D9CC;overflow:hidden;}
.lp-faq-q{width:100%;background:none;border:none;padding:1.1rem 1.4rem;text-align:left;font-family:'Inter',sans-serif;font-size:.95rem;font-weight:600;color:#1E1C18;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;}
.lp-faq-q:hover{background:#FAF7F2;}
.lp-faq-arrow{font-size:1.3rem;color:#A85228;transition:transform .2s;flex-shrink:0;display:inline-block;}
.lp-faq-q.open .lp-faq-arrow{transform:rotate(90deg);}
.lp-faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s;padding:0 1.4rem;font-size:.88rem;color:#5C5547;line-height:1.7;}
.lp-faq-a.open{max-height:300px;padding:.75rem 1.4rem 1.1rem;}
@media(max-width:600px){
  .lp-ratings{padding:3rem 1.25rem;}
  .lp-faq{padding:3rem 1.25rem;}
}
/* Back button in auth overlay */
.lp-back-btn{background:none;border:none;color:#5C5547;font-size:.82rem;cursor:pointer;padding:0 0 .75rem;font-family:'Inter',sans-serif;display:block;}
.lp-back-btn:hover{color:#A85228;}
/* Auth overlay full screen */
#auth-overlay{min-height:100vh;background:var(--cream);}
/* Responsive */
@media(max-width:768px){
  .lp-hero{flex-direction:column;padding:2.5rem 1.25rem 2rem;gap:2rem;}
  .lp-hero-visual{width:100%;flex:none;}
  .lp-mockup-bar{display:none;}
  .lp-nav{padding:.75rem .75rem;height:auto;min-height:52px;gap:.5rem;}
  .lp-nav-left{gap:.4rem;}
  .lp-nav-left{display:none;}
  .lp-nav-actions{gap:.35rem;}
  .lp-lang-btn{font-size:.65rem;padding:.15rem .4rem;}
  .lp-btn-ghost{padding:.35rem .6rem;font-size:.75rem;}
  .lp-btn-cta{padding:.35rem .7rem;font-size:.75rem;white-space:nowrap;}
  .lp-features{padding:3rem 1.25rem;}
  .lp-values-inner{gap:1.25rem;}
  .lp-cta-bottom{padding:3rem 1.25rem;}
  .lp-hero-btns{flex-direction:column;}
  .lp-hero-btns button{width:100%;}
}

/* ── Native app overrides ── */
.native-app .lp-nav-left{display:none!important;}
.native-app .lp-nav{justify-content:flex-end;}
.native-app header{overflow-x:hidden;}
.native-app #app-logo-words{display:none;}
.native-app .lang-switch{flex-shrink:1;flex-wrap:wrap;}
.native-app #btn-sync-up,.native-app #btn-sync-down{display:none!important;}
/* Shopping list: restore original compact app layout */
.native-app .shopping-items{grid-template-columns:1fr;gap:.6rem;}
.native-app .shopping-item{padding:.75rem;gap:.3rem;}
.native-app .item-card-top{padding:0;}
.native-app .item-hero{padding:0;}
.native-app .item-name{font-size:1.05rem;overflow:visible;text-overflow:unset;}
.native-app .item-qty-badge{font-size:.88rem;}
.native-app .item-cost-display{font-size:1.15rem;}
.native-app .price-cmp-section{margin-top:.3rem;padding:.3rem 0 0;background:none;border-top:1px solid var(--border);}
.native-app .price-cmp-row{font-size:.78rem;gap:.25rem;}
.native-app .price-cmp-store{max-width:none;min-width:60px;flex:1;}
.native-app .price-cmp-ref{font-size:.7rem;width:5.5rem;margin-left:0;}
.native-app .price-cmp-price{width:6.5rem;}
.native-app .item-store-row{padding:0;background:none;border-top:none;}
.native-app .item-stepper{margin-top:.25rem;padding:.35rem 0 0;border-top:1px solid var(--border);}
.native-app .price-recipe-hint{padding:0 0 0 .3rem;min-height:0;margin-top:.05rem;}
.native-app .item-coverage-hint{margin-top:.2rem;padding:.12rem .4rem;border-radius:5px;}
/* Bottom nav & desk nav swap — native app only */
@media(max-width:768px){
  .native-app .desk-nav{display:none;}
  .native-app .bottom-nav{display:block;}
  .native-app main{padding-bottom:5.5rem;}
}
@media(max-width:480px){
  .native-app .shopping-item{padding:.6rem .7rem;gap:.25rem;}
  .native-app .item-card-top{padding:0;}
  .native-app .item-hero{padding:0;}
  .native-app .price-cmp-section{padding:.3rem 0;background:none;}
  .native-app .item-store-row{padding:0;background:none;border-top:none;}
  .native-app .item-stepper{padding:.35rem 0 0;}
  .native-app .price-recipe-hint{padding:0;min-height:0;}
  .native-app .item-photo-thumb{width:64px;height:64px;}
  .native-app .item-photo-placeholder{width:64px;height:64px;}
  .native-app .item-cost-display{font-size:1.2rem;}
  .native-app .price-cmp-ref{width:5rem;font-size:.65rem;}
  .native-app .price-cmp-price{width:6rem;font-size:.8rem;}
  .native-app .price-cmp-store{min-width:65px;font-size:.8rem;}
}

/* ── LOGIN ── */
#login-screen{position:fixed;inset:0;z-index:9999;background:var(--warm);overflow-y:auto;}
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem;}
.login-card{background:#fff;border-radius:20px;box-shadow:0 8px 40px rgba(0,0,0,.12);padding:2.5rem 2rem;width:100%;max-width:360px;text-align:center;}
.login-logo{font-family:'Outfit',sans-serif;font-size:1.8rem;color:var(--dark);margin-bottom:.4rem;}
.login-logo span{color:var(--tc);font-style:italic;}
.login-subtitle{color:var(--mid);font-size:.9rem;margin-bottom:1.25rem;}
.login-field-col{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.75rem;}
.login-field-col input{padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:10px;font-family:'Inter',sans-serif;font-size:.95rem;outline:none;transition:border-color .2s;text-align:left;}
.login-field-col input:focus{border-color:var(--tc);}
.login-error{font-size:.8rem;color:#dc3545;min-height:1.2rem;margin-bottom:.25rem;text-align:left;}
.login-switch{font-size:.8rem;color:var(--mid);margin-top:.75rem;}
.login-switch a{color:var(--tc);text-decoration:none;font-weight:600;}
.login-forgot{font-size:.78rem;text-align:right;margin-top:.15rem;margin-bottom:.25rem;}
.login-forgot a{color:var(--tc);text-decoration:none;font-weight:500;opacity:.85;transition:opacity .2s;}
.login-forgot a:hover{opacity:1;text-decoration:underline;}
.pwd-strength-meter{display:flex;align-items:center;gap:.5rem;}
.pwd-strength-bar{flex:1;height:5px;border-radius:3px;background:var(--border);overflow:hidden;}
.pwd-strength-fill{height:100%;border-radius:3px;transition:width .3s,background .3s;}
.pwd-strength-label{font-size:.72rem;font-weight:600;min-width:50px;text-align:right;}
.login-note{font-size:.72rem;color:var(--mid);margin-top:1rem;}
.login-shake{animation:shake .35s ease;}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
/* Users page */
.users-section{max-width:600px;}
.users-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem;}
.user-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--border);border-radius:12px;padding:.75rem 1rem;gap:.75rem;flex-wrap:wrap;}
.user-info{display:flex;align-items:center;gap:.6rem;}
.user-name{font-weight:600;font-size:.9rem;}
.user-role-badge{font-size:.7rem;padding:.2rem .55rem;border-radius:12px;font-weight:700;text-transform:uppercase;}
.user-role-badge.admin{background:#E8F5E4;color:var(--green);}
.user-role-badge.member{background:var(--warm);color:var(--mid);}
.user-actions{display:flex;align-items:center;gap:.5rem;}
.user-role-select{padding:.35rem .5rem;border:1.5px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;font-size:.8rem;}
.users-invite{background:var(--warm);border-radius:12px;padding:1rem 1.25rem;margin-top:1.5rem;}
/* Locked elements */
.locked{position:relative;}
.btn-green{background:var(--green);color:#fff;border:none;}



.shopping-conflict-banner{background:#FEF3CD;border:1.5px solid #f0c040;border-radius:10px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.8rem;color:#856404;line-height:1.5;}
/* Store bar */
.store-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#fff;border:1px solid var(--border);border-radius:12px;}
.store-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .7rem;border:1.5px solid;border-radius:20px;background:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;}
.store-pill:hover{opacity:.8;}
.store-pill-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;color:#fff;font-size:.65rem;font-weight:700;padding:0 4px;}
.store-pill-unassigned{font-size:.75rem;color:var(--mid);align-self:center;padding:.3rem .5rem;}
/* Item store row */
.item-main{flex:1;min-width:0;}
.item-store-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;padding:.4rem .75rem;background:var(--cream);border-top:1px solid var(--border);}
.store-badge{font-size:.65rem;font-weight:700;padding:.15rem .45rem;border-radius:10px;white-space:nowrap;}
.item-store-select{font-size:.72rem;padding:.15rem .35rem;border:1px solid var(--border);border-radius:6px;font-family:'Inter',sans-serif;background:#fff;color:var(--dark);cursor:pointer;max-width:130px;min-width:90px;appearance:auto;-webkit-appearance:auto;}
.item-purchase-unit-select{font-size:.70rem;padding:.15rem .25rem;border:1px solid var(--border);border-radius:6px;font-family:'Inter',sans-serif;background:#f0f4ff;color:var(--dark);cursor:pointer;max-width:80px;margin-left:.25rem;appearance:auto;-webkit-appearance:auto;}
/* Mercadona product picker */
.merca-pick-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;margin-bottom:.5rem;}
.merca-pick-item:hover{border-color:var(--tc);background:var(--warm);}
.merca-pick-thumb{width:44px;height:44px;object-fit:contain;border-radius:6px;flex-shrink:0;background:#f5f5f5;}
.merca-pick-thumb-ph{width:44px;height:44px;border-radius:6px;flex-shrink:0;background:var(--warm);display:flex;align-items:center;justify-content:center;font-size:1.4rem;}
.merca-pick-info{flex:1;min-width:0;}
.merca-pick-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.merca-pick-sub{font-size:.72rem;color:var(--mid);margin-top:.1rem;}
.merca-pick-price{font-size:.95rem;font-weight:700;color:var(--green);flex-shrink:0;}
/* Supermarket modal */
.sm-row{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border);}
.sm-row:last-child{border-bottom:none;}
.sm-color-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
.sm-name-input{flex:1;border:1px solid var(--border);border-radius:6px;padding:.35rem .6rem;font-family:'Inter',sans-serif;font-size:.88rem;}
.sm-remove-btn{background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6;transition:opacity .15s;}
.sm-remove-btn:hover{opacity:1;}
/* Subscription status card */
.sub-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:14px;margin-bottom:1.5rem;flex-wrap:wrap;}
.sub-card-icon{font-size:1.75rem;flex-shrink:0;}
.sub-card-body{flex:1;min-width:0;}
.sub-card-title{font-weight:700;font-size:.95rem;color:var(--dark);margin-bottom:.2rem;}
.sub-card-sub{font-size:.8rem;color:var(--mid);line-height:1.4;}
.sub-active{background:#E8F5E4;border:1.5px solid #b7ddb0;}
.sub-trial{background:#FEF9E7;border:1.5px solid #f0d060;}
.sub-expired{background:#FEE7E7;border:1.5px solid #f5a5a5;}
.sub-admin{background:#F0EDF8;border:1.5px solid #C4B5FD;}
.sub-manage-btn{font-size:.82rem;font-weight:600;color:#4A6741;text-decoration:none;white-space:nowrap;padding:.4rem .85rem;background:#fff;border:1.5px solid #b7ddb0;border-radius:8px;transition:all .15s;}
.sub-manage-btn:hover{background:#E8F5E4;}
.sub-upgrade-btns{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.25rem;}
.sub-btn-monthly,.sub-btn-annual{padding:.5rem .9rem;border:none;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.35rem;transition:all .15s;}
.sub-btn-monthly{background:#A85228;color:#fff;}
.sub-btn-monthly:hover{background:#b05828;}
.sub-btn-annual{background:#1E1C18;color:#fff;position:relative;}
.sub-btn-annual:hover{background:#333;}
.sub-btn-monthly span,.sub-btn-annual span{opacity:.85;font-weight:400;}
.sub-btn-annual em{background:#A85228;color:#fff;font-style:normal;font-size:.6rem;font-weight:800;padding:.1rem .35rem;border-radius:10px;}
.shopping-item.conflict{border-left:3px solid #f0c040;background:#fffdf0;}
.conflict-badge{font-size:.65rem;background:#FEF3CD;color:#856404;padding:.1rem .35rem;border-radius:8px;margin-left:.3rem;font-weight:600;vertical-align:middle;}
.item-photo-thumb{width:64px;height:64px;object-fit:contain;border-radius:8px;flex-shrink:0;background:#f5f5f5;border:1px solid var(--border);}
.item-photo-placeholder{width:64px;height:64px;border-radius:8px;flex-shrink:0;background:var(--warm);border:1px dashed var(--border);display:none;}
.best-price-badge{font-size:.62rem;font-weight:700;padding:.1rem .4rem;border-radius:8px;background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;white-space:nowrap;}
.cheaper-hint{font-size:.62rem;font-weight:600;padding:.1rem .4rem;border-radius:8px;background:#fff8e1;color:#e65100;border:1px solid #ffe082;white-space:nowrap;cursor:pointer;}
.cheaper-hint:hover{background:#fff3cd;}
.pantry-check-section{margin-top:1.25rem;border:1.5px solid var(--border);border-radius:12px;overflow:hidden;}
.pantry-toggle{width:100%;display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;background:var(--warm);border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;color:var(--mid);text-align:left;}
.pantry-toggle:hover{background:#ede8df;}
.pantry-toggle-icon{font-size:1.1rem;flex-shrink:0;}
.pantry-toggle-label{flex:1;}
.pantry-chevron{font-size:.75rem;transition:transform .2s;flex-shrink:0;}
.pantry-check-section.open .pantry-chevron{transform:rotate(90deg);}
.pantry-body{display:none;padding:.75rem 1rem 1rem;background:#fff;}
.pantry-check-section.open .pantry-body{display:block;}
.pantry-hint{font-size:.75rem;color:var(--mid);margin:0 0 .75rem;line-height:1.5;}
.pantry-items{display:flex;flex-wrap:wrap;gap:.4rem;}
.pantry-item{display:flex;align-items:center;gap:.3rem;background:var(--warm);border-radius:20px;padding:.3rem .75rem;font-size:.8rem;color:var(--mid);}
.pantry-dot{color:var(--mid);font-size:1rem;display:none;}
.pantry-name{font-weight:500;}
.nutrdb-toolbar{display:flex;gap:.6rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap;}
.nutrdb-search-input{flex:1;min-width:160px;padding:.5rem .75rem;border:1.5px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;font-size:.83rem;background:#fff;}
.nutrdb-filter{padding:.5rem .6rem;border:1.5px solid var(--border);border-radius:8px;font-family:'Inter',sans-serif;font-size:.83rem;background:#fff;cursor:pointer;}
.nutrdb-grid-header{display:grid;grid-template-columns:1fr 80px 55px 55px 55px 55px 72px;gap:.4rem;padding:.4rem .75rem;font-size:.7rem;font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);margin-bottom:.3rem;}
.nutrdb-row{display:grid;grid-template-columns:1fr 80px 55px 55px 55px 55px 72px;gap:.4rem;align-items:center;padding:.55rem .75rem;background:#fff;border-radius:8px;margin-bottom:.3rem;border:1px solid var(--border);transition:box-shadow .15s;}
.nutrdb-row:hover{box-shadow:var(--sh);}
.nutrdb-row-name{font-size:.82rem;font-weight:600;color:var(--dark);}
.nutrdb-row-aliases{font-size:.68rem;color:var(--mid);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nutrdb-row-val{font-size:.8rem;color:var(--mid);text-align:center;}
.nutrdb-row-cat{font-size:.68rem;padding:.15rem .45rem;border-radius:10px;background:var(--warm);color:var(--mid);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nutrdb-row-actions{display:flex;gap:.3rem;justify-content:flex-end;}
.nutrdb-row-actions button{padding:.25rem .5rem;border-radius:6px;border:1.5px solid var(--border);background:#fff;cursor:pointer;font-size:.72rem;transition:all .15s;}
.nutrdb-row-actions .edit-btn:hover{border-color:var(--tc);color:var(--tc);}
.nutrdb-row-actions .del-btn:hover{border-color:#dc3545;color:#dc3545;background:#fff0f0;}
.nutrdb-empty{text-align:center;padding:2rem;color:var(--mid);font-size:.85rem;}
.nutrdb-count{font-size:.75rem;color:var(--mid);margin-bottom:.6rem;}
.nutrdb-custom-badge{font-size:.62rem;background:#E8F5E4;color:var(--green);padding:.1rem .35rem;border-radius:8px;margin-left:.3rem;font-weight:600;}
.catalog-list-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .65rem;background:#fff;border-radius:8px;margin-bottom:.3rem;border:1px solid var(--border);}
.catalog-list-row:hover{box-shadow:var(--sh);}
.catalog-list-name{font-size:.82rem;font-weight:600;flex:1;min-width:0;}
.catalog-list-meta{font-size:.68rem;color:var(--mid);white-space:nowrap;}
.catalog-list-custom{font-size:.62rem;background:#E8F5E4;color:var(--green);padding:.1rem .35rem;border-radius:8px;font-weight:600;flex-shrink:0;}
.catalog-unit-row{display:flex;gap:.4rem;align-items:center;margin-bottom:.35rem;}
.catalog-unit-row input{flex:1;padding:.35rem .5rem;border:1.5px solid var(--border);border-radius:7px;font-family:'Inter',sans-serif;font-size:.82rem;}
.catalog-unit-row .remove-unit-btn{padding:.25rem .5rem;border-radius:6px;border:1.5px solid var(--border);background:#fff;cursor:pointer;font-size:.78rem;color:#dc3545;}
.catalog-unit-row .remove-unit-btn:hover{background:#fff0f0;border-color:#dc3545;}
@media(max-width:600px){
  .nutrdb-grid-header,.nutrdb-row{grid-template-columns:1fr auto auto auto;}
  .nutrdb-col-carbs,.nutrdb-col-fat{display:none;}
  .nutrdb-row>div:first-child{min-width:0;overflow:hidden;}
}

/* ── MENU PREFERENCES ── */
.prefs-panel{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.25rem;margin-bottom:1.1rem;}
.prefs-panel h3{font-family:'Outfit',sans-serif;font-size:.95rem;margin-bottom:.85rem;display:flex;align-items:center;gap:.5rem;}
.prefs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.65rem;}
.pref-item{display:flex;flex-direction:column;align-items:center;gap:.3rem;}
.pref-emoji{font-size:1.4rem;line-height:1;}
.pref-label{font-size:.7rem;font-weight:600;color:var(--mid);text-align:center;}
.pref-controls{display:flex;align-items:center;gap:.3rem;}
.pref-controls button{width:24px;height:24px;border-radius:50%;border:none;background:#F3F4F6;cursor:pointer;font-size:.9rem;line-height:1;display:flex;align-items:center;justify-content:center;color:var(--dark);transition:all .2s;flex-shrink:0;}
.pref-controls button:hover{background:#E5E7EB;color:var(--tc);}
.pref-controls span{min-width:20px;text-align:center;font-weight:700;font-size:.9rem;color:var(--dark);}
.pref-total{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem;padding-top:.65rem;border-top:1px solid var(--border);font-size:.78rem;}
.pref-total-count{font-weight:700;color:var(--tc);}
.pref-total-count.ok{color:var(--green);}
.pref-total-count.over{color:#dc3545;}
.generate-result{margin-top:.6rem;padding:.5rem .8rem;border-radius:8px;font-size:.78rem;display:none;}
.generate-result.ok{background:#E8F5E4;color:var(--green);display:block;}
.generate-result.warn{background:#FEF3CD;color:#856404;display:block;}
.generate-result.err{background:#FEE7E7;color:#c0392b;display:block;}
@media(max-width:480px){.prefs-grid{grid-template-columns:repeat(3,1fr);}
  .prefs-panel.collapsed .prefs-grid,
  .prefs-panel.collapsed .pref-total,
  .prefs-panel.collapsed .generate-result{display:none;}
  .prefs-panel h3{cursor:pointer;}
  .prefs-panel h3 .toggle-arrow{margin-left:auto;font-size:.7rem;color:var(--mid);transition:transform .2s;}
  .prefs-panel.collapsed h3 .toggle-arrow{transform:rotate(-90deg);}
}
.import-status{padding:.7rem;border-radius:8px;font-size:.83rem;margin-top:.65rem;}
.import-status.success{background:#E8F5E4;color:var(--green);}.import-status.error{background:#FEE7E7;color:#c0392b;}

/* ── LIGHTBOX ── */
.lightbox{display:none;position:fixed;inset:0;background:rgba(10,10,10,.92);z-index:500;align-items:center;justify-content:center;padding:1rem;}
.lightbox.open{display:flex;}
.lightbox img{max-width:90vw;max-height:88vh;border-radius:10px;object-fit:contain;}
.lightbox-close{position:absolute;top:.75rem;right:1rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;}

/* ── CAMERA ── */
.camera-overlay{display:none;position:fixed;inset:0;background:rgba(10,10,10,.9);z-index:400;align-items:center;justify-content:center;flex-direction:column;gap:1rem;}
.camera-overlay.open{display:flex;}
.camera-overlay video{max-width:90vw;max-height:65vh;border-radius:12px;border:2px solid var(--tc);}
.camera-controls{display:flex;gap:1rem;align-items:center;}
.shutter-btn{width:60px;height:60px;border-radius:50%;background:#fff;border:4px solid var(--tc);cursor:pointer;}
.camera-cancel{background:rgba(255,255,255,.15);border:none;color:#fff;padding:.55rem 1.1rem;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;}

/* ── FAMILY PROFILE MODAL ── */
.profile-member-card{background:var(--warm);border-radius:10px;padding:1rem;margin-bottom:.75rem;}
.profile-member-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;}
.profile-member-card h4{font-family:'Outfit',sans-serif;font-size:.95rem;color:var(--dark);margin:0;}
.profile-result{background:#E8F5E4;border-radius:8px;padding:.65rem .9rem;margin-top:.5rem;font-size:.8rem;color:var(--green);}
.profile-remove-btn{font-size:.75rem;background:none;border:1.5px solid #f5c0c0;color:#c0392b;border-radius:8px;padding:.25rem .6rem;cursor:pointer;}
.profile-remove-btn:hover{background:#fff0f0;}
.profile-add-btn{width:100%;padding:.75rem;border:2px dashed var(--border);border-radius:10px;background:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:.85rem;color:var(--mid);margin-top:.25rem;transition:all .2s;}
.profile-add-btn:hover{border-color:var(--tc);color:var(--tc);background:var(--warm);}

/* ── RESPONSIVE ── */
/* ── TABLET (≤768px) ── */
@media(max-width:768px){
  .desk-nav{display:none;}
  .bottom-nav{display:block;}
  .dash-grid{grid-template-columns:repeat(2,1fr);}
  .family-members{grid-template-columns:repeat(2,1fr);}
  .dash-row{grid-template-columns:1fr;}
  .planner-grid{
    display:flex;
    overflow-x:auto;
    max-width:100%;
    padding-bottom:1rem;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    scroll-padding:0 .75rem;
    gap:.75rem;
  }
  .planner-day{
    min-width: calc(100vw - 3rem);
    flex-shrink: 0;
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }
  main{padding:1rem .75rem 5.5rem;}
  .page-header h1{font-size:1.5rem;}
  .recipes-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));}
  .form-grid-2{grid-template-columns:1fr;}
  .form-grid-4{grid-template-columns:1fr 1fr;}
  .modal{border-radius:16px 16px 0 0;max-height:90vh;}
  .modal-overlay{align-items:flex-end;}
  .macros-overview{grid-template-columns:repeat(2,1fr);}
  .shopping-items{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));}
  .modal-footer{gap:.5rem;}
  .modal-footer .btn{flex:1;justify-content:center;}
  .week-nav{gap:.5rem;}
  .week-nav h2{font-size:1rem;}
}

/* ── PHONE (≤480px) ── */
@media(max-width:480px){
  .recipes-grid{justify-items:center;}
  .dash-grid{grid-template-columns:repeat(2,1fr);}
  .family-members{grid-template-columns:1fr 1fr;}
  .recipes-grid{grid-template-columns:1fr;}
  .recipe-macros{grid-template-columns:repeat(4,1fr);}
  .shopping-items{grid-template-columns:1fr;}
  .nutr-name{width:85px;font-size:.72rem;}
  .nutr-val{width:60px;font-size:.7rem;}
  .macros-overview{grid-template-columns:repeat(2,1fr);}
  .form-grid-4{grid-template-columns:1fr 1fr;}
  /* Ingredient rows: stack qty+unit tighter */
  .ingredient-row input.qty{max-width:60px;}
  .ingredient-row input.unit,.ingredient-row select.unit{max-width:80px;}
  .recipes-toolbar{gap:.4rem;}
  .recipes-toolbar input{width:100%;max-width:100%;}
  .recipes-toolbar select{flex:1;}
  .ai-bar{flex-direction:column;align-items:stretch;}
  .ai-bar .btn{width:100%;justify-content:center;}
  .week-nav h2{font-size:.9rem;min-width:120px;}
  .page-header h1{font-size:1.35rem;}
  .shopping-header{flex-wrap:wrap;}
  .shopping-header .btn{flex:1;}
  /* Recipe view macros 2x2 on small phone */
  .macros-overview{gap:.4rem;}
  .macro-box .val{font-size:1.1rem;}
  /* Profile modal: full single column */
  .profile-member-card .form-grid-2{grid-template-columns:1fr;}
}

/* ── DESKTOP (≥769px) ── */
@media(min-width:769px){
  .modal-overlay{align-items:center;}
  .modal{border-radius:16px;max-height:90vh;}
  main{padding:1.5rem 1.5rem 2rem;}
}
