/* =============================================
   LAPLACE LOUISIANA COOKERY
   Green Palette Redesign v3
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100vw}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
[hidden]{display:none!important}

:root{
  --primary:#4C5C2D;
  --primary-light:#5e7237;
  --primary-pale:#eef2e6;
  --accent:#ABD6C2;
  --accent-dark:#7db8a0;
  --moss:#97BC62;
  --moss-dark:#7a9f49;
  --dark:#1c2110;
  --dark2:#2a3118;
  --text:#2d3a1a;
  --text-muted:#6b7a52;
  --bg:#f8faf4;
  --bg2:#f0f5e8;
  --border:#d4dfc6;
  --white:#ffffff;
  --font-heading:'Playfair Display',Georgia,serif;
  --font-body:'Inter',system-ui,sans-serif;
  --radius:14px;
  --radius-sm:8px;
  --radius-lg:20px;
  --shadow:0 4px 24px rgba(44,49,24,.10);
  --shadow-lg:0 12px 48px rgba(44,49,24,.18);
  --shadow-sm:0 2px 8px rgba(44,49,24,.07);
  --t:.22s ease;
  --w:1240px;
}

body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.65;font-size:16px}
h1,h2,h3,h4{font-family:var(--font-heading);color:var(--dark);line-height:1.2}
h1{font-size:clamp(1.9rem,5vw,3.2rem)}
h2{font-size:clamp(1.4rem,3vw,2.2rem)}
h3{font-size:clamp(1rem,2vw,1.3rem)}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}

.container{max-width:var(--w);margin:0 auto;padding:0 1.25rem}
.section{padding:5rem 0}
.section-sm{padding:3rem 0}
.text-center{text-align:center}
.text-muted{color:var(--text-muted)}
.hidden{display:none!important}
.skip-link{position:absolute;top:-100%;left:0;background:var(--primary);color:#fff;padding:.5rem 1rem;z-index:9999}
.skip-link:focus{top:0}

/* -- BUTTONS -- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.72rem 1.6rem;border-radius:50px;font-weight:600;font-size:.9rem;transition:all var(--t);white-space:nowrap;font-family:var(--font-body)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 14px rgba(76,92,45,.3)}
.btn-primary:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 8px 22px rgba(76,92,45,.38)}
.btn-accent{background:var(--moss);color:var(--dark)}
.btn-accent:hover{background:var(--moss-dark);color:#fff;transform:translateY(-2px)}
.btn-outline{border:2px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-outline-white{border:2px solid rgba(255,255,255,.65);color:#fff;background:transparent}
.btn-outline-white:hover{background:#fff;color:var(--primary)}
.btn-dark{background:var(--dark);color:#fff}
.btn-dark:hover{background:var(--dark2);transform:translateY(-2px)}
.btn-celadon{background:var(--accent);color:var(--dark)}
.btn-celadon:hover{background:var(--accent-dark);transform:translateY(-2px)}
.btn-lg{padding:.9rem 2.2rem;font-size:.97rem}
.btn-sm{padding:.4rem 1rem;font-size:.8rem}
.btn-block{width:100%}

/* -- NAV -- */
.nav{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);box-shadow:0 1px 8px rgba(44,49,24,.06)}
.nav-inner{display:flex;align-items:center;height:68px;gap:1rem}
.nav-logo{flex-shrink:0;display:flex;align-items:center;gap:.6rem;min-width:0}
.nav-logo-icon{width:38px;height:38px;flex-shrink:0}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.15;min-width:0;overflow:hidden}
.nav-logo-name{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-logo-sub{font-size:.6rem;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.nav-links{flex:1;display:flex;justify-content:center;gap:1.75rem}
.nav-link{font-weight:500;color:var(--text-muted);padding:.25rem 0;position:relative;font-size:.88rem;transition:color var(--t);white-space:nowrap}
.nav-link::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:2px;background:var(--moss);border-radius:2px;transform:scaleX(0);transition:transform var(--t);transform-origin:center}
.nav-link:hover,.nav-link.active{color:var(--primary)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.nav-actions{flex-shrink:0;display:flex;align-items:center;gap:.6rem}
.cart-btn{position:relative;display:flex;align-items:center;color:var(--text);padding:.35rem;transition:color var(--t)}
.cart-btn:hover{color:var(--primary)}
.cart-count{position:absolute;top:-4px;right:-6px;background:var(--primary);color:#fff;font-size:.6rem;font-weight:700;border-radius:50%;width:17px;height:17px;display:flex;align-items:center;justify-content:center}
/* Hamburger -- hidden by default, shown at breakpoint */
.nav-hamburger{display:none;align-items:center;justify-content:center;padding:6px;color:var(--text);border-radius:var(--radius-sm);transition:background var(--t)}
.nav-hamburger:hover{background:var(--primary-pale)}
/* Mobile dropdown */
.nav-mobile{background:var(--white);border-top:2px solid var(--primary-pale);padding:.5rem 1.25rem 1rem}
.nav-mobile a{display:block;padding:.65rem 0;border-bottom:1px solid var(--border);font-weight:500;color:var(--text);font-size:.95rem;transition:color var(--t)}
.nav-mobile a:hover{color:var(--primary)}
.nav-mobile a:last-child{border-bottom:none;margin-top:.5rem}

/* -- HERO -- */
.hero{position:relative;min-height:580px;display:flex;align-items:center;overflow:hidden;background:var(--dark2)}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;filter:brightness(.6) saturate(1.1)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(115deg,rgba(28,33,16,.84) 0%,rgba(76,92,45,.42) 55%,rgba(28,33,16,.18) 100%)}
.hero-content{position:relative;z-index:2;max-width:660px;color:#fff;padding:4.5rem 1.25rem}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(151,188,98,.18);border:1px solid rgba(151,188,98,.45);color:var(--moss);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .9rem;border-radius:50px;margin-bottom:1.1rem}
.hero-eyebrow-dot{width:6px;height:6px;background:var(--moss);border-radius:50%}
.hero h1{color:#fff;margin-bottom:1rem;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.hero-desc{font-size:1.05rem;opacity:.88;margin-bottom:2rem;max-width:500px;line-height:1.7}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-stats{position:absolute;bottom:2rem;right:1.5rem;z-index:2;display:flex;gap:1rem}
.hero-stat{text-align:center;color:#fff;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);padding:.65rem 1.1rem;border-radius:var(--radius)}
.hero-stat-num{font-size:1.5rem;font-weight:700;font-family:var(--font-heading);line-height:1}
.hero-stat-label{font-size:.65rem;opacity:.72;margin-top:.2rem;letter-spacing:.05em}

/* -- SECTION HEADERS -- */
.section-header{text-align:center;max-width:620px;margin:0 auto 2.75rem}
.section-label{display:inline-flex;align-items:center;gap:.45rem;color:var(--primary);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.55rem}
.section-label::before,.section-label::after{content:'';display:inline-block;width:20px;height:2px;background:var(--moss);border-radius:2px}
.section-header h2{margin-bottom:.7rem}
.section-header p{color:var(--text-muted);font-size:.98rem}

/* -- CARDS -- */
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--t);display:flex;flex-direction:column;border:1px solid var(--border);height:100%}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent-dark)}
.card-img{width:100%;aspect-ratio:16/9;overflow:hidden;flex-shrink:0;background:var(--bg2)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:1.15rem 1.25rem 1.25rem;display:flex;flex-direction:column;flex:1}
.card-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.6rem;min-height:1.6rem}
.badge{display:inline-block;padding:.2rem .65rem;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:.02em;line-height:1.4}
.badge-primary{background:var(--primary-pale);color:var(--primary)}
.badge-accent{background:rgba(171,214,194,.3);color:#2a6650}
.badge-dark{background:var(--dark);color:#fff}
.badge-green{background:rgba(151,188,98,.2);color:#3d6010}
.badge-moss{background:rgba(151,188,98,.15);color:var(--moss-dark)}
.card-title{font-family:var(--font-heading);font-size:1.05rem;margin-bottom:.45rem;color:var(--dark);line-height:1.3;flex-shrink:0}
.card-title a:hover{color:var(--primary)}
.card-desc{font-size:.83rem;color:var(--text-muted);line-height:1.6;margin-bottom:.9rem;flex:1;min-height:2.5rem}
.card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.8rem;border-top:1px solid var(--border);margin-top:auto;flex-shrink:0}
.stars{color:var(--moss);font-size:.8rem;letter-spacing:.05em}
.rating-val{font-weight:700;font-size:.83rem;color:var(--dark)}
.card-time{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:.25rem}

/* -- GRIDS -- */
.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;padding:4rem 0 2rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.checkout-grid{display:grid;grid-template-columns:1fr 360px;gap:2rem}
.auth-wrap{display:grid;grid-template-columns:1fr 460px 1fr}
.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.careers-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}

/* -- CATEGORY TILES -- */
.cat-tile{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;display:block;cursor:pointer;box-shadow:var(--shadow-sm)}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.cat-tile:hover img{transform:scale(1.08)}
.cat-tile-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,33,16,.88) 0%,rgba(44,60,20,.15) 60%,transparent 100%);transition:opacity var(--t)}
.cat-tile:hover .cat-tile-overlay{opacity:.95}
.cat-tile-label{position:absolute;bottom:0;left:0;right:0;padding:.85rem .8rem;color:#fff;font-family:var(--font-heading);font-size:.95rem;font-weight:600;display:flex;align-items:center;justify-content:space-between}
.cat-tile-arrow{width:26px;height:26px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--t)}
.cat-tile:hover .cat-tile-arrow{background:var(--moss)}

