/* =========================================================
   1YearChef — Global Design System (site.css)
   ========================================================= */

/* ---------- CSS Variables ---------- */
:root{
  --brand:#222;
  --text:#222;
  --muted:#666;
  --bg:#fff;
  --line:#e6e6e6;

  --primary:#18a058;
  --primary-ink:#fff;

  --chip:#f5f5f5;
  --chip-active:#e9f7ef;
  --chip-border:#ddd;

  --shadow:0 6px 18px rgba(0,0,0,.06);
  --radius:14px;
}

/* ---------- Reset / Base ---------- */
*{box-sizing:border-box}
html,body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
:focus-visible{outline:2px solid #0ea5e9;outline-offset:2px;border-radius:8px}

/* ---------- Header ---------- */
.site-header{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-weight:700;font-size:20px}
.main-nav{position:relative}
.menu{display:flex;gap:20px;list-style:none;margin:0;padding:0}
.menu a{padding:10px 8px;border-radius:8px;color:#444}
.menu a.is-active{background:var(--chip-active);color:#0e6a3a}
.hamburger{display:none;background:none;border:0;padding:8px;cursor:pointer}
.hamburger-line{display:block;width:22px;height:2px;background:#333;margin:4px 0;border-radius:2px}
.sr-only{position:absolute;left:-9999px}
@media (max-width:780px){
  .menu{display:none;position:absolute;right:0;top:56px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;min-width:180px;flex-direction:column;box-shadow:var(--shadow)}
  .hamburger{display:block}
  .menu.open{display:flex}
}

/* ---------- Page hero ---------- */
.page-hero{padding:28px 0;border-bottom:1px solid var(--line);background:#fff}
.page-title{margin:0 0 6px;font-size:28px;line-height:1.2}
.page-subtitle{margin:0;color:var(--muted);font-size:15px}

/* ---------- Filters ---------- */
.filters{padding:16px 0;border-bottom:1px solid var(--line);background:#fff}
.filters-form{display:flex;flex-direction:column;gap:12px}
.filters-row{display:grid;grid-template-columns:1fr 220px;gap:12px}
.input-wrap{display:flex;flex-direction:column;gap:6px}
.input-label{font-size:12px;color:var(--muted)}
.input,.select{height:40px;border:1px solid var(--line);border-radius:10px;padding:0 12px;font-size:14px;background:#fff;color:var(--text)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{border:1px solid var(--chip-border);background:var(--chip);border-radius:999px;height:34px;padding:0 14px;font-size:13px;display:inline-flex;align-items:center;cursor:pointer;transition:filter .15s ease}
.chip:hover{filter:brightness(.98)}
.chip--active{background:var(--chip-active);border-color:#b6e5cc}
.filters-actions{display:flex;gap:8px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 16px;border-radius:10px;border:1px solid var(--line);cursor:pointer;font-weight:600;background:#fff;color:#333;transition:filter .15s ease,transform .02s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}
.btn-light{background:#fff;color:#333}

/* ---------- Cards (generic) ---------- */
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1024px){.grid.cols-4{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden;transition:box-shadow .18s ease}
@media (hover:hover){.card:hover{box-shadow:var(--shadow)}}
.card-media{aspect-ratio:16/9;background:#fafafa;object-fit:cover;width:100%}
.card-body{flex:1;display:flex;flex-direction:column;gap:8px;padding:12px 12px 10px}
.card-title{margin:0;font-size:16px;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{color:var(--muted);font-size:12px;line-height:1.2;display:flex;gap:10px;flex-wrap:wrap;min-height:16px}
.card-desc{margin:0;font-size:13px;line-height:1.45;color:#444;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-footer{margin-top:auto;display:flex;justify-content:center;padding:12px;border-top:1px solid var(--line)}
.card-footer .btn-primary{width:40%;min-height:36px;display:inline-flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;text-decoration:none}
.card .btn{height:36px;min-width:120px}

/* ---------- Empty & Pagination ---------- */
.empty{padding:24px;text-align:center;color:#666;border:1px dashed var(--line);border-radius:12px;background:#fafafa}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:22px;flex-wrap:wrap}
.pagination button{padding:6px 10px;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;min-width:34px;font-weight:600}
.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* =========================================================
   MODERN FOOTER — Top CTA Card + Minimal Links (Mobile-first)
   Works with your existing footer HTML.
   ========================================================= */
.site-footer{
  background:linear-gradient(180deg,#f7faf8 0%, #ffffff 100%);
  border-top:1px solid var(--line);
  margin-top:44px;
  color:var(--text);
}
.footer-inner{padding:32px 0 18px}
.footer-cols{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:minmax(0,auto);
  grid-auto-flow:dense;
  gap:20px;
  align-items:start;
}
/* Subscribe CTA (last child in markup is floated up) */
.footer-cols > div:last-child{
  grid-column:1 / -1;
  grid-row:1;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:24px 16px;
  text-align:center;
}
.footer-cols > div:last-child h4{
  margin:0 0 6px;
  font-size:24px;
  font-weight:800;
  letter-spacing:-0.01em;
  color:var(--brand);
}
.footer-cols > div:last-child p{
  margin:0 0 14px;
  color:var(--muted);
  line-height:1.55;
  font-size:14px;
}
.subscribe-form{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  margin-top:4px;
}
.subscribe-form .input{
  width:min(460px, 100%);
  height:46px;
  border:1px solid var(--line);
  border-radius:999px;
  padding:0 14px;
  font-size:15px;
  background:#fff;
  color:var(--text);
}
.subscribe-form .btn-primary{
  height:46px;
  padding:0 22px;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.2px;
}
/* About (first child) & Explore (nav) row */
.footer-cols > div:first-child{
  grid-column:1 / 7;
  grid-row:2;
  text-align:left;
}
.footer-cols > nav{
  grid-column:7 / -1;
  grid-row:2;
  text-align:right;
}
.footer-cols h4{
  margin:0 0 8px;
  font-size:13px;
  font-weight:700;
  color:var(--brand);
  text-transform:uppercase;
  letter-spacing:.04em;
}
.footer-cols p{margin:0;color:var(--muted);line-height:1.6}
.footer-cols ul{
  list-style:none;
  margin:6px 0 0;
  padding:0;
  display:flex;
  gap:14px;
  justify-content:flex-end;
}
.footer-cols ul a{
  color:#2b2b2b;
  font-weight:600;
  transition:color .15s ease,opacity .15s ease;
}
.footer-cols ul a:hover{color:var(--primary)}
.footer-meta{
  border-top:1px solid var(--line);
  margin-top:20px;
  padding-top:14px;
  font-size:13px;
  color:var(--muted);
  text-align:center;
}
@media (max-width:900px){
  .footer-cols > div:first-child{grid-column:1 / -1;text-align:center}
  .footer-cols > nav{grid-column:1 / -1;text-align:center}
  .footer-cols ul{justify-content:center;flex-wrap:wrap}
}
@media (max-width:780px){
  .footer-inner{padding:24px 0 14px}
  .footer-cols{gap:16px}
  .footer-cols > div:last-child{padding:20px 14px}
  .subscribe-form{flex-direction:column;align-items:stretch}
  .subscribe-form .input{width:100%}
  .subscribe-form .btn-primary{width:100%}
}

/* ---------- Utilities ---------- */
.hide{display:none!important}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}
.text-center{text-align:center!important}
.nowrap{white-space:nowrap!important}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* =========================================================
   Recipes — Photo-first Cards (SCOPED & NON-DESTRUCTIVE)
   Only applies inside a section/container with .recipes
   ========================================================= */

.recipes .card.recipe{
  position:relative;
  border:none;
  overflow:hidden;
  background:#000;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}
@media (hover:hover){
  .rec ipes .card.recipe:hover{ /* keep hover nice but isolated */
    transform:translateY(-2px);
    box-shadow:0 8px 22px rgba(0,0,0,.15);
  }
}
.recipes .card.recipe .media{
  position:relative;
  display:block;
  width:100%;
  aspect-ratio:4/3; /* consistent, taller than lessons */
  background:#111;
  overflow:hidden;
}
.recipes .card.recipe img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.08) contrast(1.05);
  transition:transform .4s ease;
}
.recipes .card.recipe:hover img{ transform:scale(1.05); }

.recipes .card.recipe .grad{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 38%, rgba(0,0,0,.6) 100%);
  pointer-events:none;
  z-index:1;
}

.recipes .card.recipe .chipbar{
  position:absolute; left:12px; top:12px; z-index:2;
  display:flex; flex-wrap:wrap; gap:8px;
}
/* Keep global .chip for filters; ONLY override inside recipe cards */
.recipes .card.recipe .chip{
  font-size:12px;
  font-weight:600;
  line-height:1;
  color:#fff;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.25);
  padding:6px 10px;
  border-radius:999px;
  backdrop-filter:blur(4px);
  text-transform:uppercase;
  letter-spacing:.03em;
}

.recipes .card.recipe .titlebar{
  position:absolute;
  left:14px; right:14px; bottom:14px; z-index:2;
  color:#fff;
}
.recipes .card.recipe h3{
  margin:0 0 6px;
  font-size:clamp(17px, 3.8vw, 20px);
  line-height:1.3;
  font-weight:700;
  text-shadow:0 2px 10px rgba(0,0,0,.65);
}
.recipes .card.recipe .desc{
  font-size:13px;
  line-height:1.45;
  color:rgba(255,255,255,.85);
  margin:0 0 8px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.recipes .card.recipe .actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.recipes .card.recipe .btn{
  border:1px solid rgba(255,255,255,.25);
  background:rgba(0,0,0,.4);
  backdrop-filter:blur(5px);
  color:#fff;
  font-weight:600;
  font-size:13px;
  padding:6px 12px;
  border-radius:999px;
  transition:background .2s ease;
}
.recipes .card.recipe .btn:hover{
  background:rgba(255,255,255,.15);
  filter:brightness(1.1);
}

/* Optional rating badge for the recipe tile only */
.recipes .card.recipe .badge{
  margin-left:auto;
  font-size:12px;
  font-weight:700;
  color:#fff;
  background:var(--primary);
  padding:6px 10px;
  border-radius:999px;
}

/* Make Explore links sit in one horizontal row on desktop */
.footer-nav--align-right { text-align: right; }
.footer-grid--home { grid-template-columns: 1.2fr auto; } /* keep right col tight */

.footer-nav--align-right .menu{
  display:flex;
  gap:24px;
  justify-content:flex-end;
  align-items:center;
  flex-wrap:nowrap;        /* don't stack on desktop */
  list-style:none;
  margin:0;
  padding:0;
}
.footer-nav--align-right li{ margin:0; }
.footer-nav--align-right a{ white-space:nowrap; }

/* Mobile: allow wrapping + left align (same as home) */
@media (max-width:780px){
  .footer-nav--align-right { text-align:left; }
  .footer-nav--align-right .menu{
    justify-content:flex-start;
    flex-wrap:wrap;
    gap:10px 16px;
  }
}