@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Lato:wght@300;400;700&family=Dancing+Script:wght@600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
--cream:#fdf8f2;
--warm-white:#fff9f4;
--brown:#3d2b1f;
--dark-brown:#1e1208;
--medium-brown:#7a4f2f;
--accent:#c0392b;
--accent-light:#e74c3c;
--gold:#d4a843;
--gold-light:#f0c060;
--text:#2c1a0e;
--text-light:#6b4c30;
--border:#e8d5c0;
--shadow:rgba(61,43,31,0.12);
--card-bg:#fffaf5;
}

html{scroll-behavior:smooth}
body{font-family:'Lato',sans-serif;background:var(--cream);color:var(--text);line-height:1.7;font-size:16px}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}

.container{max-width:1180px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:860px;margin:0 auto;padding:0 24px}

/* ── HEADER ── */
.site-header{background:var(--warm-white);border-bottom:3px solid var(--gold);position:sticky;top:0;z-index:100;box-shadow:0 2px 18px var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;max-width:1180px;margin:0 auto;gap:16px}
.logo-wrap{display:flex;align-items:center;gap:14px;text-decoration:none}
.logo-wrap svg{width:52px;height:52px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-title{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:700;color:var(--brown);letter-spacing:.3px}
.logo-sub{font-family:'Dancing Script',cursive;font-size:.95rem;color:var(--medium-brown)}

.site-nav{display:flex;align-items:center;gap:6px}
.site-nav a{font-family:'Lato',sans-serif;font-size:.88rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--brown);padding:7px 14px;border-radius:4px;transition:background .2s,color .2s}
.site-nav a:hover,.site-nav a.active{background:var(--gold);color:#fff}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:var(--brown);border-radius:2px;transition:.3s}

/* ── HERO ── */
.hero{background:linear-gradient(135deg,var(--brown) 0%,var(--dark-brown) 60%,#5a2d0c 100%);padding:80px 24px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero-badge{display:inline-block;font-family:'Dancing Script',cursive;font-size:1.1rem;color:var(--gold-light);margin-bottom:14px;letter-spacing:1px}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:18px}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero p{font-size:1.15rem;color:rgba(255,255,255,.78);max-width:560px;margin:0 auto 32px}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;padding:13px 30px;border-radius:4px;font-family:'Lato',sans-serif;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.8px;transition:.25s}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-light);color:var(--dark-brown)}
.btn-outline{border:2px solid rgba(255,255,255,.55);color:#fff}
.btn-outline:hover{background:rgba(255,255,255,.12)}

/* ── SECTION LABELS ── */
.section-label{display:flex;align-items:center;gap:14px;margin-bottom:36px}
.section-label h2{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;color:var(--brown)}
.section-label::after{content:'';flex:1;height:2px;background:linear-gradient(90deg,var(--gold),transparent)}

/* ── RECIPE GRID ── */
.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}
.recipe-card{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 3px 18px var(--shadow);transition:transform .25s,box-shadow .25s;border:1px solid var(--border)}
.recipe-card:hover{transform:translateY(-5px);box-shadow:0 10px 36px rgba(61,43,31,.18)}
.card-img{position:relative;height:220px;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.recipe-card:hover .card-img img{transform:scale(1.06)}
.card-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;padding:4px 10px;border-radius:20px}
.card-body{padding:20px}
.card-meta{display:flex;gap:14px;margin-bottom:10px}
.card-meta span{font-size:.78rem;color:var(--text-light);display:flex;align-items:center;gap:4px}
.card-meta svg{width:13px;height:13px;flex-shrink:0}
.card-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--brown);margin-bottom:8px;line-height:1.3}
.card-excerpt{font-size:.88rem;color:var(--text-light);line-height:1.6;margin-bottom:16px}
.card-link{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--accent);display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
.card-link:hover{gap:9px}

/* ── SIDEBAR LAYOUT ── */
.content-with-sidebar{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start;padding:60px 0}
.sidebar{position:sticky;top:90px}
.sidebar-widget{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:22px;margin-bottom:24px}
.sidebar-widget h3{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--brown);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--gold)}
.category-list li{padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}
.category-list li:last-child{border:none}
.category-list a{color:var(--text-light);display:flex;justify-content:space-between;transition:color .2s}
.category-list a:hover{color:var(--accent)}
.category-list span{background:var(--border);border-radius:10px;padding:1px 8px;font-size:.75rem;color:var(--text-light)}

/* ── RECIPE PAGE ── */
.recipe-hero{height:420px;position:relative;overflow:hidden;border-radius:0 0 16px 16px}
.recipe-hero img{width:100%;height:100%;object-fit:cover}
.recipe-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,18,8,.75) 0%,transparent 55%);display:flex;align-items:flex-end;padding:32px}
.recipe-hero-text{color:#fff}
.recipe-hero-text h1{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;line-height:1.15;margin-bottom:10px}
.recipe-hero-text .meta-row{display:flex;gap:18px;flex-wrap:wrap}
.recipe-hero-text .meta-row span{font-size:.85rem;display:flex;align-items:center;gap:5px;opacity:.9}

.recipe-info-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:10px;overflow:hidden;margin:28px 0}
.info-cell{background:var(--card-bg);padding:18px 12px;text-align:center}
.info-cell .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-light);margin-bottom:5px}
.info-cell .value{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--brown)}

