/* =========================================================
   Spargelhof Simianer — Startseite (Homepage) styles
   Hero · Season Strip · Intro · Categories · Showcase · Stands · Location
   ========================================================= */

/* ===== Hero ============================================== */
.hero{
  position:relative;
  min-height:90vh;
  min-height:90svh;
  color:#fff;
  isolation:isolate;
  overflow:hidden;
  padding-top:140px;
  padding-bottom:90px;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.hero-bg{
  position:absolute; inset:0; z-index:-2;
  background:url("../assets/flyover.jpg") center 35% / cover no-repeat;
  background:image-set(
    url("../assets/flyover.avif") type("image/avif"),
    url("../assets/flyover.webp") type("image/webp"),
    url("../assets/flyover.jpg") type("image/jpeg")
  ) center 35% / cover no-repeat;
  transform:scale(1.06);
  animation:slowPush 22s ease-in-out infinite alternate;
}
@keyframes slowPush{
  0%{transform:scale(1.06) translate3d(0,0,0)}
  100%{transform:scale(1.12) translate3d(-1.5%, -1%, 0)}
}
.hero-grad{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(15,46,26,.55) 0%, rgba(15,46,26,.15) 30%, rgba(15,46,26,.05) 55%, rgba(15,46,26,.78) 100%),
    radial-gradient(80% 60% at 20% 80%, rgba(15,46,26,.55) 0%, transparent 60%);
}

