/* ============================================
   STUDIO VISUS — Index-Seite
   Ergänzende Styles (gemeinsame Basis in style.css)
   ============================================ */

/* ===== HERO (Index) ===== */
.idx-hero{
  max-width:1440px;
  margin:0 auto;
  padding:80px 48px 60px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:60px;
  align-items:center;
  position:relative;
}
.idx-hero-lead{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:21px;
  line-height:1.5;
  color:var(--ink-soft);
  max-width:48ch;
  margin-bottom:36px;
}
.idx-hero-cta{
  display:flex; gap:14px; flex-wrap:wrap;
}
.idx-hero-right{
  position:relative;
  aspect-ratio:4/5;
}
.idx-hero-img-main{
  width:100%; height:100%;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.idx-hero-img-main img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
.idx-hero-img-sub{
  position:absolute;
  bottom:-40px; left:-50px;
  width:42%;
  aspect-ratio:3/4;
  border:8px solid var(--paper);
  box-shadow:var(--shadow);
  overflow:hidden;
  border-radius: 150px;
}
.idx-hero-img-sub img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}

/* ===== TRUST BAR ===== */
.idx-trust{
  max-width:1440px;
  margin:40px auto 0;
  padding:32px 48px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:48px;
}
.idx-trust-item{
  display:flex; flex-direction:column; gap:6px;
}
.idx-trust-item .num{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:32px;
  color:var(--accent);
  line-height:1;
}
.idx-trust-item .label{
  font-size:13px;
  color:var(--ink-soft);
  line-height:1.4;
}

/* ===== SECTION BLOCKS ===== */
.idx-bloc{
  max-width:1440px;
  margin:0 auto;
  padding:100px 48px;
}
.idx-sec-title{
  font-family:'Fraunces', serif;
  font-weight:300;
  font-size:clamp(36px, 4.5vw, 64px);
  line-height:1.05;
  letter-spacing:-.015em;
  max-width:18ch;
}
.idx-sec-title em{font-style:italic; color:var(--accent); font-weight:400}

/* ===== INTRO ===== */
.idx-intro-inner{
  max-width:880px;
  margin:0 auto;
  text-align:center;
}
.idx-intro-text{
  font-size:18px;
  line-height:1.75;
  color:var(--ink-soft);
  max-width:62ch;
  margin:0 auto;
}
.idx-intro-text em{
  font-family:'Fraunces', serif;
  color:var(--accent);
  font-style:italic;
}