/* -- LOCK overlay -- */
.card-relative{position:relative}
.recipe-lock{position:absolute;inset:0;background:rgba(248,250,244,.93);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;text-align:center;padding:1.25rem;z-index:5}
.recipe-lock svg{color:var(--primary)}
.lock-label{font-family:var(--font-heading);font-size:.95rem;color:var(--dark);font-weight:700}
.lock-sub{font-size:.75rem;color:var(--text-muted)}

/* -- FORMS -- */
.form-group{margin-bottom:1.15rem}
.form-label{display:block;font-weight:600;margin-bottom:.38rem;font-size:.86rem;color:var(--dark)}
.form-control{width:100%;padding:.72rem .95rem;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.93rem;color:var(--text);background:var(--white);transition:border-color var(--t),box-shadow var(--t)}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(76,92,45,.1)}
.form-control::placeholder{color:#b8c8a8}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-hint{font-size:.76rem;color:var(--text-muted);margin-top:.28rem}
textarea.form-control{min-height:120px;resize:vertical}
select.form-control{appearance:none;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 fill='%236b7a52' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}

/* -- ALERTS -- */
.alert{padding:.85rem 1.15rem;border-radius:var(--radius-sm);margin-bottom:1.1rem;font-size:.88rem}
.alert-error{background:rgba(180,40,40,.07);border:1px solid rgba(180,40,40,.22);color:#6e1515}
.alert-success{background:rgba(76,92,45,.09);border:1px solid rgba(76,92,45,.28);color:var(--primary)}
.alert-info{background:var(--primary-pale);border:1px solid var(--border);color:var(--dark)}

/* -- PLANS -- */
.plans-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem;max-width:720px;margin:0 auto}
.plan-card{background:var(--white);border-radius:var(--radius-lg);padding:2.25rem 1.75rem;border:2px solid var(--border);text-align:center;transition:all var(--t);position:relative;overflow:hidden}
.plan-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--border);transition:background var(--t)}
.plan-card:hover,.plan-card.featured{border-color:var(--primary);box-shadow:var(--shadow-lg)}
.plan-card:hover::before,.plan-card.featured::before{background:var(--primary)}
.plan-card.featured{transform:scale(1.02)}
.plan-tag{display:inline-block;background:var(--moss);color:var(--dark);font-size:.7rem;font-weight:700;padding:.22rem .8rem;border-radius:50px;margin-bottom:.9rem}
.plan-name{font-size:1.25rem;margin-bottom:.35rem}
.plan-price{font-size:2.8rem;font-weight:700;color:var(--primary);margin:.5rem 0;font-family:var(--font-heading)}
.plan-price span{font-size:.95rem;color:var(--text-muted);font-weight:400}
.plan-features{text-align:left;margin:1.25rem 0}
.plan-features li{padding:.42rem 0;font-size:.86rem;display:flex;align-items:center;gap:.55rem;border-bottom:1px solid var(--border)}
.plan-features li:last-child{border-bottom:none}
.plan-features li::before{content:'';width:15px;height:15px;flex-shrink:0;background:var(--primary-pale) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 15'%3E%3Cpath stroke='%234C5C2D' stroke-width='2' fill='none' stroke-linecap='round' d='M12 4L6 11 3 8'/%3E%3C/svg%3E") no-repeat center;border-radius:50%}

/* -- TESTIMONIALS -- */
.testi-card{background:var(--white);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;transition:all var(--t);height:100%}
.testi-card:hover{box-shadow:var(--shadow);border-color:var(--accent-dark)}
.testi-card::before{content:'\201C';position:absolute;top:.75rem;right:1.25rem;font-size:4.5rem;color:var(--primary-pale);font-family:var(--font-heading);line-height:1;pointer-events:none}
.testi-stars{color:var(--moss);font-size:.82rem;margin-bottom:.65rem}
.testi-quote{font-size:.9rem;color:var(--text);line-height:1.72;margin-bottom:1.35rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:.7rem}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--moss));display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1rem;color:#fff;font-weight:700;flex-shrink:0}
.testi-name{font-weight:700;font-size:.88rem;color:var(--dark)}
.testi-loc{font-size:.75rem;color:var(--text-muted)}

