/* ============================================================
   BELLA TORTA — Italian Cake Blog
   Theme: soft pastel (blush pink, gold, ivory) patisserie
   ============================================================ */

:root{
  --ivory:#FBF7F0;
  --ivory-2:#FFFDF8;
  --cream:#F4ECE0;
  --blush:#E8B4BC;
  --blush-soft:#F6E2E4;
  --blush-deep:#C98A93;
  --gold:#C9A14A;
  --gold-soft:#E7D3A1;
  --ink:#3A2F2A;
  --ink-soft:#6E625B;
  --line:#EBE1D4;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(58,47,42,.08);
  --shadow-lg:0 24px 60px rgba(58,47,42,.14);
  --radius:18px;
  --radius-sm:12px;
  --maxw:1180px;
  --serif:'Cormorant Garamond', Georgia, serif;
  --display:'Playfair Display', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--ivory);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.18;color:var(--ink)}
h1{font-size:clamp(2.1rem,5vw,3.6rem)}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem)}
h3{font-size:1.35rem}

.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  padding:14px 30px;
  border-radius:50px;
  font-weight:600;
  font-size:.92rem;
  letter-spacing:.02em;
  transition:.25s ease;
  cursor:pointer;
  border:none;
}
.btn-primary{background:var(--ink);color:var(--ivory-2)}
.btn-primary:hover{background:var(--blush-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--ivory-2)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(251,247,240,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .logo{
  font-family:var(--display);
  font-size:1.7rem;font-weight:800;
  letter-spacing:.01em;
}
.brand .logo span{color:var(--blush-deep)}
.brand .tag{
  font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-top:4px;font-weight:600;
}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{
  font-size:.86rem;font-weight:500;letter-spacing:.03em;
  position:relative;padding:4px 0;color:var(--ink-soft);transition:.2s;
}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--gold);transition:.25s;
}
.nav-links a:hover::after{width:100%}
.nav-search{
  display:flex;align-items:center;gap:8px;
  background:var(--white);border:1px solid var(--line);
  border-radius:50px;padding:9px 16px;
}
.nav-search input{border:none;outline:none;background:none;font-size:.85rem;width:130px;font-family:var(--sans)}
.menu-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--ink)}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(180deg,var(--blush-soft) 0%,var(--ivory) 100%);
  padding:72px 0 84px;
  position:relative;overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.hero h1{margin:18px 0 20px}
.hero p.lead{font-size:1.12rem;color:var(--ink-soft);max-width:520px;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-visual img{
  border-radius:24px;box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;object-fit:cover;width:100%;
}
.hero-badge{
  position:absolute;bottom:-22px;left:-22px;
  background:var(--white);border-radius:16px;padding:16px 22px;
  box-shadow:var(--shadow);
}
.hero-badge .num{font-family:var(--display);font-size:1.8rem;font-weight:800;color:var(--blush-deep)}
.hero-badge .lbl{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- Section headings ---------- */
.section{padding:72px 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 48px}
.section-head h2{margin:12px 0 14px}
.section-head p{color:var(--ink-soft)}
.section-head.left{text-align:left;margin-left:0}

/* ---------- Category strip ---------- */
.cat-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.cat-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:1/1;box-shadow:var(--shadow);display:block;
}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.cat-card:hover img{transform:scale(1.07)}
.cat-card .cat-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(58,47,42,.72) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:26px;
}
.cat-card .cat-overlay h3{color:var(--ivory-2);font-size:1.5rem}
.cat-card .cat-overlay span{color:var(--gold-soft);font-size:.8rem;letter-spacing:.08em;margin-top:4px}

/* ---------- Recipe card grid ---------- */
.recipe-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px;
}
.recipe-card{
  background:var(--white);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:.3s ease;display:flex;flex-direction:column;
}
.recipe-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.recipe-card .thumb{position:relative;aspect-ratio:4/3;overflow:hidden}
.recipe-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.6s}
.recipe-card:hover .thumb img{transform:scale(1.06)}
.recipe-card .cat-tag{
  position:absolute;top:14px;left:14px;
  background:rgba(251,247,240,.92);color:var(--blush-deep);
  font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 12px;border-radius:50px;
}
.recipe-card .card-body{padding:22px 22px 26px;display:flex;flex-direction:column;flex:1}
.recipe-card h3{font-size:1.22rem;margin-bottom:8px;line-height:1.25}
.recipe-card p{font-size:.9rem;color:var(--ink-soft);flex:1}
.recipe-card .meta{
  display:flex;gap:18px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);
  font-size:.78rem;color:var(--ink-soft);
}
.recipe-card .meta b{color:var(--ink);font-weight:600}

