/* Toffee Kitchen - style.css (ASCII only). Warm toffee + caramel design system. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Albert+Sans:wght@400;500;600;700&display=swap');

:root{
  --primary:#7A3E1D; --primary-dark:#5A2E15; --primary-soft:#9C5A30;
  --accent:#E0A458; --accent-light:#F2C98A; --accent-dark:#C9853A;
  --cream:#FBF3E7; --cream-2:#F4E7D3; --paper:#FFFCF6;
  --ink:#2C2017; --ink-soft:#5C4A3A; --line:#E8D8C0;
  --tomato:#D7553B; --leaf:#5C7A43; --gold:#E0A458;
  --shadow-sm:0 2px 10px rgba(90,46,21,.08);
  --shadow:0 12px 36px rgba(90,46,21,.14);
  --shadow-lg:0 26px 60px rgba(90,46,21,.20);
  --radius:18px; --radius-lg:26px; --maxw:1200px;
  --sans:'Albert Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100vw}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--primary-dark);letter-spacing:-.01em}
.serif{font-family:var(--serif)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:840px;margin:0 auto;padding:0 24px}
section{position:relative}
.muted{color:var(--ink-soft)}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;font-weight:700;color:var(--accent-dark)}

/* ---------- TOP STRIP ---------- */
.top-strip{background:var(--primary-dark);color:var(--accent-light);font-size:.8rem;letter-spacing:.04em;text-align:center;padding:7px 12px}
.top-strip .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);margin:0 12px;vertical-align:middle}