/* -- HOW IT WORKS -- */
.how-step{text-align:center;padding:2rem 1.5rem;background:rgba(255,255,255,.07);border-radius:var(--radius);border:1px solid rgba(255,255,255,.1);transition:all var(--t)}
.how-step:hover{background:rgba(255,255,255,.12);border-color:rgba(151,188,98,.35);transform:translateY(-3px)}
.how-step-icon{width:64px;height:64px;background:rgba(151,188,98,.14);border:2px solid rgba(151,188,98,.28);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.1rem;color:var(--moss)}
.how-step-num{display:inline-block;width:28px;height:28px;background:var(--moss);color:var(--dark);border-radius:50%;font-size:.76rem;font-weight:700;line-height:28px;text-align:center;margin-bottom:.9rem}

/* -- CART -- */
.cart-item{display:flex;gap:1rem;padding:1.15rem 0;border-bottom:1px solid var(--border);align-items:center}
.cart-item:last-child{border-bottom:none}
.cart-item-img{width:76px;height:68px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-weight:600;margin-bottom:.2rem;font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cart-item-price{color:var(--primary);font-weight:700;font-size:.88rem}
.qty-controls{display:flex;align-items:center;gap:.45rem;flex-shrink:0}
.qty-btn{width:30px;height:30px;border:2px solid var(--border);border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t);font-size:.95rem;color:var(--text)}
.qty-btn:hover{border-color:var(--primary);color:var(--primary)}
.qty-val{width:32px;text-align:center;font-weight:700;font-size:.9rem}
.order-summary{background:var(--white);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm);border:1px solid var(--border);position:sticky;top:85px}
.order-summary h3{margin-bottom:1.35rem;padding-bottom:.9rem;border-bottom:1px solid var(--border)}
.summary-row{display:flex;justify-content:space-between;padding:.45rem 0;font-size:.9rem;color:var(--text-muted)}
.summary-total{font-weight:700;font-size:1.05rem;color:var(--dark);border-top:2px solid var(--border);padding-top:.7rem;margin-top:.4rem}

