/* Minimal elegant white-based style */
:root{
  --bg:#ffffff;
  --fg:#1a1a1a;
  --muted:#666;
  --card:#f7f7f8;
  --accent:#0d9488; /* teal-ish */
  --ring: rgba(13,148,136,0.35);
  --shadow: 0 10px 30px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font:16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1100px;margin:0 auto;padding:24px}
.site-header{position:sticky;top:0;background:#fff;backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;z-index:10}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{width:28px;height:28px}
.brand .title{font-weight:700;letter-spacing:.2px;color:var(--fg)}
nav a{margin-left:16px;padding:6px 10px;border-radius:10px}
nav a:hover{background:var(--card);text-decoration:none}
.grid{display:grid;gap:16px}
.grid.cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.card{background:var(--card);border:1px solid #eee;border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.card .media{width:100%;aspect-ratio:4/3;background:#eaeaea;display:block;object-fit:cover}
.card .body{padding:14px}
.badge{display:inline-block;font-size:.78rem;padding:2px 8px;border-radius:999px;border:1px solid #ddd;background:#fff;color:#333;margin-right:6px}
.badge.ok{border-color:#10b981;color:#065f46;background:#ecfdf5}
.badge.warn{border-color:#f59e0b;color:#7c2d12;background:#fffbeb}
.badge.muted{border-color:#e5e7eb;color:#6b7280;background:#f9fafb}
.hero{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:stretch;margin-bottom:28px}
.hero .img{border-radius:18px;overflow:hidden;border:1px solid #eee;box-shadow:var(--shadow)}
.hero .img img{width:100%;height:100%;object-fit:cover;display:block}
.hero .content{padding:4px 6px}
.hero h1{margin:.2em 0 .2em 0;font-size:2rem}
.hero .tags{margin-top:8px}
.section{margin:28px 0}
h2{margin:.3em 0 .6em 0}
.kv{display:flex;flex-wrap:wrap;gap:8px}
.kv .chip{border:1px solid #eee;border-radius:999px;padding:8px 12px;background:#fff;box-shadow:var(--shadow);display:inline-flex;align-items:center;gap:8px}
.kv .chip:hover{background:#fafafa}
.kv .chip .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}
.list-ingredients{list-style:none;margin:0;padding:0}
.list-ingredients li{display:flex;justify-content:space-between;border-bottom:1px dashed #eee;padding:8px 0}
.input, select, textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e5e7eb;outline:none}
.input:focus, select:focus, textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--ring)}
label{font-weight:600;font-size:.9rem;margin:8px 0 6px 0;display:block}
.btn{display:inline-block;padding:10px 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn:hover{filter:brightness(0.98)}
.form-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}
.form-grid .full{grid-column:1/-1}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid #eee;text-align:left}
.site-footer{border-top:1px solid #eee;padding:18px 24px;text-align:center;color:var(--muted)}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;z-index:50}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:80vh;border-radius:12px;box-shadow:var(--shadow)}
.small{font-size:.9rem;color:var(--muted)}
@media (max-width:840px){
  .hero{grid-template-columns:1fr}
}

/* === Uniform crop for hero images === */
.media-fixed{
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #eaeaea;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid #eee;
  box-shadow: var(--shadow);
}
.media-fixed img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Optional: tighten card media to match exactly */
.card .media{ aspect-ratio: 4 / 3; object-fit: cover; }
