
:root{
  --bg:#fff; --text:#1f2937; --muted:#6b7280; --line:#e5e7eb;
  --brand:#16a34a; --brand2:#0ea5e9; --card:#ffffff;
  --shadow: 0 10px 30px rgba(17,24,39,.08);
  --radius:18px;
  --max:1100px;
  --serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.5}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:22px}
header{
  position:sticky;top:0;background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(10px); border-bottom:1px solid var(--line); z-index:20;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.brand{
  display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px
}
.brand .dot{width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand2))}
.brand span{font-size:18px}
.navlinks{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-weight:600;font-size:14px}
.hero{
  padding:38px 0 8px;
}
.hero h1{
  font-family:var(--serif);font-size:44px;line-height:1.05;margin:0 0 10px;
}
.hero p{max-width:70ch;color:var(--muted);margin:0 0 18px;font-size:16px}
.kpis{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line);padding:8px 12px;border-radius:999px;background:#fff;
  font-size:13px;color:var(--muted);font-weight:700;
}
.pill b{color:var(--text)}
.controls{
  display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:18px 0 12px;
}
.search{
  flex:1;min-width:220px;
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--line);border-radius:999px;padding:10px 14px;background:#fff;
}
.search input{border:none;outline:none;width:100%;font-size:14px}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  border:1px solid var(--line);background:#fff;color:var(--muted);
  padding:8px 12px;border-radius:999px;font-size:13px;font-weight:700;cursor:pointer;
}
.chip.active{border-color:rgba(22,163,74,.35); color:#065f46; background:rgba(22,163,74,.08)}
.grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:14px 0 42px;
}
@media (max-width:980px){.grid{grid-template-columns:repeat(2,1fr)} .hero h1{font-size:38px}}
@media (max-width:640px){.grid{grid-template-columns:1fr} .hero h1{font-size:34px}}
.card{
  border:1px solid var(--line);background:var(--card);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px;display:flex;flex-direction:column;gap:10px;
  transition:transform .12s ease, box-shadow .12s ease;
}
.card:hover{transform:translateY(-2px)}
.card h3{margin:0;font-size:16px;line-height:1.25}
.meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px;font-weight:700}
.badge{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;border:1px solid var(--line);
  background:#fff;color:var(--muted);font-size:12px;font-weight:800;
}
.badge strong{color:var(--text)}
footer{border-top:1px solid var(--line);padding:26px 0;color:var(--muted);font-size:13px}
.small{font-size:12px;color:var(--muted)}
/* modal */
.modalOverlay{
  position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:flex-start;justify-content:center;
  padding:22px;z-index:50;overflow:auto;
}
.modal{
  width:min(880px,100%); background:#fff;border-radius:22px;box-shadow:0 30px 80px rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.25); padding:18px 18px 10px;
}
.modalHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modalHeader h2{font-family:var(--serif);margin:0;font-size:28px;line-height:1.15}
.closeBtn{
  border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 12px;cursor:pointer;font-weight:900;
}
.twoCol{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;margin-top:10px}
@media (max-width:860px){.twoCol{grid-template-columns:1fr}}
.section{border:1px solid var(--line);border-radius:18px;padding:14px}
.section h4{margin:0 0 8px;font-size:14px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
ul,ol{margin:0;padding-left:18px}
li{margin:6px 0}


/* --- Recipe card images --- */
.card .thumb{
  width:100%;
  aspect-ratio: 16/10;
  border-radius: 14px;
  overflow:hidden;
  background: #f3f4f6;
  border:1px solid var(--line);
  margin-bottom:12px;
}
.card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* --- Tag filter chips --- */
.filter-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.chip.tag{
  border-color: rgba(14,165,233,.35);
}
.chip.tag.active{
  background: rgba(14,165,233,.12);
  border-color: rgba(14,165,233,.55);
}

/* --- Recipe pages (printable cards) --- */
.recipe-wrap{ max-width: 860px; margin: 0 auto; padding: 26px 18px 60px; }
.recipe-hero{
  display:flex; gap:18px; flex-wrap:wrap; align-items:flex-start;
  padding:18px; border:1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); background: var(--card);
}
.recipe-hero img{
  width: 320px; max-width: 100%;
  aspect-ratio: 16/10; object-fit: cover;
  border-radius: 14px; border:1px solid var(--line);
}
.recipe-hero h1{ margin:0; font-size: 34px; line-height:1.1; font-family: var(--serif); }
.recipe-hero .meta{ margin-top:10px; }
.recipe-grid{
  display:grid; grid-template-columns: 1fr; gap: 16px; margin-top:16px;
}
@media (min-width: 860px){
  .recipe-grid{ grid-template-columns: 1fr 1fr; }
}
.recipe-card{
  padding:18px; border:1px solid var(--line); border-radius: var(--radius);
  background: var(--card); box-shadow: var(--shadow);
}
.recipe-card h2{ margin:0 0 10px; font-size: 18px; }
.recipe-card ul{ margin:0; padding-left: 18px; }
.recipe-card ol{ margin:0; padding-left: 18px; }
.printbar{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:12px;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius: 12px; border:1px solid var(--line);
  background:#fff; cursor:pointer; text-decoration:none; color: var(--text);
  font-weight:600;
}
.btn.primary{ border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.10); }

/* Print */
@media print{
  header, footer, .printbar, .backlink { display:none !important; }
  body{ background:#fff; }
  .recipe-wrap{ padding:0; }
  .recipe-hero, .recipe-card{ box-shadow:none; }
  .recipe-hero{ border:none; padding:0; }
  .recipe-card{ border:none; padding:0; }
  .recipe-grid{ grid-template-columns: 1fr 1fr; gap: 18px; }
}

.modalOverlay.open{display:flex;}
.modalOverlay[aria-hidden="false"]{display:flex;}


/* Category + tag pages */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:14px}
.cat-card{display:flex;gap:12px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:16px;background:var(--card);text-decoration:none;color:inherit}
.cat-card img{width:64px;height:64px;border-radius:14px;object-fit:cover;border:1px solid var(--border)}
.tag-cloud{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.tag-pill{display:inline-flex;gap:8px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:999px;background:var(--card);text-decoration:none;color:inherit}

/* Hero + newsletter */
.hero{padding:26px 0 6px 0}
.hero-inner{display:grid;grid-template-columns:1.3fr 0.9fr;gap:18px;align-items:start}
.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.newsletter{padding:16px}
.newsletter-form{display:flex;gap:10px;margin-top:10px}
.newsletter-form input{flex:1;min-width:180px}
.mini-links{margin-top:10px}

/* Chips on cards */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.chip{font-size:12px;border:1px solid var(--border);border-radius:999px;padding:4px 8px;background:transparent;color:inherit}
.active-tags{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.tag-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:999px;padding:6px 10px;background:var(--card);font-size:12px}
.tag-chip button{border:none;background:transparent;cursor:pointer;font-size:14px;line-height:1}
.sr-only{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}

/* Footer */
.site-footer{margin-top:30px;padding:20px 0;border-top:1px solid var(--border)}
/* Responsive */
@media (max-width: 900px){
  .hero-inner{grid-template-columns:1fr}
  .newsletter-form{flex-direction:column}
}