/* -- AUTH -- */
.auth-box{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow);border:1px solid var(--border)}
.auth-box h1{font-size:1.65rem;margin-bottom:.35rem}
.auth-subtitle{color:var(--text-muted);margin-bottom:1.75rem;font-size:.93rem}
.auth-footer{text-align:center;margin-top:1.35rem;font-size:.86rem;color:var(--text-muted)}
.auth-footer a{color:var(--primary);font-weight:600}

/* -- PAGE HERO -- */
.page-hero{background:linear-gradient(135deg,var(--dark2) 0%,var(--primary) 100%);padding:4.5rem 0 3.5rem;color:#fff;text-align:center}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.78);max-width:540px;margin:.9rem auto 0}
.breadcrumb{display:flex;gap:.45rem;font-size:.8rem;color:var(--text-muted);flex-wrap:wrap}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb span{color:var(--border)}

/* -- FILTERS -- */
.filter-bar{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:1.75rem}
.filter-btn{padding:.42rem 1rem;border-radius:50px;border:2px solid var(--border);font-size:.8rem;font-weight:600;transition:all var(--t);cursor:pointer;background:var(--white);color:var(--text-muted)}
.filter-btn.active,.filter-btn:hover{border-color:var(--primary);background:var(--primary);color:#fff}

/* -- PRODUCT DETAIL -- */
.product-detail-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow)}
.product-detail-img img{width:100%;height:100%;object-fit:cover}
.product-price-large{font-size:2.2rem;font-weight:700;color:var(--primary);margin:.9rem 0}
.stock-badge{display:inline-block;padding:.22rem .8rem;border-radius:50px;font-size:.76rem;font-weight:700}
.in-stock{background:rgba(76,92,45,.1);color:var(--primary)}
.out-stock{background:rgba(180,40,40,.1);color:#6e1515}
.product-rating-row{display:flex;align-items:center;gap:.7rem;margin:.65rem 0}

/* -- RECIPE DETAIL -- */
.recipe-detail-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9;margin-bottom:1.75rem}
.recipe-detail-img img{width:100%;height:100%;object-fit:cover}
.recipe-meta-bar{display:flex;gap:1.25rem;flex-wrap:wrap;padding:1.35rem;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin:1.75rem 0;border:1px solid var(--border)}
.meta-item{text-align:center;flex:1;min-width:72px}
.meta-label{font-size:.68rem;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin-bottom:.25rem;letter-spacing:.06em}
.meta-val{font-size:1rem;font-weight:700;color:var(--primary)}