.hero-inner{
  display:grid;
  grid-template-columns: 1fr;
  gap:60px;
  align-items:end;
  max-width:min(100%, 1100px);
}
.hero-headline{
  margin:0;
  color:#fff;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(60px, 10vw, 168px);
  line-height:0.95;
  letter-spacing:-0.025em;
  text-wrap:balance;
  text-shadow:
    0 1px 2px  rgba(15,46,26,.45),
    0 4px 18px rgba(15,46,26,.28);
}
.hero-headline em{font-style:italic; color:#dfe9d3}
.hero-sub{
  margin-top:24px;
  max-width:46ch;
  font-size:clamp(16px, 1.4vw, 19px);
  line-height:1.55;
  color:rgba(255,255,255,.95);
  text-shadow:
    0 1px 2px rgba(15,46,26,.7),
    0 2px 8px rgba(15,46,26,.5),
    0 4px 22px rgba(15,46,26,.4);
}
.hero-actions{
  margin-top:36px;
  display:flex; flex-wrap:wrap; gap:14px;
}

.hero-side{
  display:flex; flex-direction:column; align-items:flex-end; gap:14px;
}
.hero-card{
  display:flex; flex-direction:column; gap:6px;
  padding:18px 22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  border-radius:16px;
  min-width:240px;
}
.hero-card--alt{background:rgba(255,255,255,.06)}
.hero-card .lbl{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
  font-weight:600;
}
.hero-card .val{
  font-family:var(--serif);
  font-size:24px;
  line-height:1.1;
  color:#fff;
  letter-spacing:-0.01em;
}
.hero-card .val small{
  display:block;
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.04em;
  color:rgba(255,255,255,.65);
  margin-top:4px;
  font-weight:500;
}
.hero-meta{
  display:flex; flex-direction:column; gap:6px;
  padding:14px 18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  border-radius:14px;
  font-size:12.5px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(255,255,255,.85);
}
.hero-meta strong{color:#fff; letter-spacing:.04em}

.hero-chip{
  position:absolute;
  top:120px; right:max(40px, calc((100vw - var(--maxw))/2 + 20px));
  display:inline-flex; align-items:center; gap:10px;
  padding:9px 16px 9px 12px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(10px);
  border-radius:999px;
  font-size:12.5px;
  letter-spacing:.08em;
  color:#fff;
  z-index:1;
}
.hero-chip .dot{
  width:8px; height:8px; border-radius:50%;
  background:#80e0a0;
  box-shadow:0 0 0 0 rgba(128,224,160,.7);
  animation:pulse 2.2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(128,224,160,.6)}
  70%{box-shadow:0 0 0 10px rgba(128,224,160,0)}
  100%{box-shadow:0 0 0 0 rgba(128,224,160,0)}
}

.hero-scroll{
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.hero-scroll .line{
  width:1px; height:44px; background:rgba(255,255,255,.6);
  animation:lineGrow 2.4s ease-in-out infinite;
  transform-origin:top;
}
@keyframes lineGrow{
  0%,100%{transform:scaleY(.3); opacity:.4}
  50%{transform:scaleY(1); opacity:1}
}

@media (max-width:900px){
  .hero{padding-bottom:130px}
  .hero-inner{grid-template-columns:1fr; gap:30px}
  .hero-headline br{display:block}
  .hero-chip{display:none}
}

/* ===== Intro / Welcome =================================== */
.intro{
  padding:clamp(80px, 12vw, 140px) 0;
  background:var(--paper);
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.intro-bg{
  position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(60% 80% at 8% 18%, var(--green-50) 0%, transparent 55%),
    radial-gradient(40% 50% at 100% 95%, rgba(217,68,46,.08) 0%, transparent 60%),
    linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
  opacity:.9;
}
.intro::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(1px 1px at 18% 24%, rgba(15,46,26,.16) 50%, transparent 51%),
    radial-gradient(1px 1px at 78% 14%, rgba(15,46,26,.12) 50%, transparent 51%),
    radial-gradient(1px 1px at 32% 78%, rgba(217,68,46,.18) 50%, transparent 51%),
    radial-gradient(1px 1px at 88% 62%, rgba(15,46,26,.1) 50%, transparent 51%);
  background-size:600px 600px;
  pointer-events:none;
}
.intro-watermark{
  position:absolute;
  z-index:-1;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(180px, 26vw, 420px);
  line-height:.85;
  letter-spacing:-0.04em;
  color:var(--green-700);
  opacity:.045;
  right:-2vw; bottom:-3vw;
  pointer-events:none;
  user-select:none;
  white-space:nowrap;
}
.intro-decor{
  position:absolute;
  z-index:-1;
  top:8%; right:max(20px, 5vw);
  width:clamp(120px, 12vw, 200px);
  height:auto;
  color:var(--green-600);
  opacity:.4;
  pointer-events:none;
  animation:introFloat 9s ease-in-out infinite alternate;
  transform-origin:50% 100%;
}
@keyframes introFloat{
  0%{transform:translateY(0) rotate(-1deg)}
  100%{transform:translateY(-12px) rotate(1.5deg)}
}

.intro-grid{
  display:grid;
  grid-template-columns: .85fr 1.15fr;
  gap:80px;
  align-items:start;
  position:relative;
}
.intro-head{
  position:sticky;
  top:120px;
  display:flex; flex-direction:column;
  gap:20px;
  align-items:center;
  text-align:center;
}
.intro-logo{
  display:grid; place-items:center;
  width:88px; height:88px;
  border-radius:50%;
  background:#fff;
  box-shadow:
    0 22px 50px -22px rgba(15,46,26,.3),
    0 0 0 1px var(--line);
  position:relative;
  margin-bottom:4px;
  animation:introBob 6s ease-in-out infinite alternate;
}
.intro-logo::before{
  content:"";
  position:absolute; inset:7px;
  border-radius:50%;
  border:1px dashed rgba(15,46,26,.18);
  pointer-events:none;
}
.intro-logo img{
  width:60%; height:60%;
  object-fit:contain;
}
@keyframes introBob{
  0%{transform:translateY(0)}
  100%{transform:translateY(-6px)}
}

.intro-headline{
  font-size:clamp(40px, 5.6vw, 86px);
  line-height:.98;
  letter-spacing:-0.02em;
  margin:0;
}
.intro-headline em{font-style:italic; color:var(--green-700)}
.intro-tag{
  margin:6px 0 0;
  font-family:var(--serif);
  font-style:italic;
  font-size:18px;
  line-height:1.4;
  color:var(--green-700);
  letter-spacing:.005em;
}

.intro-body{
  font-size:clamp(17px, 1.5vw, 21px);
  line-height:1.7;
  color:#2a3a30;
  max-width:62ch;
}
.intro-body em{font-style:italic; color:var(--green-700)}
.intro-dropcap{
  font-family:var(--serif);
  font-style:italic;
  font-size:5em;
  line-height:.82;
  color:var(--green-700);
  float:left;
  padding:.08em .14em 0 0;
  margin-bottom:-.08em;
}
.intro-body p + p{margin-top:1.1em}
.intro-signature{
  margin-top:42px;
  padding-top:24px;
  display:flex; align-items:center; gap:22px;
  border-top:1px solid var(--line);
}
.intro-sig-line{
  width:60px; height:1px;
  background:var(--green-700);
  flex:0 0 auto;
}
.intro-signature .sig{
  font-family:var(--serif); font-style:italic;
  font-size:30px;
  line-height:1.1;
  color:var(--green-700);
  letter-spacing:-0.01em;
}
.intro-signature .sig-sub{
  font-size:12px;
  color:var(--ink-muted);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
  margin-top:4px;
}

@media (max-width:900px){
  .intro-grid{grid-template-columns:1fr; gap:36px}
  .intro-head{position:static}
  .intro-decor{display:none}
  .intro-watermark{font-size:120px}
}

/* ===== Categories ======================================== */
.cats{
  background:var(--green-800);
  color:#f1ecde;
  padding:clamp(80px, 12vw, 140px) 0;
  position:relative;
  overflow:hidden;
}
.cats::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 80% at 90% -10%, rgba(63,138,85,.25) 0%, transparent 60%),
    radial-gradient(50% 60% at -10% 110%, rgba(217,68,46,.18) 0%, transparent 60%);
  pointer-events:none;
}
.cats-header{
  display:flex; justify-content:space-between; align-items:end;
  gap:40px; margin-bottom:60px;
  position:relative;
}
.cats-header .eyebrow{color:#cbd9c8}
.cats-header .eyebrow::before{background:#cbd9c8}
.cats-title{
  font-family:var(--serif);
  font-size:clamp(36px, 5vw, 72px);
  line-height:1;
  margin-top:18px;
  color:#fff;
  letter-spacing:-0.02em;
  max-width:18ch;
}
.cats-lede{
  max-width:36ch;
  color:rgba(241,236,222,.78);
  font-size:16px;
  line-height:1.65;
}

.cat-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  position:relative;
}
.cat-card{
  position:relative;
  background:#fbf8f1;
  border-radius:var(--radius-l);
  overflow:hidden;
  color:var(--ink);
  display:flex; flex-direction:column;
  min-height:520px;
  transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s ease;
  isolation:isolate;
}
.cat-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lift)}
.cat-media{
  position:relative;
  height:300px;
  overflow:hidden;
  background:#dcd4c1;
}
.cat-media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.2s ease;
}
.cat-media picture{display:block; width:100%; height:100%}
.cat-media picture img{display:block}
.cat-card:hover .cat-media img{transform:scale(1.06)}
.cat-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(15,46,26,.25) 100%);
}
.cat-tag{
  position:absolute; top:18px; left:18px;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  padding:6px 12px;
  background:rgba(251,248,241,.92);
  border-radius:999px;
  color:var(--green-800);
  font-weight:600;
}
.cat-body{
  padding:28px 28px 32px;
  display:flex; flex-direction:column; gap:14px;
  flex:1;
}
.cat-num{
  font-family:var(--serif); font-style:italic;
  color:var(--green-600);
  font-size:18px;
  display:flex; align-items:center; gap:10px;
}
.cat-num::after{content:""; flex:1; height:1px; background:var(--line)}
.cat-title{
  font-family:var(--serif);
  font-size:42px;
  line-height:1;
  letter-spacing:-0.02em;
}
.cat-desc{
  color:#3a4a40;
  font-size:15px;
  line-height:1.55;
}
.cat-foot{
  margin-top:auto; padding-top:18px;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  border-top:1px solid var(--line);
}
.cat-meta{display:flex; flex-wrap:wrap; gap:6px}
.cat-meta span{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-muted);
}
.cat-meta span + span::before{content:"·  "}
.cat-arrow{
  display:grid; place-items:center;
  width:44px; height:44px; border-radius:50%;
  background:var(--green-700); color:#fff;
  transition:transform .3s ease, background .3s ease;
  flex:0 0 auto;
}
.cat-card:hover .cat-arrow{background:var(--green-800); transform:translate(2px,-2px)}
.cat-arrow svg{width:18px; height:18px}

