/* Sabines Seifen – Bauernladen-inspirierte Startseite */
:root {
  --green: #5f8b2f;
  --green-dark: #3f6f1d;
  --green-deep: #2f5315;
  --green-soft: #edf5e6;
  --orange: #f19b22;
  --orange-dark: #d98211;
  --cream: #f8f6ee;
  --card: #ffffff;
  --ink: #26311f;
  --muted: #6f7568;
  --border: #e5e5dc;
  --shadow: 0 16px 40px rgba(38,49,31,.09);
  --shadow-strong: 0 28px 80px rgba(38,49,31,.16);
  --radius: 18px;
  --max: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at 8% -10%, rgba(95,139,47,.16), transparent 30rem), radial-gradient(circle at 96% 0%, rgba(241,155,34,.13), transparent 30rem), var(--cream);
  line-height: 1.55;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
.container { width: min(var(--max), calc(100% - 40px)); margin: 0 auto; }
.skip-link { position:absolute; left:-999px; top:12px; background:var(--green-dark); color:#fff; padding:10px 14px; border-radius:999px; z-index:1000; }
.skip-link:focus { left:12px; }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.94); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); box-shadow: 0 8px 24px rgba(38,49,31,.06); }
.header-inner { min-height: 74px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand { display:flex; align-items:center; gap:12px; text-decoration:none; font-weight:950; }
.brand-mark { width:46px; height:46px; border-radius:50%; background:var(--green); color:#fff; display:grid; place-items:center; box-shadow:0 12px 26px rgba(95,139,47,.25); }
.brand small { display:block; color:var(--muted); font-size:12px; font-weight:700; margin-top:-3px; }
nav { display:flex; gap:20px; }
nav a { text-decoration:none; font-weight:850; color:var(--ink); }
nav a:hover { color:var(--green); }
.top-cta, .primary, .secondary, .profile-link, .cart-button, .final-box a { display:inline-flex; align-items:center; justify-content:center; border-radius:999px; min-height:46px; padding:12px 18px; text-decoration:none; font-weight:950; transition: transform .18s ease, background .18s ease, box-shadow .18s ease; }
.top-cta, .primary { background:var(--green); color:#fff; box-shadow:0 14px 28px rgba(95,139,47,.24); }
.top-cta:hover, .primary:hover { transform:translateY(-2px); background:var(--green-dark); box-shadow:0 18px 40px rgba(95,139,47,.32); }
.secondary, .profile-link { background:#fff; color:var(--green-dark); border:1px solid var(--border); }
.hero { padding: 74px 0 42px; }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:44px; }
.eyebrow, .section-kicker { display:inline-flex; padding:8px 13px; border-radius:999px; background:var(--green-soft); color:var(--green-dark); font-size:14px; font-weight:950; }
h1 { max-width:760px; margin:20px 0 18px; font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif; font-size:clamp(44px, 7vw, 78px); line-height:.95; letter-spacing:-.055em; }
.lead { max-width:680px; margin:0 0 24px; color:#4c5543; font-size:clamp(18px,2.1vw,22px); }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.shop-note { margin-top:18px; max-width:620px; padding:14px 16px; background:#fff; border:1px solid var(--border); border-left:5px solid var(--orange); border-radius:16px; box-shadow:0 12px 32px rgba(38,49,31,.07); color:var(--muted); }
.shop-note strong { color:var(--green-dark); }
.trust-pills { display:flex; flex-wrap:wrap; gap:10px; margin-top:20px; }
.trust-pills span { padding:8px 12px; border-radius:999px; background:#fff; border:1px solid var(--border); color:var(--green-dark); font-weight:850; font-size:14px; }
.hero-photo { margin:0; position:relative; border-radius:28px; overflow:hidden; background:#fff; border:1px solid var(--border); box-shadow:var(--shadow-strong); }
.hero-photo img { width:100%; height:560px; object-fit:cover; object-position:center top; }
.hero-photo figcaption { position:absolute; left:18px; right:18px; bottom:18px; padding:14px 16px; border-radius:18px; background:rgba(255,255,255,.93); color:var(--green-dark); font-weight:950; box-shadow:0 12px 30px rgba(38,49,31,.12); }
.service-bar { padding: 14px 0 54px; }
.service-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.service-grid div { background:#fff; border:1px solid var(--border); border-radius:18px; padding:18px; box-shadow:var(--shadow); }
.service-grid strong { display:block; color:var(--green-dark); font-size:28px; line-height:1; }
.service-grid span { display:block; color:var(--muted); font-weight:750; margin-top:5px; }
.products-section { background: linear-gradient(180deg, #fff 0%, var(--cream) 100%); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:74px 0; }
.section-head { display:flex; justify-content:space-between; align-items:end; gap:30px; margin-bottom:26px; }
.section-head h2 { margin:12px 0 0; font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif; font-size:clamp(36px,4vw,56px); line-height:1; letter-spacing:-.04em; }
.section-head p { max-width:520px; color:var(--muted); margin:0; font-size:17px; }
.toolbar { display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:12px; margin-bottom:24px; padding:14px; background:#fff; border:1px solid var(--border); border-radius:18px; box-shadow:var(--shadow); }
.toolbar label { font-weight:950; color:var(--green-dark); }
.toolbar input { width:100%; min-height:48px; border:1px solid var(--border); border-radius:999px; padding:0 18px; font:inherit; outline:none; }
.toolbar input:focus { border-color:var(--green); box-shadow:0 0 0 4px rgba(95,139,47,.12); }
.product-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.product-card { background:#fff; border:1px solid var(--border); border-radius:18px; overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; position:relative; transition: transform .18s ease, box-shadow .18s ease; }
.product-card:hover { transform:translateY(-4px); box-shadow:0 24px 60px rgba(38,49,31,.14); }
.product-card::before { content:"Sabines Seifen"; position:absolute; z-index:2; top:12px; left:12px; padding:5px 9px; border-radius:999px; background:rgba(255,255,255,.95); border:1px solid var(--border); color:var(--green-dark); font-size:12px; font-weight:950; }
.product-image-link { display:block; background:#fff; border-bottom:1px solid var(--border); }
.product-image-link img { width:100%; aspect-ratio: 1.18 / .86; object-fit:contain; padding:12px; background:#fff; }
.product-body { flex:1; display:flex; flex-direction:column; gap:10px; padding:16px; }
.product-brand { color:var(--muted); font-size:13px; font-weight:900; }
.product-card h3 { margin:0; line-height:1.22; font-size:17px; color:var(--green-dark); }
.product-card h3 a { text-decoration:none; }
.product-card h3 a:hover { text-decoration:underline; text-underline-offset:4px; }
.product-meta { display:flex; justify-content:space-between; gap:10px; align-items:end; padding-top:8px; border-top:1px solid var(--border); color:var(--muted); }
.product-meta strong { color:var(--ink); font-size:20px; white-space:nowrap; }
.cart-button { margin-top:auto; width:100%; background:var(--orange); color:#fff; min-height:42px; box-shadow:0 10px 22px rgba(241,155,34,.24); }
.cart-button:hover { background:var(--orange-dark); transform:translateY(-2px); }
.benefits { padding:74px 0; }
.benefits-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.benefits article { background:#fff; border:1px solid var(--border); border-radius:22px; padding:26px; box-shadow:var(--shadow); }
.benefits span { display:inline-flex; width:42px; height:42px; border-radius:50%; align-items:center; justify-content:center; background:var(--green); color:#fff; font-weight:950; }
.benefits h3 { color:var(--green-dark); margin:16px 0 8px; font-size:22px; }
.benefits p { color:var(--muted); margin:0; }
.final-cta { padding:0 0 74px; }
.final-box { display:grid; grid-template-columns:1fr auto; align-items:center; gap:24px; padding:36px; border-radius:28px; color:#fff; background:linear-gradient(135deg,var(--green),var(--green-deep)); box-shadow:var(--shadow-strong); }
.final-box h2 { margin:0 0 8px; font-family:ui-serif, Georgia, serif; font-size:clamp(32px,4vw,52px); line-height:1; letter-spacing:-.04em; }
.final-box p { margin:0; color:rgba(255,255,255,.86); }
.final-box a { background:#fff; color:var(--green-dark); }
.contact-section { padding:0 0 74px; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.contact-card { background:#fff; border:1px solid var(--border); border-radius:22px; padding:26px; box-shadow:var(--shadow); }
.contact-card.highlight { border-top:5px solid var(--orange); }
.contact-card h2 { color:var(--green-dark); margin:0 0 12px; }
.contact-card p { color:var(--muted); }
.contact-card a { color:var(--green-dark); font-weight:950; }
footer { border-top:1px solid var(--border); padding:30px 0; color:var(--muted); background:#fff; }
.footer-inner { display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.product-card.is-hidden { display:none; }
@media (max-width: 1020px) { nav { display:none; } .hero-grid, .final-box, .contact-grid { grid-template-columns:1fr; } .hero-photo img { height:auto; aspect-ratio:1.1 / 1; } .product-grid { grid-template-columns:repeat(3,1fr); } .service-grid { grid-template-columns:repeat(2,1fr); } .toolbar { grid-template-columns:1fr; } .section-head { display:block; } .section-head p { margin-top:12px; } }
@media (max-width: 760px) { .container { width:min(var(--max), calc(100% - 28px)); } .header-inner { min-height:66px; } .top-cta { display:none; } .hero { padding-top:46px; } .product-grid, .benefits-grid, .service-grid { grid-template-columns:1fr; } .hero-actions .primary, .hero-actions .secondary, .profile-link, .final-box a { width:100%; } .products-section, .benefits { padding:54px 0; } }
