*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--primary:#3a7d5c;--primary-light:#6db88a;--bg:#f8f8f4;--text:#222;--muted:#777;--card:#fff;--footer:#222;--radius:8px;--shadow:0 2px 8px rgba(0,0,0,.07);--shadow-hover:0 6px 20px rgba(0,0,0,.12)}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;color:var(--text);background:var(--bg);line-height:1.6;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary-light)}
.container{max-width:1140px;margin:0 auto;padding:0 20px}

/* HEADER */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #eee;padding:0 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:700;color:var(--primary);text-decoration:none}
.logo svg{width:28px;height:28px}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{color:var(--text);font-size:15px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--primary)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px}
.menu-toggle svg{width:28px;height:28px;stroke:var(--text)}

/* HERO */
.hero{position:relative;height:480px;overflow:hidden;margin-bottom:48px}
.hero img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.6) 0%,rgba(0,0,0,.1) 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:40px}
.hero-overlay .tag{display:inline-block;background:var(--primary);color:#fff;padding:4px 14px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:12px;width:fit-content}
.hero-overlay h1{color:#fff;font-size:36px;line-height:1.25;max-width:640px;margin-bottom:10px}
.hero-overlay p{color:rgba(255,255,255,.85);font-size:16px;max-width:540px}

/* SECTIONS */
.section{padding:48px 0}
.section-title{font-size:26px;font-weight:700;margin-bottom:28px;color:var(--text)}
.section-title span{color:var(--primary)}

/* CARDS */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.card-img{width:100%;height:200px;object-fit:cover}
.card-body{padding:18px 20px 22px}
.card-tag{font-size:12px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.card-body h3{font-size:18px;line-height:1.35;margin-bottom:8px}
.card-body h3 a{color:var(--text)}
.card-body h3 a:hover{color:var(--primary)}
.card-body p{color:var(--muted);font-size:14px;line-height:1.55}
.card-meta{padding:0 20px 16px;font-size:13px;color:var(--muted)}

/* TWO-COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.two-col .card-img{height:240px}

/* BANNER */
.banner-section{background:var(--primary);color:#fff;padding:56px 0;text-align:center}
.banner-section blockquote{font-size:22px;line-height:1.5;max-width:700px;margin:0 auto 16px;font-style:italic}
.banner-section cite{font-size:15px;opacity:.8;font-style:normal}

/* RECIPE CARDS */
.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.recipe-card{display:flex;gap:14px;background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.recipe-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.recipe-card img{width:90px;height:90px;border-radius:6px;object-fit:cover;flex-shrink:0}
.recipe-card h4{font-size:15px;margin-bottom:4px;line-height:1.35}
.recipe-card h4 a{color:var(--text)}
.recipe-card h4 a:hover{color:var(--primary)}
.recipe-card p{font-size:13px;color:var(--muted);line-height:1.45}

/* NEWSLETTER */
.newsletter-section{background:#eef6f0;padding:52px 0;text-align:center}
.newsletter-section h2{font-size:24px;margin-bottom:8px}
.newsletter-section p{color:var(--muted);margin-bottom:20px;font-size:15px}
.newsletter-form{display:flex;gap:10px;max-width:440px;margin:0 auto}
.newsletter-form input{flex:1;padding:12px 16px;border:1px solid #ccc;border-radius:6px;font-size:15px;outline:none;transition:border .2s}
.newsletter-form input:focus{border-color:var(--primary)}
.newsletter-form button{padding:12px 24px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}
.newsletter-form button:hover{background:var(--primary-light)}

/* ABOUT PREVIEW */
.about-preview{display:flex;gap:32px;align-items:center}
.about-preview img{width:320px;height:220px;object-fit:cover;border-radius:var(--radius);flex-shrink:0}
.about-preview-text h2{font-size:24px;margin-bottom:12px}
.about-preview-text p{color:var(--muted);font-size:15px;line-height:1.65;margin-bottom:16px}
.btn-link{display:inline-block;color:var(--primary);font-weight:600;font-size:15px;border-bottom:2px solid var(--primary);padding-bottom:2px;transition:color .2s,border-color .2s}
.btn-link:hover{color:var(--primary-light);border-color:var(--primary-light)}

/* FOOTER */
.site-footer{background:var(--footer);color:#aaa;padding:48px 0 24px;font-size:14px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:32px}
.footer-grid h4{color:#fff;font-size:16px;margin-bottom:14px;font-weight:600}
.footer-grid ul{list-style:none}
.footer-grid li{margin-bottom:8px}
.footer-grid a{color:#aaa;transition:color .2s}
.footer-grid a:hover{color:#fff}
.footer-bottom{border-top:1px solid #333;padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-bottom p{margin:0}
#manage-cookies{color:#aaa;cursor:pointer;transition:color .2s}
#manage-cookies:hover{color:#fff}

/* ARTICLE PAGE */
.article-page{max-width:680px;margin:0 auto;padding:40px 20px 60px}
.article-page .breadcrumb{font-size:13px;color:var(--muted);margin-bottom:20px}
.article-page .breadcrumb a{color:var(--muted)}
.article-page .breadcrumb a:hover{color:var(--primary)}
.article-page h1{font-size:32px;line-height:1.3;margin-bottom:12px}
.article-page .article-meta{font-size:14px;color:var(--muted);margin-bottom:24px}
.article-page .featured-img{width:100%;height:380px;object-fit:cover;border-radius:var(--radius);margin-bottom:28px}
.article-page .content{line-height:1.8;font-size:17px}
.article-page .content h2{font-size:22px;margin:32px 0 14px;color:var(--text)}
.article-page .content h3{font-size:19px;margin:24px 0 10px}
.article-page .content p{margin-bottom:18px}
.article-page .content img{border-radius:var(--radius);margin:20px 0}

/* INFO PAGES */
.info-page{max-width:740px;margin:0 auto;padding:40px 20px 60px}
.info-page h1{font-size:30px;margin-bottom:20px}
.info-page h2{font-size:22px;margin:28px 0 12px}
.info-page p{margin-bottom:16px;line-height:1.7}
.info-page ul,.info-page ol{margin:0 0 16px 24px;line-height:1.7}
.info-page a{text-decoration:underline}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:28px}
.contact-info p{margin-bottom:12px;line-height:1.7}
.contact-form label{display:block;font-size:14px;font-weight:500;margin-bottom:4px;margin-top:14px}
.contact-form input,.contact-form textarea{width:100%;padding:10px 14px;border:1px solid #ccc;border-radius:6px;font-size:15px;font-family:inherit;outline:none;transition:border .2s}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--primary)}
.contact-form textarea{height:120px;resize:vertical}
.contact-form button{margin-top:18px;padding:12px 28px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}
.contact-form button:hover{background:var(--primary-light)}

/* COOKIE BANNER */
#cookie-consent{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center}
.cookie-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45)}
.cookie-box{position:relative;background:#fff;border-radius:12px;padding:32px;max-width:480px;width:90%;box-shadow:0 12px 40px rgba(0,0,0,.2);z-index:1}
.cookie-box h3{font-size:20px;margin-bottom:10px}
.cookie-box>p{font-size:14px;color:var(--muted);line-height:1.55;margin-bottom:20px}
.cookie-toggles{margin-bottom:22px}
.cookie-toggle{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #eee}
.cookie-toggle:last-child{border-bottom:none}
.cookie-toggle span{flex:1;font-size:14px;font-weight:500}
.cookie-toggle small{font-size:12px;color:var(--muted);width:90px;text-align:right}
.toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;inset:0;background:#ccc;border-radius:24px;transition:.3s}
.slider::before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}
input:checked+.slider{background:var(--primary)}
input:checked+.slider::before{transform:translateX(20px)}
.toggle.disabled .slider{background:var(--primary);opacity:.6;cursor:default}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}
.btn-outline{padding:10px 18px;border:1px solid #ccc;background:none;border-radius:6px;font-size:14px;cursor:pointer;transition:border-color .2s,color .2s}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-primary{padding:10px 18px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}
.btn-primary:hover{background:var(--primary-light)}

/* RESPONSIVE */
@media(max-width:900px){
  .cards-grid,.recipe-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .about-preview{flex-direction:column}
  .about-preview img{width:100%;height:200px}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .cards-grid,.two-col,.recipe-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{height:360px}
  .hero-overlay h1{font-size:26px}
  .nav-links{display:none;position:absolute;top:64px;left:0;right:0;background:#fff;flex-direction:column;padding:20px;gap:16px;box-shadow:0 4px 12px rgba(0,0,0,.1);border-top:1px solid #eee}
  .nav-links.open{display:flex}
  .menu-toggle{display:block}
  .newsletter-form{flex-direction:column}
  .footer-bottom{flex-direction:column;text-align:center}
}
