/* ==========================================================================
   style.css
   Personalizzazione di Tabler per l'Archivio Ricette.
   Palette ispirata alla cucina: verde basilico come colore principale,
   terracotta bruciata come accento per le categorie, sfondo caldo e neutro.
   ========================================================================== */

:root {
  /* Palette */
  --recipe-bg: #faf7f2;
  --recipe-surface: #ffffff;
  --recipe-ink: #2b2622;
  --recipe-ink-soft: #6b6259;
  --recipe-green: #3f6b4a;
  --recipe-green-dark: #2f5138;
  --recipe-rust: #a8502e;
  --recipe-rust-soft: #f1e3da;
  --recipe-border: #e7e0d6;

  /* Override variabili Tabler */
  --tblr-primary: var(--recipe-green);
  --tblr-primary-rgb: 63, 107, 74;
  --tblr-link-color: var(--recipe-green);
  --tblr-link-hover-color: var(--recipe-green-dark);
  --tblr-body-bg: var(--recipe-bg);
  --tblr-body-color: var(--recipe-ink);
  --tblr-border-color: var(--recipe-border);
  --tblr-border-color-translucent: var(--recipe-border);
  --tblr-border-radius: 10px;
  --tblr-border-radius-lg: 14px;
  --tblr-card-border-radius: 14px;
  --tblr-font-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    "Helvetica Neue", Arial, sans-serif;
}

body {
  background-color: var(--recipe-bg);
}

a {
  color: var(--recipe-green);
}

/* --- Navbar -------------------------------------------------------------- */

.navbar {
  --tblr-navbar-bg: var(--recipe-surface);
  border-bottom: 1px solid var(--recipe-border);
}

.navbar-brand {
  font-weight: 700;
  color: var(--recipe-ink) !important;
}

.brand-mark {
  color: var(--recipe-green);
  display: inline-flex;
}

/* --- Hero pagina indice --------------------------------------------------- */

.index-hero-title {
  font-family: var(--tblr-font-serif);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--recipe-ink);
  margin-bottom: 0.5rem;
}

.index-hero-lead {
  font-size: 1.0625rem;
  max-width: 42rem;
}

/* --- Sezioni categoria ---------------------------------------------------- */

.category-title {
  font-family: var(--tblr-font-serif);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--recipe-ink);
  scroll-margin-top: 5rem;
}

.category-section:not(:first-child) {
  padding-top: 1.5rem;
  border-top: 1px solid var(--recipe-border);
}

/* --- Card ricetta nell'indice --------------------------------------------- */

.recipe-index-card {
  border: 1px solid var(--recipe-border);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
  color: var(--recipe-ink);
}

.recipe-index-card:hover,
.recipe-index-card:focus-visible {
  transform: translateY(-2px);
  box-shadow: var(--tblr-shadow-card-hover);
  border-color: var(--recipe-green);
}

.recipe-index-card-title {
  font-family: var(--tblr-font-serif);
  font-weight: 700;
  color: var(--recipe-ink);
  margin-bottom: 0.375rem;
}

/* --- Hero pagina ricetta --------------------------------------------------- */

.badge.bg-category {
  background-color: var(--recipe-rust-soft);
  color: var(--recipe-rust);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: 0.6875rem;
  padding: 0.4em 0.75em;
}

.recipe-title {
  font-family: var(--tblr-font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--recipe-ink);
  margin: 0.25rem 0 0.5rem;
}

.recipe-lead {
  font-size: 1.0625rem;
  max-width: 42rem;
}

.recipe-meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  background-color: var(--recipe-surface);
  border: 1px solid var(--recipe-border);
  border-radius: 100rem;
  padding: 0.375rem 0.875rem;
  font-size: 0.8125rem;
  color: var(--recipe-ink-soft);
}

.recipe-meta-chip svg {
  color: var(--recipe-green);
  flex-shrink: 0;
}

/* --- Card contenuti ricetta ------------------------------------------------ */

.recipe-card .card-header {
  background-color: transparent;
  border-bottom: 1px solid var(--recipe-border);
}

.recipe-card .card-title {
  font-family: var(--tblr-font-serif);
  color: var(--recipe-ink);
}

.recipe-card-cooking {
  background-color: var(--recipe-rust-soft);
  border-color: transparent;
}

.recipe-card-cooking .card-header {
  border-bottom-color: rgba(168, 80, 46, 0.2);
}

.cooking-info-list li {
  padding: 0.25rem 0;
}

/* --- Lista ingredienti (stile "lista della spesa") ------------------------ */

.ingredient-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.ingredient-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  line-height: 1.35;
}

.ingredient-check {
  flex-shrink: 0;
  width: 1.05rem;
  height: 1.05rem;
  margin-top: 0.15rem;
  border: 2px solid var(--recipe-green);
  border-radius: 4px;
}

/* --- Lista procedura (passi numerati) -------------------------------------- */

.step-list {
  list-style: none;
  counter-reset: step-counter;
  padding-left: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.step-item {
  position: relative;
  padding-left: 2.75rem;
  counter-increment: step-counter;
  line-height: 1.55;
}

.step-item::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: -0.1rem;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: var(--recipe-green);
  color: #fff;
  font-weight: 700;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.step-item:not(:last-child) {
  padding-bottom: 1.25rem;
  border-bottom: 1px dashed var(--recipe-border);
}

/* --- Footer ---------------------------------------------------------------- */

.footer {
  border-top: 1px solid var(--recipe-border);
  padding: 1.5rem 0;
  margin-top: 2rem;
}

/* --- Utility di accessibilita' / riduzione movimento ----------------------- */

@media (prefers-reduced-motion: reduce) {
  .recipe-index-card {
    transition: none;
  }
}