/* ===== FEATURE (Editorial — Neu im Atelier) =====
   Format-agnostisch: jedes Werk-Format (Hoch, Quer, Quadrat, Diptychon)
   sitzt mit Atemraum im Frame durch object-fit:contain + max-width/-height.
*/
.idx-feature-section{
  position:relative;
  max-width:1440px;
  margin:0 auto;
  padding:60px 48px 120px;
  overflow:hidden;
}
.idx-feature-eyebrow{
  position:relative;
  z-index:2;
  text-align:center;
  font-size:12px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:40px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
}
.idx-feature-eyebrow::before,
.idx-feature-eyebrow::after{
  content:"";
  width:36px;
  height:1px;
  background:var(--accent);
  opacity:.4;
}
/* Hintergrund-Werknummer */
.idx-feature-bignum{
  position:absolute;
  top:96px;
  left:50%;
  transform:translateX(-50%);
  font-family:'Fraunces', serif;
  font-weight:300;
  font-style:italic;
  font-size:clamp(180px, 28vw, 240px);
  line-height:.85;
  color:var(--paper-deep);
  letter-spacing:-.04em;
  pointer-events:none;
  user-select:none;
  z-index:0;
  white-space:nowrap;
}
.idx-feature-inner{
  position:relative;
  z-index:1;
}
/* Frame — formatfrei */
.idx-feature-frame{
  aspect-ratio:4/5;
  background:
    radial-gradient(ellipse at 30% 20%, #f9f4e8 0%, transparent 55%),
    radial-gradient(ellipse at 75% 80%, #ede3cf 0%, transparent 60%),
    linear-gradient(160deg, #f3ede0 0%, #e8dec8 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow:var(--shadow);
  margin:0 auto;
  max-width:600px;
  position:relative;
}
.idx-feature-frame img{
  max-width:86%;
  max-height:86%;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:
    drop-shadow(0 20px 30px rgba(33,29,24,.18))
    drop-shadow(0 6px 10px rgba(33,29,24,.12));
}
.idx-feature-frame-tag{
  position:absolute;
  top:18px;
  left:18px;
  font-family:'Inter Tight', sans-serif;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  background:rgba(247,242,232,.92);
  padding:7px 11px;
  backdrop-filter:blur(4px);
  z-index:2;
}
/* Karte */
.idx-feature-card{
  margin:-40px 24px 0;
  background:var(--paper);
  padding:36px 30px 38px;
  position:relative;
  box-shadow:0 -20px 40px -20px rgba(33,29,24,.15);
  max-width:540px;
  margin-left:auto;
  margin-right:auto;
}
.idx-feature-card-meta{
  font-family:'Caveat', cursive;
  font-size:22px;
  color:var(--accent);
  margin-bottom:6px;
}
.idx-feature-card-title{
  font-family:'Fraunces', serif;
  font-weight:300;
  font-style:italic;
  font-size:clamp(48px, 9vw, 72px);
  line-height:.95;
  letter-spacing:-.02em;
  margin-bottom:20px;
}
.idx-feature-card-specs{
  font-family:'Fraunces', serif;
  font-size:15px;
  color:var(--ink-soft);
  letter-spacing:.03em;
  padding:14px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:24px;
}
.idx-feature-card p{
  font-size:16px;
  line-height:1.75;
  color:var(--ink-soft);
  margin-bottom:18px;
}

/* Desktop */
@media (min-width:900px){
  .idx-feature-section{
    padding:80px 48px 140px;
  }
  .idx-feature-eyebrow{
    margin-bottom:56px;
  }
  .idx-feature-bignum{
    top:140px;
    font-size:clamp(180px, 22vw, 260px);
  }
  .idx-feature-inner{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    align-items:center;
    gap:72px;
    max-width:1200px;
    margin:0 auto;
  }
  .idx-feature-frame{
    margin:0;
    max-width:none;
  }
  .idx-feature-card{
    margin:0;
    padding:0;
    background:transparent;
    box-shadow:none;
    max-width:460px;
  }
}

/* ===== EVIDENCE ===== */
.idx-evidence{
  background:var(--paper-soft);
  padding:120px 0;
}
.idx-evidence-inner{
  max-width:1440px;
  margin:0 auto;
  padding:0 48px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
}
.idx-evidence-text p{
  font-size:17px;
  line-height:1.8;
  color:var(--ink-soft);
  margin-bottom:24px;
  max-width:52ch;
}
.idx-evidence-text p strong{
  color:var(--ink);
  font-weight:500;
}
.idx-evidence-callouts{
  display:flex; flex-direction:column; gap:24px;
}
.idx-callout{
  background:var(--paper);
  padding:32px 36px;
  border-left:3px solid var(--accent);
  position:relative;
}
.idx-callout .ico{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:48px;
  color:var(--accent);
  line-height:1;
  margin-bottom:12px;
}
.idx-callout h3, .idx-callout h4{
  font-family:'Fraunces', serif;
  font-size:22px;
  font-weight:400;
  margin-bottom:10px;
  letter-spacing:-.01em;
}
.idx-callout p{
  font-size:15px;
  line-height:1.6;
  color:var(--ink-soft);
}

/* ===== TARGET GROUPS ===== */
.idx-groups-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:end;
  margin-bottom:60px;
}
.idx-groups-head p{
  font-size:17px;
  line-height:1.7;
  color:var(--ink-soft);
  max-width:48ch;
}
.idx-groups{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:48px 40px;
}
.idx-group-card{
  display:block;
  cursor:pointer;
}
.idx-group-img{
  aspect-ratio:5/4;
  overflow:hidden;
  box-shadow:var(--shadow);
  position:relative;
  background:var(--paper-deep);
  margin-bottom:22px;
}
.idx-group-img .bg{
  position:absolute; inset:0;
  transition:transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.idx-group-img.var-1 .bg,
.idx-group-img.var-2 .bg,
.idx-group-img.var-3 .bg,
.idx-group-img.var-4 .bg{
  background:var(--paper-deep);
}
.idx-group-img .bg img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
.idx-group-card:hover .idx-group-img .bg{transform:scale(1.05)}
.idx-label-tag{
  position:absolute;
  top:18px; left:18px;
  background:var(--paper);
  padding:6px 12px;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink);
  z-index:2;
}
.idx-group-card h3, .idx-group-card h4{
  font-family:'Fraunces', serif;
  font-weight:400;
  font-size:28px;
  line-height:1.15;
  margin-bottom:10px;
  letter-spacing:-.01em;
  max-width:24ch;
}
.idx-group-card h4 em{font-style:italic; color:var(--accent)}
.idx-group-card p{
  font-size:15px;
  line-height:1.65;
  color:var(--ink-soft);
  max-width:50ch;
}
.idx-more{
  display:inline-block;
  margin-top:14px;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent);
  border-bottom:1px solid var(--accent);
  padding-bottom:2px;
}

/* ===== BUY / COMMISSION ===== */
.idx-buy{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  margin-top:30px;
}
.idx-buy-card{
  background:var(--paper-soft);
  padding:48px 44px;
  position:relative;
  box-shadow: 0 20px 40px -25px rgba(33,29,24,.2);
}
.idx-buy-card .bignum{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:80px;
  font-weight:300;
  color:var(--accent);
  line-height:1;
  margin-bottom:24px;
}
.idx-buy-card h3{
  font-family:'Fraunces', serif;
  font-weight:400;
  font-size:32px;
  line-height:1.15;
  letter-spacing:-.01em;
  margin-bottom:20px;
  max-width:18ch;
}
.idx-buy-card h3 em{font-style:italic; color:var(--accent)}
.idx-buy-card p{
  font-size:15px;
  line-height:1.7;
  color:var(--ink-soft);
  margin-bottom:24px;
}
.idx-buy-dark{
  background:var(--ink);
  color:var(--paper);
}
.idx-buy-dark .bignum{color:var(--accent-soft)}
.idx-buy-dark h3{color:var(--paper)}
.idx-buy-dark h3 em{color:var(--accent-soft)}
.idx-buy-dark p{color:rgba(243,237,226,.8)}

/* ===== HEALING ARCHITECTURE ===== */
.idx-healing{
  background:var(--ink);
  color:var(--paper);
  padding:140px 0;
  position:relative;
  overflow:hidden;
}
.idx-healing::before{
  content:"";
  position:absolute;
  top:-200px; right:-200px;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(168,72,42,.4), transparent 60%);
  pointer-events:none;
}
.idx-healing-inner{
  max-width:1440px;
  margin:0 auto;
  padding:0 48px;
  position:relative;
  z-index:2;
}
.idx-healing-head{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:80px;
  align-items:end;
  margin-bottom:60px;
}
.idx-healing-title{
  font-family:'Fraunces', serif;
  font-weight:300;
  font-size:clamp(40px, 5vw, 72px);
  line-height:1.05;
  letter-spacing:-.02em;
}
.idx-healing-title em{font-style:italic;color:var(--accent-soft);font-weight:400}
.idx-healing .sec-eyebrow::before{background:var(--accent-soft)}
.idx-healing-lead{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:20px;
  line-height:1.5;
  color:rgba(243,237,226,.8);
  max-width:42ch;
}
.idx-healing-body{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  padding-top:40px;
  border-top:1px solid rgba(243,237,226,.15);
}
.idx-healing-body p{
  font-size:16px;
  line-height:1.85;
  color:rgba(243,237,226,.8);
  margin-bottom:20px;
}
.idx-healing-quote{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:28px;
  line-height:1.35;
  color:var(--paper);
  margin:32px 0;
  padding-left:24px;
  border-left:2px solid var(--accent-soft);
}

