/* home.css — hero + home section styles */

/* tint helpers — fixed category colors (independent of global accent) */
[data-tint="oliv"]      { --tint: #4d5a3c; --tint-bg: #eef0e8; }
[data-tint="stahlblau"] { --tint: #2f4f68; --tint-bg: #e7eef3; }
[data-tint="sandgrau"]  { --tint: #6a5f4c; --tint-bg: #f0ede5; }
[data-tint="anthrazit"] { --tint: #3a4045; --tint-bg: #ececef; }

/* ---------- Hero ---------- */
.hero { background:
    radial-gradient(120% 80% at 85% -10%, var(--accent-100), transparent 60%),
    var(--paper-2);
  border-bottom: 1px solid var(--line-soft); }
.hero__grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem);
  align-items: center; padding-block: clamp(2.75rem, 2rem + 4vw, 5.5rem);
}
.hero__title { font-size: var(--fs-mega); letter-spacing: -0.025em; margin: 1rem 0 1.1rem; }
.hero__lead { font-size: clamp(1.05rem, 1rem + 0.4vw, 1.22rem); color: var(--ink-2); max-width: 46ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.8rem; }
.hero__stats { display: flex; gap: clamp(1.5rem, 1rem + 2vw, 3rem); margin: 2.4rem 0 0; padding-top: 1.6rem; border-top: 1px solid var(--line); }
.hero__stats div { display: flex; flex-direction: column; }
.hero__stats dt { font-size: 2rem; font-weight: 700; line-height: 1; letter-spacing: -0.02em; color: var(--accent-ink); }
.hero__stats dd { margin: .35rem 0 0; font-size: var(--fs-cap); color: var(--ink-3); }

.hero__media { position: relative; }
.hero__img { width: 100%; aspect-ratio: 4 / 5; display: block; }
.hero__media-tag {
  position: absolute; left: -14px; bottom: 26px;
  display: flex; align-items: center; gap: .7rem;
  padding: .7rem .9rem; background: var(--paper); box-shadow: var(--sh-lg);
}
.hero__media-tag svg { color: var(--accent); flex-shrink: 0; }
.hero__media-tag strong { display: block; font-size: var(--fs-ui); }
.hero__media-tag span.muted { font-size: var(--fs-cap); }

@media (max-width: 860px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__media { order: -1; max-width: 420px; }
  .hero__img { aspect-ratio: 16 / 10; }
}

/* ---------- Quick-access tiles ---------- */
.tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(.75rem, .4rem + 1vw, 1.1rem); }
.tile {
  display: grid; grid-template-columns: auto 1fr; grid-template-rows: auto auto; gap: .15rem 1rem;
  text-align: left; padding: 1.25rem 1.3rem;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-md);
  box-shadow: var(--sh-sm); transition: border-color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
}
.tile:hover { border-color: var(--accent-200); box-shadow: var(--sh-md); transform: translateY(-2px); }
.tile:active { transform: translateY(0); }
.tile__icon {
  grid-row: 1 / 3; align-self: start; display: inline-flex; padding: .6rem;
  background: var(--accent-100); color: var(--accent-ink); border-radius: var(--r-sm);
}
.tile__body { display: flex; flex-direction: column; gap: .2rem; min-width: 0; }
.tile__top { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.tile__label { font-weight: 600; font-size: 1.05rem; color: var(--ink); }
.tile__arrow { color: var(--ink-4); transition: transform var(--t-fast), color var(--t-fast); }
.tile:hover .tile__arrow { color: var(--accent); transform: translateX(3px); }
.tile__desc { font-size: var(--fs-ui); color: var(--ink-2); }
.tile__meta { grid-column: 2; margin-top: .7rem; font-size: var(--fs-meta); color: var(--ink-4); }

@media (max-width: 820px) { .tiles { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .tiles { grid-template-columns: 1fr; } }

/* ---------- Info ---------- */
.info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(.85rem, .5rem + 1vw, 1.4rem); }
.info-card { padding: 1.6rem 1.5rem; }
.info-card__icon { display: inline-flex; padding: .65rem; background: var(--accent-100); color: var(--accent-ink); border-radius: var(--r-sm); margin-bottom: 1.1rem; }
.info-card h3 { font-size: var(--fs-h3); margin-bottom: .6rem; }
.info-card p { font-size: var(--fs-ui); color: var(--ink-2); }
@media (max-width: 820px) { .info-grid { grid-template-columns: 1fr; } }

/* ---------- Teaser heads ---------- */
.teaser-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.teaser-head .section-head { margin-bottom: clamp(1.2rem, 1rem + 1vw, 2rem); }

/* ---------- Category cards ---------- */
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(.85rem, .5rem + 1vw, 1.4rem); }
.cat-card {
  position: relative; text-align: left; padding: 1.5rem 1.4rem 1.3rem; overflow: hidden;
  transition: border-color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
}
.cat-card:hover { border-color: var(--tint); box-shadow: var(--sh-md); transform: translateY(-2px); }
.cat-card__bar { position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--tint); }
.cat-card__icon { display: inline-flex; padding: .6rem; background: var(--tint-bg); color: var(--tint); border-radius: var(--r-sm); margin-bottom: 1rem; }
.cat-card h3 { font-size: var(--fs-h3); margin-bottom: .5rem; }
.cat-card p { font-size: var(--fs-cap); color: var(--ink-2); min-height: 2.6em; }
.cat-card__foot { display: inline-flex; align-items: center; gap: .25rem; margin-top: 1rem; font-size: var(--fs-meta); color: var(--tint); font-weight: 500; }
@media (max-width: 900px) { .cat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .cat-grid { grid-template-columns: 1fr; } }