.ingredients-box{background:linear-gradient(135deg,#fff8ee,var(--card-bg));border:1px solid var(--border);border-left:4px solid var(--gold);border-radius:8px;padding:26px;margin-bottom:28px}
.ingredients-box h2{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--brown);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.ingredients-box ul{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ingredients-box li{font-size:.9rem;display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px dashed var(--border)}
.ingredients-box li::before{content:'•';color:var(--gold);font-size:1.2rem;line-height:1;flex-shrink:0}

.steps-section h2{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--brown);margin-bottom:20px;display:flex;align-items:center;gap:8px}
.step{display:flex;gap:18px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.step:last-child{border:none}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--brown);color:#fff;font-family:'Playfair Display',serif;font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.step-text{font-size:.95rem;line-height:1.75;color:var(--text)}

/* ── ABOUT / STATIC PAGES ── */
.page-hero{background:linear-gradient(135deg,var(--brown),var(--dark-brown));padding:60px 24px;text-align:center}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);color:#fff;font-weight:700}
.page-hero p{color:rgba(255,255,255,.7);margin-top:10px;font-size:1rem}

.prose{font-size:.97rem;line-height:1.85;color:var(--text)}
.prose h2{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--brown);margin:32px 0 12px}
.prose h3{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--brown);margin:24px 0 8px}
.prose p{margin-bottom:16px}
.prose ul{list-style:disc;padding-left:22px;margin-bottom:16px}
.prose ul li{margin-bottom:6px}
.prose a{color:var(--accent);text-decoration:underline}

/* ── FOOTER ── */
.site-footer{background:var(--dark-brown);color:rgba(255,255,255,.75);padding:48px 24px 28px}
.footer-inner{max-width:1180px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:36px}
.footer-brand .logo-title{color:#fff;font-size:1.3rem}
.footer-brand .logo-sub{color:var(--gold-light)}
.footer-brand p{margin-top:14px;font-size:.88rem;line-height:1.7;color:rgba(255,255,255,.6)}
.footer-col h4{font-family:'Playfair Display',serif;font-size:1rem;color:#fff;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.15)}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{font-size:.88rem;color:rgba(255,255,255,.6);transition:color .2s}
.footer-col ul li a:hover{color:var(--gold-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;text-align:center;font-size:.83rem;color:rgba(255,255,255,.45);line-height:1.9}

/* ── BREADCRUMB ── */
.breadcrumb{padding:14px 0;font-size:.82rem;color:var(--text-light);display:flex;gap:6px;align-items:center}
.breadcrumb a{color:var(--accent)}
.breadcrumb span{opacity:.5}

/* ── CONTACT ── */
.contact-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:36px;max-width:580px;margin:0 auto}
.contact-card h2{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--brown);margin-bottom:8px}
.contact-card p{color:var(--text-light);margin-bottom:24px}
.email-link{display:inline-flex;align-items:center;gap:10px;background:var(--brown);color:#fff;padding:14px 28px;border-radius:6px;font-weight:700;font-size:1rem;transition:.2s}
.email-link:hover{background:var(--accent)}
.contact-note{margin-top:22px;font-size:.85rem;color:var(--text-light);line-height:1.7}

/* ── UTILITIES ── */
.mt-2{margin-top:8px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mt-6{margin-top:40px}
.mb-2{margin-bottom:8px}.mb-4{margin-bottom:24px}.mb-6{margin-bottom:40px}
.py-8{padding:48px 0}.py-10{padding:64px 0}.py-12{padding:80px 0}
.text-center{text-align:center}

/* ── MOBILE ── */
@media(max-width:900px){
.content-with-sidebar{grid-template-columns:1fr}
.sidebar{position:static}
.footer-top{grid-template-columns:1fr 1fr}
.footer-brand{grid-column:1/-1}
.ingredients-box ul{grid-template-columns:1fr}
.recipe-info-bar{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
.hamburger{display:flex}
.site-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--warm-white);flex-direction:column;padding:16px;border-top:2px solid var(--gold);box-shadow:0 8px 24px var(--shadow);gap:4px}
.site-nav.open{display:flex}
.site-nav a{width:100%;padding:10px 16px;font-size:.9rem}
.footer-top{grid-template-columns:1fr}
.recipe-grid{grid-template-columns:1fr}
.hero h1{font-size:2rem}
.hero-btns{flex-direction:column;align-items:center}
}

/* ── AD PLACEHOLDER ── */
.ad-placeholder{background:linear-gradient(135deg,#f5ede4,#ede0d4);border:1px dashed var(--gold);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px;gap:4px}
.ad-placeholder.leaderboard{width:100%;height:90px;margin:24px 0}
.ad-placeholder.rectangle{width:100%;height:250px}
.ad-placeholder.banner{width:100%;height:60px;margin:16px 0}