.cat-card--featured{grid-row:span 1; background:var(--cream-2)}
.cat-card--featured .cat-media{height:340px}

@media (max-width:980px){
  .cat-grid{grid-template-columns:1fr}
  .cat-card{min-height:auto}
  .cats-header{flex-direction:column; align-items:flex-start; gap:18px}
}

/* ===== Showcase ========================================== */
.showcase{
  background:var(--paper);
  padding:clamp(80px, 12vw, 160px) 0;
}
.showcase-grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr;
  gap:60px;
  align-items:center;
}
.showcase-media{
  position:relative;
  border-radius:var(--radius-l);
  overflow:hidden;
  aspect-ratio: 5/4;
  box-shadow:var(--shadow-soft);
}
.showcase-media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.2s ease;
}
.showcase:hover .showcase-media img{transform:scale(1.04)}
.showcase-badge{
  position:absolute; bottom:24px; left:24px;
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 16px;
  background:rgba(251,248,241,.94);
  backdrop-filter:blur(8px);
  border-radius:999px;
  font-size:13px;
  color:var(--green-800);
  font-weight:600;
}
.showcase-badge .swatch{width:10px; height:10px; border-radius:50%; background:var(--accent)}
.showcase-copy h3{
  font-family:var(--serif);
  font-size:clamp(32px, 4.5vw, 64px);
  line-height:1.02;
  letter-spacing:-0.02em;
  margin-bottom:24px;
}
.showcase-copy h3 em{color:var(--accent); font-style:italic}
.showcase-copy p{
  font-size:17px; line-height:1.7;
  color:#2a3a30;
  max-width:50ch;
}
.showcase-list{
  list-style:none; padding:0; margin:32px 0 0;
  display:grid; gap:14px;
}
.showcase-list li{
  display:flex; gap:14px; align-items:flex-start;
  padding:14px 0;
  border-top:1px solid var(--line);
  font-size:15px;
}
.showcase-list li:last-child{border-bottom:1px solid var(--line)}
.showcase-list .k{
  font-family:var(--serif); font-style:italic;
  color:var(--green-700);
  min-width:90px;
}
.showcase-list-extras{
  padding:12px 0;
  font-size:13.5px;
  color:var(--ink-muted);
  line-height:1.55;
}
.showcase-list-extras .k{font-size:14.5px; opacity:.85}
.showcase-list-extras em{
  font-family:var(--serif);
  font-style:italic;
  color:var(--green-700);
  font-size:15px;
}
@media (max-width:900px){
  .showcase-grid{grid-template-columns:1fr; gap:30px}
}

@media (max-width:900px){
  .stands-grid{grid-template-columns:1fr}
}