/* ---------- HEADER / NAV ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(251,243,231,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s,background .3s}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(251,243,231,.95)}
.nav-wrap{max-width:var(--maxw);margin:0 auto;padding:12px 24px;display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{display:inline-flex;filter:drop-shadow(0 4px 8px rgba(90,46,21,.18))}
.brand-wordmark{display:flex;flex-direction:column;line-height:1}
.brand-text{font-family:var(--serif);font-weight:700;font-size:1.34rem;color:var(--primary-dark)}
.brand-sub{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-dark);margin-top:3px}
.primary-nav{display:flex;gap:6px;margin-left:auto;align-items:center}
.primary-nav a{font-weight:600;font-size:.95rem;color:var(--ink);padding:9px 14px;border-radius:999px;transition:background .2s,color .2s}
.primary-nav a:hover{background:var(--cream-2);color:var(--primary-dark)}
.nav-actions{display:flex;align-items:center;gap:14px;margin-left:8px}
.nav-link{font-weight:600;font-size:.95rem;color:var(--ink)}
.nav-link:hover{color:var(--primary)}
.cart-link{position:relative;color:var(--primary-dark);display:inline-flex}
.cart-count{position:absolute;top:-9px;right:-11px;background:var(--tomato);color:#fff;font-size:.68rem;font-weight:700;min-width:18px;height:18px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--sans)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2.4px;background:var(--primary-dark);border-radius:2px;transition:.3s}

/* ---------- MOBILE DRAWER ---------- */
.mobile-drawer{position:fixed;top:0;right:-320px;width:300px;max-width:84vw;height:100vh;background:var(--paper);z-index:100;box-shadow:var(--shadow-lg);padding:84px 22px 22px;display:flex;flex-direction:column;gap:4px;transition:right .32s cubic-bezier(.4,0,.2,1)}
.mobile-drawer.open{right:0}
.mobile-drawer a{padding:13px 12px;border-radius:12px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line)}
.mobile-drawer a:hover{background:var(--cream-2)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(44,32,23,.45);z-index:90;opacity:0;pointer-events:none;transition:opacity .3s}
.drawer-backdrop.open{opacity:1;pointer-events:auto}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:700;font-size:.96rem;padding:13px 26px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s,color .2s;text-align:center}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 10px 24px rgba(122,62,29,.28)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-accent{background:var(--accent);color:var(--primary-dark);box-shadow:0 10px 24px rgba(224,164,88,.4)}
.btn-accent:hover{background:var(--accent-dark);color:#fff}
.btn-ghost{background:transparent;color:var(--primary-dark);border-color:var(--primary)}
.btn-ghost:hover{background:var(--primary);color:#fff}
.btn-light{background:#fff;color:var(--primary-dark);border-color:var(--line)}
.btn-light:hover{border-color:var(--primary)}
.btn-block{display:flex;width:100%}
.btn-lg{padding:16px 34px;font-size:1.04rem}
.btn-sm{padding:9px 18px;font-size:.86rem}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#FCEFD9 0%,#F6E3C8 60%,#F0D6B0 100%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:72px 0 80px}
.hero-copy h1{font-size:clamp(2.4rem,5vw,4rem);margin-bottom:18px}
.hero-copy .lead{font-size:1.18rem;color:var(--ink-soft);max-width:540px;margin-bottom:28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;margin-top:34px}
.hero-stats .num{font-family:var(--serif);font-size:1.9rem;font-weight:700;color:var(--primary)}
.hero-stats .lbl{font-size:.82rem;color:var(--ink-soft)}
.hero-art{position:relative}
.hero-art .hero-photo{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);aspect-ratio:4/5;object-fit:cover;width:100%}
.hero-art .float-card{position:absolute;background:var(--paper);border-radius:16px;box-shadow:var(--shadow);padding:14px 18px;display:flex;align-items:center;gap:12px}
.hero-art .float-card.tl{top:24px;left:-26px}
.hero-art .float-card.br{bottom:26px;right:-22px}
.hero-art .float-card .fc-em{font-family:var(--serif);font-size:1.5rem;color:var(--accent-dark)}
.hero-art .float-card .fc-lbl{font-size:.78rem;color:var(--ink-soft);line-height:1.2}
.hero-art .float-card strong{display:block;color:var(--primary-dark);font-size:.95rem}

/* page hero (banner) */
.page-hero{position:relative;color:#fff;padding:96px 0;background-size:cover;background-position:center}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,24,12,.42),rgba(44,24,12,.74))}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4.4vw,3.3rem);margin-bottom:12px}
.page-hero p{color:#FCEEDA;max-width:620px;font-size:1.1rem}
.page-hero .eyebrow{color:var(--accent-light)}
.crumbs{font-size:.84rem;color:#F1DDC2;margin-bottom:14px}
.crumbs a{color:#FCEEDA}

/* ---------- SECTION TITLES ---------- */
.section{padding:78px 0}
.section.tight{padding:54px 0}
.section-head{margin-bottom:40px;max-width:680px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin:10px 0 12px}
.section-head p{color:var(--ink-soft);font-size:1.06rem}
.bg-cream2{background:var(--cream-2)}
.bg-paper{background:var(--paper)}
.bg-primary{background:var(--primary-dark);color:var(--cream)}
.bg-primary h2,.bg-primary h3{color:#fff}
.bg-primary p{color:#F1DDC2}

/* ---------- CARDS / GRIDS ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card-grid.cols-2{grid-template-columns:repeat(2,1fr)}

.recipe-card{background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .25s;display:flex;flex-direction:column;border:1px solid var(--line)}
.recipe-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rc-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.rc-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.recipe-card:hover .rc-media img{transform:scale(1.06)}
.rc-cat{position:absolute;top:12px;left:12px;background:rgba(251,243,231,.92);color:var(--primary-dark);font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;letter-spacing:.02em}
.rc-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.rc-body h3{font-size:1.18rem;margin-bottom:7px}
.rc-desc{font-size:.92rem;color:var(--ink-soft);flex:1;margin-bottom:14px}
.rc-meta{display:flex;gap:14px;font-size:.82rem;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:13px;align-items:center}
.rc-meta .star{color:var(--accent-dark);font-weight:700}
.rc-meta .sep{margin-left:auto}

/* premium padlock badge */
.lock-badge{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;background:linear-gradient(140deg,var(--tomato),#B23A22);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(178,58,34,.45);z-index:2}
.lock-badge svg{width:18px;height:18px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:999px;letter-spacing:.02em}
.pill-members{background:#FBE3DB;color:#B23A22}
.pill-free{background:#E5EFD8;color:#4F6B36}

/* product card */
.product-card{background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .2s,box-shadow .25s}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pc-media{aspect-ratio:1/1;overflow:hidden;background:var(--cream-2)}
.pc-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.product-card:hover .pc-media img{transform:scale(1.05)}
.pc-body{padding:16px 16px 18px;display:flex;flex-direction:column;flex:1}
.pc-cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-dark);font-weight:700}
.pc-body h3{font-size:1.06rem;margin:6px 0}
.pc-short{font-size:.86rem;color:var(--ink-soft);flex:1;margin-bottom:12px}
.pc-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pc-price{font-family:var(--serif);font-weight:700;font-size:1.24rem;color:var(--primary-dark)}

/* category tiles */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cat-tile{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/2;display:block;box-shadow:var(--shadow-sm)}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.cat-tile:hover img{transform:scale(1.08)}
.cat-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,24,12,0) 30%,rgba(44,24,12,.82))}
.cat-tile .cat-label{position:absolute;left:16px;bottom:14px;right:16px;z-index:2;color:#fff}
.cat-tile .cat-label h3{color:#fff;font-size:1.2rem;margin-bottom:2px}
.cat-tile .cat-label span{font-size:.8rem;color:#F4DEC2}

/* ---------- PHOTO MOSAIC / STRIP / GALLERY ---------- */
.photo-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,180px);gap:14px}
.photo-mosaic img{width:100%;height:100%;object-fit:cover;border-radius:14px}
.photo-mosaic .m0{grid-row:span 2}
.photo-mosaic .m5{grid-row:span 2}
.photo-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.photo-strip img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px}
.recipe-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.recipe-gallery figure{border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.recipe-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover}

/* ---------- RECIPE DETAIL ---------- */
.rd-hero{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:54px 0}
.rd-hero img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;object-fit:cover}
.rd-hero h1{font-size:clamp(2rem,4vw,3rem);margin:12px 0 14px}
.meta-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0}
.meta-tile{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px;text-align:center}
.meta-tile .mt-num{font-family:var(--serif);font-weight:700;font-size:1.3rem;color:var(--primary)}
.meta-tile .mt-lbl{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.rd-cols{display:grid;grid-template-columns:1fr 1.4fr;gap:44px;align-items:start}
.ingredient-list{list-style:none}
.ingredient-list li{padding:11px 0;border-bottom:1px dashed var(--line);display:flex;gap:12px;align-items:flex-start}
.ingredient-list li::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--accent);margin-top:8px;flex:none}
.step-list{list-style:none;counter-reset:step}
.step-list li{counter-increment:step;position:relative;padding:0 0 26px 60px;margin-bottom:0}
.step-list li::before{content:counter(step);position:absolute;left:0;top:-4px;width:42px;height:42px;border-radius:50%;background:var(--primary);color:#fff;font-family:var(--serif);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.step-list li:not(:last-child)::after{content:"";position:absolute;left:20px;top:42px;bottom:6px;width:2px;background:var(--line)}
.side-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px}

/* paywall */
.paywall{background:linear-gradient(150deg,var(--primary),var(--primary-dark));color:#fff;border-radius:var(--radius-lg);padding:40px;text-align:center;box-shadow:var(--shadow)}
.paywall .pw-lock{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.paywall h3{color:#fff;font-size:1.7rem;margin-bottom:10px}
.paywall p{color:#F1DDC2;max-width:480px;margin:0 auto 22px}
.paywall .pw-feats{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:540px;margin:0 auto 26px;text-align:left}
.paywall .pw-feats li{display:flex;gap:10px;align-items:flex-start;color:#FCEEDA;font-size:.92rem}
.paywall .pw-feats li svg{flex:none;margin-top:3px}
.paywall .pw-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* free-to-explore banner */
.explore-banner{background:var(--cream-2);border:1px solid var(--line);border-left:5px solid var(--accent);border-radius:14px;padding:18px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:30px}
.explore-banner p{flex:1;min-width:240px;color:var(--ink-soft);font-size:.96rem}
.explore-banner strong{color:var(--primary-dark)}

/* ---------- FORMS ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px;color:var(--ink)}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.6px solid var(--line);border-radius:12px;font-family:var(--sans);font-size:1rem;background:#fff;color:var(--ink);transition:border .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px rgba(224,164,88,.18)}
.field textarea{min-height:130px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.alert{padding:13px 16px;border-radius:12px;font-size:.92rem;margin-bottom:16px}
.alert-error{background:#FBE2DC;color:#9A2C16;border:1px solid #F0B9AC}
.alert-success{background:#E3F0D6;color:#3E5A28;border:1px solid #C2DBA6}
.alert-info{background:var(--cream-2);color:var(--ink-soft);border:1px solid var(--line)}

/* ---------- CART / CHECKOUT ---------- */
.cart-row{display:grid;grid-template-columns:80px 1fr auto auto auto;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.cart-row img{width:80px;height:64px;object-fit:cover;border-radius:10px}
.qty-controls{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:999px;padding:4px 6px}
.qty-btn{width:28px;height:28px;border-radius:50%;border:0;background:var(--cream-2);color:var(--primary-dark);font-weight:700;cursor:pointer;font-size:1rem;line-height:1}
.qty-btn:hover{background:var(--accent);color:#fff}
.summary-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:sticky;top:96px}
.summary-row{display:flex;justify-content:space-between;padding:9px 0;font-size:.96rem;color:var(--ink-soft)}
.summary-row.total{border-top:2px solid var(--line);margin-top:8px;padding-top:16px;font-family:var(--serif);font-size:1.3rem;font-weight:700;color:var(--primary-dark)}

/* ---------- PRICING ---------- */
.plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:760px;margin:0 auto}
.plan{background:var(--paper);border:2px solid var(--line);border-radius:var(--radius-lg);padding:32px;position:relative;display:flex;flex-direction:column}
.plan.featured{border-color:var(--accent);box-shadow:var(--shadow)}
.plan .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--primary-dark);font-size:.72rem;font-weight:700;padding:5px 16px;border-radius:999px;letter-spacing:.04em}
.plan .price{font-family:var(--serif);font-size:3rem;font-weight:700;color:var(--primary-dark);line-height:1}
.plan .price small{font-size:1rem;color:var(--ink-soft);font-family:var(--sans);font-weight:500}
.plan ul{list-style:none;margin:20px 0;flex:1}
.plan ul li{padding:9px 0;display:flex;gap:10px;align-items:flex-start;font-size:.95rem;border-bottom:1px dashed var(--line)}
.plan ul li svg{flex:none;margin-top:3px}

/* ---------- FEATURE / STEPS ROWS ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feature{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.feature .fi{width:52px;height:52px;border-radius:14px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--primary)}
.feature h3{font-size:1.2rem;margin-bottom:8px}
.feature p{font-size:.95rem;color:var(--ink-soft)}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.team-card{text-align:center}
.team-card .ava{width:96px;height:96px;border-radius:50%;background:linear-gradient(140deg,var(--accent-light),var(--accent));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:2.2rem;font-weight:700;color:var(--primary-dark);margin:0 auto 14px;box-shadow:var(--shadow-sm)}
.team-card h3{font-size:1.12rem}
.team-card .role{color:var(--accent-dark);font-weight:600;font-size:.86rem;margin-bottom:8px}
.team-card p{font-size:.9rem;color:var(--ink-soft)}

/* faq / accordion */
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:20px 22px;font-family:var(--serif);font-weight:600;font-size:1.1rem;color:var(--primary-dark);cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq-q .ic{flex:none;transition:transform .3s;color:var(--accent-dark);font-size:1.4rem}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 22px}
.faq-item.open .faq-a{max-height:420px;padding-bottom:20px}
.faq-a p{color:var(--ink-soft);font-size:.96rem}

/* legal / prose */
.prose{max-width:820px}
.prose h2{font-size:1.5rem;margin:32px 0 12px}
.prose h3{font-size:1.18rem;margin:24px 0 8px}
.prose p{margin-bottom:14px;color:var(--ink-soft)}
.prose ul{margin:0 0 16px 22px;color:var(--ink-soft)}
.prose li{margin-bottom:7px}
.prose a{color:var(--primary);text-decoration:underline}
.legal-meta{background:var(--cream-2);border-radius:12px;padding:14px 18px;font-size:.9rem;color:var(--ink-soft);margin-bottom:26px}
.data-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:.92rem}
.data-table th,.data-table td{border:1px solid var(--line);padding:11px 13px;text-align:left;vertical-align:top}
.data-table th{background:var(--cream-2);font-family:var(--sans);color:var(--primary-dark)}

/* sitemap */
.sitemap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.sitemap-grid h3{font-size:1.1rem;margin-bottom:12px;border-bottom:2px solid var(--accent);display:inline-block;padding-bottom:4px}
.sitemap-grid ul{list-style:none}
.sitemap-grid li{padding:6px 0}
.sitemap-grid a{color:var(--ink-soft)}
.sitemap-grid a:hover{color:var(--primary)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{padding:8px 16px;border-radius:999px;border:1.6px solid var(--line);background:var(--paper);font-size:.88rem;font-weight:600;color:var(--ink);transition:.2s}
.chip:hover,.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* account */
.acct-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:30px;align-items:start}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.stat-box{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center}
.stat-box .n{font-family:var(--serif);font-weight:700;font-size:1.7rem;color:var(--primary)}
.stat-box .l{font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em}
.order-row{display:flex;justify-content:space-between;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);font-size:.92rem}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--primary-dark);color:#EAD6BC;padding:64px 0 0}
.footer-grid{max-width:var(--maxw);margin:0 auto;padding:0 24px 44px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.4fr;gap:34px}
.brand-dark .brand-text{color:#fff}
.brand-dark .brand-sub{color:var(--accent-light)}
.footer-tag{margin:16px 0 12px;color:#EAD6BC;font-size:.96rem;max-width:280px}
.footer-copy{font-size:.84rem;color:#C8AE8E;line-height:1.7}
.footer-col h4{color:#fff;font-size:1rem;margin-bottom:14px;font-family:var(--sans);font-weight:700;letter-spacing:.02em}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:9px}
.footer-col a{color:#EAD6BC;font-size:.92rem}
.footer-col a:hover{color:var(--accent-light)}
.footer-col p{font-size:.9rem;color:#C8AE8E;margin-bottom:8px}
.support-link{color:var(--accent-light);font-weight:700}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:20px 24px;max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:#C8AE8E}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a{color:#C8AE8E}
.footer-links a:hover{color:var(--accent-light)}

/* ---------- COOKIE / TOAST ---------- */
.cookie-notice{position:fixed;left:18px;right:18px;bottom:18px;z-index:120;background:var(--primary-dark);color:#F1DDC2;border-radius:16px;box-shadow:var(--shadow-lg);max-width:720px;margin:0 auto}
.cookie-inner{display:flex;align-items:center;gap:18px;padding:16px 20px;flex-wrap:wrap}
.cookie-text{flex:1;min-width:240px;font-size:.88rem}
.cookie-text strong{color:#fff}
.cookie-text a{color:var(--accent-light);text-decoration:underline}
.toast-wrap{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{background:var(--ink);color:#fff;padding:12px 22px;border-radius:999px;font-size:.9rem;font-weight:600;box-shadow:var(--shadow);animation:toastin .3s}
@keyframes toastin{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.site-main{min-height:50vh}
.center{text-align:center}
.mt-1{margin-top:10px}.mt-2{margin-top:20px}.mt-3{margin-top:32px}.mt-4{margin-top:48px}
.mb-2{margin-bottom:20px}.mb-3{margin-bottom:32px}
.flex-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.divider{height:1px;background:var(--line);margin:36px 0;border:0}
.tag-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;font-size:.82rem;color:var(--ink-soft)}
.badge-soft{background:var(--cream-2);color:var(--primary-dark);font-weight:700;font-size:.74rem;padding:5px 12px;border-radius:999px}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-radius:var(--radius-lg);padding:48px;text-align:center;color:var(--primary-dark)}
.cta-band h2{color:var(--primary-dark);margin-bottom:10px}
.cta-band p{color:#5A2E15;max-width:560px;margin:0 auto 24px;font-size:1.06rem}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .primary-nav,.nav-actions .nav-link{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:34px;padding:48px 0 56px}
  .hero-art .float-card.tl{left:10px}.hero-art .float-card.br{right:10px}
  .card-grid,.card-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .feature-grid,.cat-grid,.sitemap-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .rd-cols{grid-template-columns:1fr;gap:32px}
  .acct-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .photo-mosaic{grid-template-rows:repeat(2,150px)}
}
@media(max-width:768px){
  body{font-size:16px}
  .section{padding:54px 0}
  .rd-hero{grid-template-columns:1fr;gap:24px;padding:32px 0}
  .card-grid,.card-grid.cols-4,.card-grid.cols-2,.cat-grid,.feature-grid,.team-grid{grid-template-columns:1fr}
  .plan-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .meta-tiles{grid-template-columns:repeat(2,1fr)}
  .photo-mosaic{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,130px)}
  .photo-strip{grid-template-columns:repeat(4,1fr)}
  .recipe-gallery{grid-template-columns:repeat(2,1fr)}
  .photo-mosaic .m0,.photo-mosaic .m5{grid-row:span 1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-stats{gap:22px}
  .cart-row{grid-template-columns:64px 1fr;grid-template-areas:"img name" "img qty" "price price";row-gap:8px}
  .cart-row img{width:64px}
  .paywall .pw-feats{grid-template-columns:1fr}
  .sitemap-grid{grid-template-columns:1fr}
  .cta-band,.paywall{padding:30px 22px}
}
@media(max-width:480px){
  .container,.narrow{padding:0 16px}
  .card-grid,.card-grid.cols-4,.card-grid.cols-2{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .photo-strip{grid-template-columns:repeat(3,1fr)}
  .recipe-gallery{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-actions .btn,.flex-cta .btn{width:100%}
  .hero-copy h1{font-size:2.1rem}
  .stat-row{grid-template-columns:1fr}
}