/* ===== LOCAL ===== */
.idx-local-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.idx-local-title{
  font-family:'Fraunces', serif;
  font-weight:300;
  font-size:clamp(36px, 4.4vw, 56px);
  line-height:1.05;
  margin-bottom:24px;
  letter-spacing:-.015em;
}
.idx-local-title em{font-style:italic; color:var(--accent); font-weight:400}
.idx-local-text p{
  font-size:17px;
  line-height:1.75;
  color:var(--ink-soft);
  margin-bottom:20px;
  max-width:52ch;
}
.idx-local-cities{
  display:flex; flex-wrap:wrap; gap:8px;
  margin:24px 0 32px;
}
.idx-city-tag{
  border:1px solid var(--line);
  padding:8px 16px;
  border-radius:999px;
  font-size:13px;
  color:var(--ink-soft);
  background:rgba(255,255,255,.3);
}
.idx-map-frame{
  aspect-ratio:1/1;
  background:var(--paper-soft);
  border:1px solid var(--line);
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.idx-map-frame::before{
  content:"";
  position:absolute; inset:0;
}
.idx-map-frame img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
.idx-map-pin{
  position:absolute;
  top: 51%;
  left: 33%;
  transform:translate(-50%,-50%);
  text-align:center;
}
.idx-map-pin .dot{
  width:14px; height:14px;
  background:var(--accent);
  border-radius:50%;
  margin:0 auto 8px;
  box-shadow:0 0 0 6px rgba(168,72,42,.25), 0 0 0 14px rgba(168,72,42,.12);
}
.idx-map-pin .map-label{
  font-family:'Caveat', cursive;
  font-size:24px;
  color:var(--accent);
}
.idx-map-pin .sub{
  font-family:'Fraunces', serif;
  font-style:italic;
  font-size:14px;
  color:var(--ink-soft);
}

/* ===== INDEX RESPONSIVE ===== */
@media (max-width: 900px){
  .idx-hero{grid-template-columns:1fr; padding:60px 24px 40px; gap:40px}
  .idx-hero-img-sub{display:none}
  .idx-trust{grid-template-columns:repeat(2,1fr); gap:24px; padding:24px}
  .idx-bloc{padding:70px 24px}
  .idx-evidence-inner,
  .idx-groups-head,
  .idx-buy,
  .idx-healing-head,
  .idx-healing-body,
  .idx-local-inner{
    grid-template-columns:1fr;
    gap:40px;
  }
  .idx-groups{grid-template-columns:1fr}
  .idx-evidence{padding:70px 0}
  .idx-evidence-inner{padding:0 24px}
  .idx-healing{padding:80px 0}
  .idx-healing-inner{padding:0 24px}
}
