
/* ── reset & base ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#FBF8F4;
  --card:#FFFFFF;
  --primary:#D4552A;
  --primary-dark:#B03E1A;
  --green:#2D6A4F;
  --pin:#E60023;
  --text:#1A1A1A;
  --muted:#666;
  --border:#E5DFD9;
  --radius:12px;
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --shadow-hover:0 8px 32px rgba(0,0,0,.14);
}
html{scroll-behavior:smooth}
body{font-family:'Nunito',sans-serif;background:var(--bg);color:var(--text);line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.25}

/* ── layout ─────────────────────────────────────────────────────────── */
.container{max-width:1280px;margin:0 auto;padding:0 20px}
.section{padding:60px 0}

/* ── header ─────────────────────────────────────────────────────────── */
.site-header{background:#fff;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;max-width:1280px;margin:0 auto;gap:16px}
.site-logo{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--primary)}
.site-logo span{color:var(--green)}
.main-nav{display:flex;gap:6px;flex-wrap:wrap}
.main-nav a{padding:6px 14px;border-radius:20px;font-size:.875rem;font-weight:600;color:var(--muted);transition:.2s}
.main-nav a:hover,.main-nav a.active{background:var(--primary);color:#fff}

/* ── hero ───────────────────────────────────────────────────────────── */
.hero{background:linear-gradient(135deg,#2D6A4F 0%,#D4552A 100%);color:#fff;padding:80px 20px;text-align:center}
.hero h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:16px;text-shadow:0 2px 8px rgba(0,0,0,.2)}
.hero p{font-size:1.125rem;opacity:.9;max-width:600px;margin:0 auto 32px}
.hero-cta-wrap{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:30px;font-weight:700;font-size:.95rem;transition:.2s;cursor:pointer;border:none}
.btn-primary{background:#fff;color:var(--primary)}
.btn-primary:hover{background:var(--bg);transform:translateY(-2px)}
.btn-pin{background:var(--pin);color:#fff}
.btn-pin:hover{background:#c0001c;transform:translateY(-2px)}

/* ── category strip ─────────────────────────────────────────────────── */
.cat-strip{background:#fff;border-bottom:1px solid var(--border);padding:12px 20px}
.cat-strip-inner{max-width:1280px;margin:0 auto;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cat-strip-inner .label{font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-right:6px}
.cat-tag{padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:600;border:2px solid var(--border);color:var(--muted);transition:.2s}
.cat-tag:hover,.cat-tag.active{border-color:var(--primary);color:var(--primary);background:#FDF0EB}

/* ── post grid ──────────────────────────────────────────────────────── */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px;padding:40px 20px;max-width:1280px;margin:0 auto}

/* ── card ───────────────────────────────────────────────────────────── */
.card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.card-img-wrap{position:relative;overflow:hidden;aspect-ratio:4/3;flex-shrink:0}
.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .card-img-wrap img{transform:scale(1.05)}
.pin-btn{position:absolute;top:12px;right:12px;background:var(--pin);color:#fff;border-radius:20px;padding:7px 14px;font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:6px;opacity:0;transform:translateY(-4px);transition:.25s;white-space:nowrap}
.card:hover .pin-btn,.pin-btn:focus{opacity:1;transform:translateY(0)}
.pin-btn:hover{background:#c0001c}
.card-body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-cat{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--green)}
.card-cat:hover{color:var(--primary)}
.card-title{font-size:1.1rem;line-height:1.3}
.card-title a:hover{color:var(--primary)}
.card-exc{font-size:.875rem;color:var(--muted);line-height:1.6;flex:1}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}
.card-date{font-size:.78rem;color:var(--muted)}
.card-read{font-size:.82rem;font-weight:700;color:var(--primary)}
.card-read:hover{color:var(--primary-dark)}

/* ── single post ────────────────────────────────────────────────────── */
.post-hero{position:relative;max-height:520px;overflow:hidden}
.post-hero img{width:100%;height:520px;object-fit:cover}
.post-hero-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.65));padding:40px 24px 24px}
.post-hero-overlay .post-cat{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:8px}
.post-hero-overlay h1{color:#fff;font-size:clamp(1.5rem,4vw,2.6rem);line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.post-hero-pin{position:absolute;top:20px;right:20px;background:var(--pin);color:#fff;border-radius:24px;padding:10px 18px;font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:8px;transition:.2s}
.post-hero-pin:hover{background:#c0001c;transform:scale(1.05)}

.post-meta{display:flex;gap:16px;flex-wrap:wrap;align-items:center;padding:16px 0;border-bottom:1px solid var(--border);margin-bottom:32px;font-size:.85rem;color:var(--muted)}
.post-meta .meta-cat{background:#FDF0EB;color:var(--primary);padding:4px 12px;border-radius:12px;font-weight:600}

.post-layout{display:grid;grid-template-columns:1fr 360px;gap:48px;max-width:1200px;margin:0 auto;padding:40px 20px}
@media(max-width:900px){.post-layout{grid-template-columns:1fr}}

/* ── article body ───────────────────────────────────────────────────── */
.post-body{min-width:0}
.post-body h2{font-size:1.6rem;margin:40px 0 16px;color:var(--text)}
.post-body h3{font-size:1.25rem;margin:28px 0 12px;color:var(--green)}
.post-body h4{font-size:1.05rem;margin:20px 0 8px}
.post-body p{margin-bottom:20px;line-height:1.8;color:#333}
.post-body ul,.post-body ol{margin:0 0 20px 24px}
.post-body li{margin-bottom:8px;line-height:1.7}
.post-body blockquote{border-left:4px solid var(--primary);padding:16px 20px;background:#FDF7F4;border-radius:0 8px 8px 0;margin:24px 0;font-style:italic;color:#555}
.post-body strong{color:var(--text);font-weight:700}

/* ── recipe card (sidebar) ──────────────────────────────────────────── */
.recipe-card{position:sticky;top:90px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.recipe-card-head{background:linear-gradient(135deg,var(--green),#1B4D38);color:#fff;padding:20px 22px}
.recipe-card-head h3{font-size:1.15rem;margin-bottom:4px}
.recipe-card-head p{font-size:.82rem;opacity:.85}
.recipe-section{padding:20px 22px;border-bottom:1px solid var(--border)}
.recipe-section:last-child{border-bottom:none}
.recipe-section h4{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.recipe-section ul{list-style:none;padding:0}
.recipe-section ul li{padding:7px 0;border-bottom:1px dashed var(--border);font-size:.9rem;display:flex;gap:8px;align-items:baseline}
.recipe-section ul li::before{content:"•";color:var(--primary);flex-shrink:0}
.recipe-section ol{padding-left:20px}
.recipe-section ol li{padding:8px 0;border-bottom:1px dashed var(--border);font-size:.9rem;line-height:1.5}
.pin-recipe-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:var(--pin);color:#fff;font-weight:700;font-size:.95rem;transition:.2s}
.pin-recipe-btn:hover{background:#c0001c}

/* ── related posts ──────────────────────────────────────────────────── */
.related-section{padding:60px 0;border-top:2px solid var(--border);margin-top:60px}
.related-section h2{font-size:1.8rem;margin-bottom:32px;text-align:center}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}

/* ── category page hero ─────────────────────────────────────────────── */
.cat-hero{background:linear-gradient(135deg,#1B4D38 0%,#2D6A4F 100%);color:#fff;padding:60px 20px;text-align:center}
.cat-hero h1{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:12px}
.cat-hero p{font-size:1rem;opacity:.85;max-width:520px;margin:0 auto}
.cat-count{display:inline-block;background:rgba(255,255,255,.2);border-radius:20px;padding:4px 14px;font-size:.82rem;margin-top:12px}

/* ── home author section ────────────────────────────────────────────── */
.home-author{background:#fff;padding:56px 20px;border-bottom:1px solid var(--border)}
.home-author-inner{max-width:860px;margin:0 auto;display:flex;gap:48px;align-items:center}
.home-author-photo{flex-shrink:0;width:180px;height:180px;border-radius:50%;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.14);border:4px solid var(--border)}
.home-author-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.home-author-body{flex:1;min-width:0}
.home-author-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--primary);display:block;margin-bottom:6px}
.home-author-body h2{font-size:1.75rem;margin-bottom:12px}
.home-author-body p{color:var(--muted);line-height:1.8;margin-bottom:18px;font-size:.95rem}
.home-author-tags{display:flex;gap:8px;flex-wrap:wrap}
.home-author-tags span{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:.8rem;font-weight:600;color:var(--text)}
@media(max-width:620px){
  .home-author-inner{flex-direction:column;align-items:center;text-align:center;gap:28px}
  .home-author-tags{justify-content:center}
}

/* ── footer ─────────────────────────────────────────────────────────── */
.site-footer{background:#1A1A1A;color:#aaa;padding:48px 20px;text-align:center}
.footer-inner{max-width:900px;margin:0 auto}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:16px}
.footer-cats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:20px 0}
.footer-cats a{font-size:.88rem;transition:.2s}
.footer-cats a:hover{color:#fff}
.footer-copy{font-size:.8rem;margin-top:24px;border-top:1px solid #333;padding-top:20px}
.footer-pinterest{margin:20px 0}
.footer-pinterest a{display:inline-flex;align-items:center;gap:8px;background:var(--pin);color:#fff;padding:10px 22px;border-radius:24px;font-weight:700;font-size:.9rem;transition:.2s}
.footer-pinterest a:hover{background:#c0001c}

/* ── author bio ─────────────────────────────────────────────────────── */
.author-bio{display:flex;gap:24px;align-items:flex-start;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 32px;margin:48px 0}
.author-bio-avatar{flex-shrink:0;width:88px;height:88px;border-radius:50%;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.18);border:3px solid var(--border)}
.author-bio-avatar img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.author-bio-info{flex:1;min-width:0}
.author-bio-info h4{font-size:1.15rem;margin-bottom:3px;font-family:'Playfair Display',serif}
.author-bio-role{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green);margin-bottom:10px;display:block}
.author-bio-info p{font-size:.9rem;color:var(--muted);line-height:1.75;margin:0}
@media(max-width:500px){.author-bio{flex-direction:column;align-items:center;text-align:center;padding:22px 20px}}

/* ── pagination ─────────────────────────────────────────────────────── */
.pagination{display:flex;justify-content:center;gap:10px;padding:40px 20px}
.pagination a,.pagination span{padding:10px 18px;border-radius:8px;font-weight:600;font-size:.9rem;border:2px solid var(--border)}
.pagination a:hover{border-color:var(--primary);color:var(--primary)}
.pagination .current{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── breadcrumb ─────────────────────────────────────────────────────── */
.breadcrumb{padding:14px 20px;max-width:1200px;margin:0 auto;font-size:.82rem;color:var(--muted);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.breadcrumb a{color:var(--primary)}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .sep{opacity:.4}

/* ── sidebar pin card ────────────────────────────────────────────────── */
.pin-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-top:24px}
.pin-card-head{background:var(--pin);color:#fff;padding:14px 18px;display:flex;align-items:center;gap:10px;font-weight:700;font-size:.9rem}
.pin-card-body{padding:20px;display:flex;flex-direction:column;align-items:center;gap:14px}
.pin-card-label{font-size:.78rem;color:var(--muted);text-align:center;font-style:italic;line-height:1.4}
.pin-card-thumb{position:relative;width:180px;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.18);flex-shrink:0}
.pin-card-thumb a{display:block}
.pin-card-thumb img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;transition:.35s}
.pin-card-thumb:hover img{transform:scale(1.05)}
.pin-card-overlay{position:absolute;inset:0;background:rgba(230,0,35,0);display:flex;align-items:center;justify-content:center;transition:.25s}
.pin-card-thumb:hover .pin-card-overlay{background:rgba(230,0,35,.4)}
.pin-card-overlay span{background:var(--pin);color:#fff;padding:8px 16px;border-radius:20px;font-weight:700;font-size:.78rem;display:flex;align-items:center;gap:6px;opacity:0;transform:scale(.85);transition:.25s;white-space:nowrap}
.pin-card-thumb:hover .pin-card-overlay span{opacity:1;transform:scale(1)}
.pin-card-save{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 16px;background:var(--pin);color:#fff;border-radius:10px;font-weight:700;font-size:.88rem;transition:.2s}
.pin-card-save:hover{background:#c0001c;transform:translateY(-1px);box-shadow:0 4px 16px rgba(230,0,35,.3)}
/* ── in-article pinterest banner ─────────────────────────────────────── */
.pin-banner{border-radius:16px;border:2px solid rgba(230,0,35,.12);background:linear-gradient(135deg,#fff5f4 0%,#ffecea 100%);padding:28px;margin:48px 0;display:flex;gap:28px;align-items:center}
.pin-banner-text{flex:1;min-width:0}
.pin-banner-badge{display:inline-flex;align-items:center;gap:6px;background:var(--pin);color:#fff;padding:5px 14px;border-radius:20px;font-size:.72rem;font-weight:700;margin-bottom:14px;letter-spacing:.04em;text-transform:uppercase}
.pin-banner-text h4{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.3}
.pin-banner-text p{font-size:.875rem;color:#555;line-height:1.65;margin-bottom:18px}
.pin-banner-btn{display:inline-flex;align-items:center;gap:8px;background:var(--pin);color:#fff;padding:13px 26px;border-radius:30px;font-weight:700;font-size:.88rem;transition:.22s;box-shadow:0 4px 16px rgba(230,0,35,.25)}
.pin-banner-btn:hover{background:#c0001c;transform:translateY(-2px);box-shadow:0 8px 24px rgba(230,0,35,.4)}
.pin-banner-image{flex-shrink:0;width:150px}
.pin-banner-image a{display:block;border-radius:12px;overflow:hidden;box-shadow:0 6px 28px rgba(0,0,0,.16);position:relative}
.pin-banner-image img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;transition:.35s}
.pin-banner-image a:hover img{transform:scale(1.06)}
@media(max-width:640px){
  .pin-banner{flex-direction:column-reverse;align-items:center;text-align:center;padding:22px}
  .pin-banner-image{width:130px}
  .pin-banner-badge{margin:0 auto 12px}
  .pin-banner-btn{width:100%;justify-content:center}
}
/* ── sticky floating pinterest button ────────────────────────────────── */
.pin-float{position:fixed;bottom:28px;right:28px;background:var(--pin);color:#fff;border-radius:50px;padding:13px 22px;display:flex;align-items:center;gap:8px;font-weight:700;font-size:.88rem;box-shadow:0 4px 24px rgba(230,0,35,.5);z-index:300;opacity:0;transform:translateY(70px);transition:.35s cubic-bezier(.34,1.56,.64,1);pointer-events:none;text-decoration:none;white-space:nowrap}
.pin-float.show{opacity:1;transform:translateY(0);pointer-events:auto}
.pin-float:hover{background:#c0001c;transform:translateY(-3px)!important;box-shadow:0 8px 32px rgba(230,0,35,.6)}
.pin-float svg{flex-shrink:0}
@media(max-width:768px){.pin-float{bottom:16px;right:16px;padding:11px 18px;font-size:.82rem}}
/* inline pin block (no sidebar, e.g. posts without recipe) */
.pin-inline{max-width:320px;margin:40px auto}

/* ── responsive ─────────────────────────────────────────────────────── */
@media(max-width:768px){
  .header-inner{flex-direction:column;gap:10px;padding:12px 16px}
  .posts-grid{padding:20px 16px;gap:20px}
  .post-hero img{height:320px}
  .post-hero-overlay h1{font-size:1.4rem}
  .post-hero-pin{font-size:.75rem;padding:8px 12px}
  .section{padding:40px 0}
}
@media(max-width:480px){
  .main-nav{justify-content:center}
  .hero{padding:50px 16px}
  .post-hero img{height:260px}
}