/* ---------- Plan teaser split ---------- */
.teaser-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: center; }
.check-list { display: flex; flex-direction: column; gap: .7rem; margin: 1.4rem 0 1.8rem; }
.check-list li { display: flex; align-items: center; gap: .6rem; font-size: var(--fs-ui); color: var(--ink-2); }
.check-list li svg { color: var(--accent); flex-shrink: 0; }
.week-preview { display: flex; flex-direction: column; gap: .7rem; }
.week-preview__row { display: flex; align-items: center; gap: 1rem; padding: .9rem 1.1rem; position: relative; }
.week-preview__row::before { content: ""; position: absolute; left: 0; top: 8px; bottom: 8px; width: 3px; background: var(--tint); border-radius: 0 2px 2px 0; }
.week-preview__kw { font-size: var(--fs-cap); font-weight: 700; color: var(--tint); min-width: 56px; }
.week-preview__body { display: flex; flex-direction: column; flex: 1; line-height: 1.2; }
.week-preview__body strong { font-size: var(--fs-ui); }
.week-preview__body .muted { font-size: var(--fs-cap); }
@media (max-width: 820px) { .teaser-split { grid-template-columns: 1fr; } }

/* ---------- Shop teaser ---------- */
.shop-teaser-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(.85rem, .5rem + 1vw, 1.4rem); }
.shop-mini { text-align: left; padding: 0; overflow: hidden; transition: border-color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast); }
.shop-mini:hover { border-color: var(--tint); box-shadow: var(--sh-md); transform: translateY(-2px); }
.shop-mini__img { width: 100%; aspect-ratio: 16 / 9; display: block; border-bottom: 1px solid var(--line-soft); }
.shop-mini__body { display: block; padding: 1.1rem 1.2rem 1.3rem; }
.shop-mini__row { display: flex; align-items: center; justify-content: space-between; gap: .5rem; margin-bottom: .5rem; }
.shop-mini__row strong { font-size: 1.05rem; }
.shop-mini__desc { font-size: var(--fs-cap); display: block; min-height: 3.4em; }
.shop-mini__price { display: block; margin-top: .8rem; font-weight: 700; color: var(--ink); font-size: 1.05rem; }
@media (max-width: 820px) { .shop-teaser-grid { grid-template-columns: 1fr; } }