/* -- FAQ -- */
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.15rem 0;font-size:.97rem;font-weight:600;text-align:left;background:none;color:var(--dark);cursor:pointer;transition:color var(--t)}
.faq-q:hover{color:var(--primary)}
.faq-q svg{flex-shrink:0;color:var(--primary);transition:transform var(--t)}
.faq-q[aria-expanded="true"] svg{transform:rotate(180deg)}
.faq-a{padding:0 0 1.15rem;color:var(--text-muted);line-height:1.72;font-size:.92rem}

/* -- LEGAL -- */
.legal-wrap{max-width:800px;margin:0 auto;padding:3rem 1.25rem}
.legal-wrap h2{margin:1.75rem 0 .85rem;font-size:1.2rem;color:var(--primary)}
.legal-wrap h3{margin:1.35rem 0 .65rem;font-size:1rem}
.legal-wrap p,.legal-wrap li{color:var(--text-muted);line-height:1.78;margin-bottom:.65rem}
.legal-wrap ul{padding-left:1.35rem;list-style:disc}
.legal-wrap table{width:100%;border-collapse:collapse;margin:1.35rem 0}
.legal-wrap th,.legal-wrap td{padding:.68rem;border:1px solid var(--border);font-size:.85rem;text-align:left}
.legal-wrap th{background:var(--bg2);font-weight:700}