/* ---------- Filter bar (category pages) ---------- */
.filter-bar{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.chip{
  padding:10px 22px;border-radius:50px;border:1.5px solid var(--line);
  background:var(--white);font-size:.85rem;font-weight:500;cursor:pointer;transition:.2s;
}
.chip:hover{border-color:var(--blush)}
.chip.active{background:var(--ink);color:var(--ivory-2);border-color:var(--ink)}

/* ---------- Newsletter ---------- */
.newsletter{
  background:linear-gradient(135deg,var(--ink) 0%,#4a3b34 100%);
  border-radius:26px;padding:56px;text-align:center;color:var(--ivory-2);
}
.newsletter h2{color:var(--ivory-2)}
.newsletter p{color:rgba(251,247,240,.78);max-width:480px;margin:12px auto 28px}
.newsletter form{display:flex;gap:12px;max-width:460px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.newsletter input{
  flex:1;min-width:220px;padding:14px 20px;border-radius:50px;border:none;font-size:.92rem;font-family:var(--sans);
}
.newsletter .btn-primary{background:var(--gold);color:var(--ink)}
.newsletter .btn-primary:hover{background:var(--gold-soft)}

/* ---------- Footer ---------- */
.site-footer{background:var(--cream);border-top:1px solid var(--line);padding:60px 0 30px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-grid h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-grid ul{list-style:none}
.footer-grid li{margin-bottom:10px}
.footer-grid a{font-size:.9rem;color:var(--ink-soft);transition:.2s}
.footer-grid a:hover{color:var(--ink)}
.footer-brand .logo{font-family:var(--display);font-size:1.5rem;font-weight:800}
.footer-brand p{font-size:.9rem;color:var(--ink-soft);margin-top:12px;max-width:280px}
.footer-bottom{border-top:1px solid var(--line);padding-top:24px;text-align:center;font-size:.82rem;color:var(--ink-soft)}

/* ============================================================
   RECIPE ARTICLE PAGE
   ============================================================ */
.article-hero{padding:46px 0 10px}
.breadcrumb{font-size:.8rem;color:var(--ink-soft);margin-bottom:20px;letter-spacing:.02em}
.breadcrumb a:hover{color:var(--blush-deep)}
.article-head{max-width:780px;margin:0 auto;text-align:center}
.article-head .eyebrow{display:block;margin-bottom:14px}
.article-head h1{margin-bottom:18px}
.article-head .dek{font-size:1.12rem;color:var(--ink-soft)}
.article-meta{
  display:flex;justify-content:center;gap:28px;flex-wrap:wrap;
  margin:28px 0 8px;font-size:.84rem;color:var(--ink-soft);
}
.article-meta .mi b{color:var(--ink);font-weight:600}
.article-figure{margin:36px 0}
.article-figure img{
  width:100%;border-radius:24px;box-shadow:var(--shadow-lg);
  aspect-ratio:16/10;object-fit:cover;
}
.article-figure figcaption{text-align:center;font-size:.8rem;color:var(--ink-soft);margin-top:12px;font-style:italic}

.article-body{max-width:760px;margin:0 auto;padding:10px 0 30px}
.article-body p{margin-bottom:22px;font-size:1.06rem}
.article-body h2{margin:42px 0 16px}
.article-body h3{margin:30px 0 12px;font-family:var(--display)}
.article-body ul,.article-body ol{margin:0 0 24px 22px}
.article-body li{margin-bottom:10px}
.article-body img{border-radius:18px;margin:30px 0;box-shadow:var(--shadow)}
.article-body blockquote{
  border-left:3px solid var(--gold);padding:6px 0 6px 24px;margin:28px 0;
  font-family:var(--serif);font-size:1.3rem;font-style:italic;color:var(--ink-soft);
}
.tip-box{
  background:var(--blush-soft);border-radius:var(--radius-sm);padding:22px 26px;margin:28px 0;
}
.tip-box h4{font-family:var(--display);margin-bottom:8px;color:var(--blush-deep)}
.tip-box p{margin:0;font-size:.98rem}

/* ---------- Recipe Card ---------- */
.recipe-card-print{
  max-width:760px;margin:46px auto;border:1px solid var(--line);
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow);background:var(--white);
}
.rcp-header{background:linear-gradient(135deg,var(--blush-soft),var(--cream));padding:34px 38px;position:relative}
.rcp-header .eyebrow{margin-bottom:8px}
.rcp-header h2{font-size:1.9rem;margin-bottom:8px}
.rcp-header p{color:var(--ink-soft);font-size:.95rem}
.rcp-stats{display:flex;flex-wrap:wrap;gap:0;border-bottom:1px solid var(--line)}
.rcp-stat{flex:1;min-width:120px;text-align:center;padding:20px 10px;border-right:1px solid var(--line)}
.rcp-stat:last-child{border-right:none}
.rcp-stat .s-lbl{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:700}
.rcp-stat .s-val{font-family:var(--display);font-size:1.3rem;font-weight:700;margin-top:6px}
.rcp-body{padding:34px 38px}
.rcp-section-title{
  font-family:var(--sans);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blush-deep);font-weight:700;margin:8px 0 18px;
  display:flex;align-items:center;gap:12px;
}
.rcp-section-title::after{content:"";flex:1;height:1px;background:var(--line)}
.rcp-ingredients{list-style:none;columns:2;column-gap:36px}
.rcp-ingredients li{
  padding:9px 0 9px 26px;position:relative;font-size:.95rem;break-inside:avoid;
  border-bottom:1px dashed var(--line);
}
.rcp-ingredients li::before{
  content:"";position:absolute;left:0;top:15px;width:9px;height:9px;border-radius:50%;
  background:var(--gold);
}
.rcp-steps{list-style:none;counter-reset:step;margin-top:8px}
.rcp-steps li{
  position:relative;padding:0 0 26px 56px;counter-increment:step;
}
.rcp-steps li::before{
  content:counter(step);position:absolute;left:0;top:-2px;
  width:38px;height:38px;border-radius:50%;background:var(--gold);
  color:var(--white);font-family:var(--display);font-weight:700;font-size:1.05rem;
  display:flex;align-items:center;justify-content:center;
}
.rcp-steps li::after{
  content:"";position:absolute;left:18px;top:38px;bottom:6px;width:2px;background:var(--line);
}
.rcp-steps li:last-child::after{display:none}
.rcp-steps li p{margin:0;font-size:.98rem;padding-top:6px}
.rcp-nutrition{
  display:flex;flex-wrap:wrap;gap:0;background:var(--ivory);border-radius:var(--radius-sm);
  margin-top:28px;overflow:hidden;border:1px solid var(--line);
}
.rcp-nut{flex:1;min-width:90px;text-align:center;padding:16px 8px;border-right:1px solid var(--line)}
.rcp-nut:last-child{border-right:none}
.rcp-nut .n-val{font-family:var(--display);font-weight:700;font-size:1.15rem}
.rcp-nut .n-lbl{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.rcp-footer{padding:22px 38px;background:var(--ivory);border-top:1px solid var(--line);font-size:.84rem;color:var(--ink-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- Related ---------- */
.related{padding:60px 0}

/* ---------- Page header (category) ---------- */
.page-header{background:linear-gradient(180deg,var(--blush-soft),var(--ivory));padding:60px 0 50px;text-align:center}
.page-header .eyebrow{display:block;margin-bottom:14px}
.page-header p{color:var(--ink-soft);max-width:560px;margin:14px auto 0}

/* ---------- Misc ---------- */
.empty-state{text-align:center;padding:60px 0;color:var(--ink-soft)}
.fade-in{opacity:0;transform:translateY(16px);transition:.6s ease}
.fade-in.visible{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{max-width:420px;margin:0 auto}
  .cat-strip{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .rcp-ingredients{columns:1}
}
@media(max-width:760px){
  .nav-links,.nav-search{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;position:absolute;top:78px;left:0;right:0;
    background:var(--ivory-2);padding:24px;gap:18px;box-shadow:var(--shadow);
  }
  .menu-toggle{display:block}
  .newsletter{padding:40px 24px}
  .footer-grid{grid-template-columns:1fr}
  body{font-size:16px}
}