/* -- CONTACT -- */
.contact-info-item{display:flex;gap:.9rem;margin-bottom:1.5rem}
.contact-info-icon{width:44px;height:44px;background:var(--primary-pale);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.contact-info-text strong{display:block;font-weight:700;margin-bottom:.18rem}
.contact-info-text span{color:var(--text-muted);font-size:.88rem}

/* -- SUCCESS -- */
.success-icon{width:80px;height:80px;background:rgba(76,92,45,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.35rem}
.success-box{text-align:center;max-width:520px;margin:0 auto;padding:3.5rem 2rem;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border)}

/* -- ACCOUNT -- */
.account-header{background:linear-gradient(135deg,var(--dark2) 0%,var(--primary) 100%);color:#fff;padding:2.75rem 0}
.account-sidebar{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.account-sidebar a{display:block;padding:.85rem 1.35rem;border-bottom:1px solid var(--border);font-weight:500;transition:all var(--t);font-size:.88rem}
.account-sidebar a:hover,.account-sidebar a.active{background:var(--primary-pale);color:var(--primary)}
.account-sidebar a:last-child{border-bottom:none}
.account-panel{background:var(--white);border-radius:var(--radius);padding:1.85rem;box-shadow:var(--shadow-sm);border:1px solid var(--border)}

/* -- BLOG -- */
.blog-card .card-img{aspect-ratio:16/9}
.post-body{max-width:700px;margin:2.5rem auto;font-size:1.02rem;line-height:1.82}
.post-body h2{margin:1.85rem 0 .9rem;color:var(--primary)}
.post-body h3{margin:1.35rem 0 .65rem}
.post-body p{margin-bottom:1.35rem;color:var(--text-muted)}

/* -- FOOTER -- */
.footer{background:var(--dark2);color:#fff;margin-top:5rem;position:relative}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--moss),var(--accent))}
.footer-logo{display:flex;align-items:center;gap:.65rem;margin-bottom:.9rem}
.footer-logo-text{display:flex;flex-direction:column;line-height:1.15}
.footer-logo-name{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:#fff}
.footer-logo-sub{font-size:.58rem;color:rgba(255,255,255,.45);letter-spacing:.06em;text-transform:uppercase}
.footer-tagline{color:rgba(255,255,255,.62);font-size:.86rem;margin-bottom:.65rem;line-height:1.62}
.footer-address,.footer-email{font-size:.8rem;color:rgba(255,255,255,.46);margin-bottom:.28rem}
.footer-email a{color:var(--accent)}
.footer-col h4{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:rgba(255,255,255,.4);margin-bottom:1rem}
.footer-col ul li{margin-bottom:.55rem}
.footer-col ul li a{color:rgba(255,255,255,.68);font-size:.85rem;transition:color var(--t)}
.footer-col ul li a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:1.35rem 0;text-align:center}
.footer-bottom p{color:rgba(255,255,255,.38);font-size:.8rem}
.footer-sub{margin-top:.22rem}

/* -- COOKIE NOTICE -- */
.cookie-notice{position:fixed;bottom:1.25rem;left:50%;transform:translateX(-50%);background:var(--dark);color:#fff;padding:1.1rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:1.25rem;z-index:9000;max-width:660px;width:calc(100% - 2.5rem);flex-wrap:wrap;border:1px solid rgba(171,214,194,.18)}
.cookie-notice p{font-size:.86rem;color:rgba(255,255,255,.8);flex:1;margin:0}
.cookie-notice a{color:var(--accent)}
.cookie-actions{display:flex;gap:.65rem;flex-shrink:0}

/* -- TRUST BAR -- */
.trust-bar{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1rem 0}
.trust-items{display:flex;justify-content:center;align-items:center;gap:2.5rem;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:600;color:var(--text-muted)}
.trust-item svg{color:var(--primary);flex-shrink:0}

/* ============================================
   RESPONSIVE BREAKPOINTS
   ============================================ */

/* -- 1200px: Shrink logo text slightly -- */
@media(max-width:1200px){
  .nav-logo-name{font-size:.92rem}
}

/* -- 1024px: Switch to hamburger -- */
@media(max-width:1024px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .checkout-grid{grid-template-columns:1fr}
  .product-detail-grid{grid-template-columns:1fr}
  .recipe-grid{grid-template-columns:repeat(2,1fr)}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .hero-stats{display:none}
  .how-grid{grid-template-columns:repeat(2,1fr)}
}

/* -- 768px: Full mobile -- */
@media(max-width:768px){
  .section{padding:3rem 0}
  .section-sm{padding:2.25rem 0}
  .hero{min-height:460px}
  .hero-content{padding:3rem 1.25rem}
  .hero h1{font-size:clamp(1.5rem,7vw,2.2rem)}
  .hero-desc{font-size:.95rem}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn{width:auto}
  .nav-actions .btn-outline{display:none}
  .nav-logo-name{font-size:.88rem}
  .nav-logo-sub{display:none}
  .how-grid,.testi-grid,.blog-grid,.contact-grid,.careers-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:1.75rem}
  .plans-grid{grid-template-columns:1fr}
  .plan-card.featured{transform:none}
  .form-row{grid-template-columns:1fr}
  .auth-wrap{grid-template-columns:1fr}
  .trust-items{gap:1.25rem}
  .recipe-meta-bar{gap:.9rem}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
}

/* -- 480px: Small phones -- */
@media(max-width:480px){
  .container{padding:0 1rem}
  .recipe-grid,.product-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:stretch}
  .cookie-notice{flex-direction:column;bottom:0;border-radius:var(--radius) var(--radius) 0 0;width:100%;left:0;transform:none}
  .nav-logo-name{font-size:.82rem}
  .hero-eyebrow{font-size:.68rem;padding:.25rem .75rem}
  .trust-items{gap:1rem}
  .testi-grid{grid-template-columns:1fr}
}
