/* ==========================================================================
   MODOM — Premium page components (ATELIER) — shared by o-projekte, modom-36, …
   Living crossfade hero + floating data card + benefits ticker, statement
   word-scrub, benefit rows, gallery slider, product range (shared mcard),
   technical layer-card, vision CTA. Shared components come from components.css.
   ========================================================================== */

/* --- 01 Hero ---------------------------------------------------------------- */
.phero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--ink);
  color: var(--paper);
}
.phero__media { position: absolute; inset: 0; z-index: 0; }
.phero__layer { position: absolute; inset: 0; opacity: 0; }
.phero__layer.is-front { opacity: 1; }
.phero__layer img { width: 100%; height: 100%; object-fit: cover; }
.phero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(23, 20, 17, 0.4) 0%, rgba(23, 20, 17, 0.16) 40%, rgba(23, 20, 17, 0.72) 100%),
    radial-gradient(130% 80% at 18% 78%, rgba(23, 20, 17, 0.6), transparent 58%);
}

.phero__inner {
  position: relative; z-index: 2;
  width: 100%;
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  align-items: center;
  gap: clamp(2.5rem, 1rem + 4vw, 5rem);
  padding-block: clamp(7rem, 6rem + 6vh, 10rem) clamp(6rem, 5rem + 5vh, 8rem);
}
.phero__eyebrow { color: var(--taupe); }
.phero__eyebrow::after { background: var(--taupe); }
.phero__title {
  margin-top: var(--space-24);
  font-weight: 300;
  font-size: var(--fs-display);
  letter-spacing: var(--tracking-display);
  line-height: var(--lh-display);
  color: var(--paper);
}
.phero__line { display: block; overflow: hidden; padding-block: 0.06em; }
.phero__line-in { display: inline-block; will-change: transform; }
.phero__lead {
  margin-top: var(--space-32);
  max-width: 52ch;
  font-size: var(--fs-lead);
  line-height: 1.72;
  color: var(--color-cream-70);
}
.phero__actions { margin-top: var(--space-40); display: flex; flex-wrap: wrap; gap: var(--space-16); }

/* Floating product-range card (same fc component as home) */
.phero__card { position: relative; z-index: 2; justify-self: end; width: min(320px, 100%); will-change: transform; }

/* Benefits ticker — one slow seamless loop, pauses for reduced motion */
.phero__ticker {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  border-top: 1px solid rgba(245, 240, 233, 0.14);
  background: rgba(23, 20, 17, 0.42);
  backdrop-filter: blur(10px);
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.phero__ticker-track {
  display: inline-flex; align-items: center; gap: var(--space-32);
  padding: 0.95rem var(--space-32);
  white-space: nowrap;
  animation: phero-ticker 46s linear infinite;
}
.phero__ticker-track span {
  font-size: 0.74rem; font-weight: var(--weight-bold);
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--color-cream-70);
}
.phero__ticker-track i { font-size: 7px; color: var(--taupe); }
@keyframes phero-ticker { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .phero__ticker-track { animation: none; } }

/* --- 02 Statement (GSAP word scrub; plain text without it) ------------------ */
.pstatement__wrap { max-width: 1080px; }
.pstatement {
  margin-top: var(--space-32);
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.7rem, 1.1rem + 2.6vw, 3.1rem);
  line-height: 1.22;
  letter-spacing: -0.035em;
  color: var(--ink);
  text-wrap: balance;
}

/* --- 03 Benefits — badge rows (same fc-badge language as home) --------------- */
.pwhy { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2.5rem, 1rem + 5vw, 5rem); align-items: start; }
.pwhy__list { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 0 var(--space-40); }
.pwhy__item {
  display: flex; align-items: center; gap: var(--space-16);
  padding-block: var(--space-20);
  border-bottom: 1px solid var(--line-warm);
}
.pwhy__item .fc-badge { flex: none; width: 44px; height: 44px; }
.pwhy__item .fc-badge i { font-size: 17px; }
.pwhy__item h3 {
  font-family: var(--sans);
  font-size: 0.98rem; font-weight: var(--weight-black);
  letter-spacing: -0.025em; line-height: 1.35;
  color: var(--ink);
}
.pwhy__item:nth-child(2n) { transition-delay: 90ms; }

/* --- 04 Gallery slider -------------------------------------------------------- */
.gslider { overflow: hidden; }
.gslider__viewport { overflow: hidden; touch-action: pan-y; cursor: grab; }
.gslider__viewport.is-dragging { cursor: grabbing; }
.gslider__track { display: flex; transition: transform 0.75s var(--ease-out); will-change: transform; }
.gslider__slide { flex: 0 0 100%; aspect-ratio: 16 / 8.2; }
.gslider__slide img { width: 100%; height: 100%; object-fit: cover; pointer-events: none; }

.gslider__bar {
  display: flex; align-items: center; gap: var(--space-24);
  padding: var(--space-20) var(--space-24);
}
.gslider__count {
  display: inline-flex; align-items: baseline; gap: 6px;
  font-family: var(--serif); font-size: 1.1rem; letter-spacing: -0.02em; color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.gslider__count-sep { color: var(--muted); font-size: 0.85rem; }
.gslider__progress { flex: 1; height: 2px; background: var(--line-warm); border-radius: 999px; overflow: hidden; }
.gslider__progress-fill {
  display: block; height: 100%; width: 0;
  background: var(--accent); border-radius: inherit;
  transition: width 0.45s var(--ease-out);
}
.gslider__nav { display: flex; gap: var(--space-8); }
.gslider__btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid #d6c5b2; background: var(--panel-2); color: var(--accent);
  box-shadow: var(--bevel);
  transition: transform var(--dur-base), border-color var(--dur-base), color var(--dur-base);
}
.gslider__btn:hover { border-color: #ad8356; color: var(--ink); transform: translateY(-2px); }
.gslider__btn i { font-size: 15px; }

/* --- 05 Product range (mirrors home models layout) ---------------------------- */
.prange { display: grid; grid-template-columns: 0.86fr 1.14fr; gap: clamp(2.5rem, 1rem + 5vw, 5rem); align-items: center; }
.prange__cards { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(1rem, 0.5rem + 1vw, 1.5rem); }
.prange__col { display: flex; flex-direction: column; gap: clamp(1rem, 0.5rem + 1vw, 1.5rem); }

/* --- 06 Technical --------------------------------------------------------------- */
.ptech { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(2.5rem, 1rem + 5vw, 5rem); align-items: center; }

/* --- 07 Vision + CTA -------------------------------------------------------------- */
.pvision { max-width: 1080px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.pvision .eyebrow { align-items: center; }
.pvision__text {
  margin-top: var(--space-32);
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.55rem, 1.05rem + 2.2vw, 2.7rem);
  line-height: 1.24;
  letter-spacing: -0.035em;
  color: var(--ink);
  text-wrap: balance;
}
.pvision__slogan {
  margin-top: var(--space-40);
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.1rem, 1rem + 0.6vw, 1.35rem);
  color: var(--accent);
}
.pvision__actions { margin-top: var(--space-48); display: flex; flex-wrap: wrap; gap: var(--space-16); justify-content: center; }

/* --- Responsive -------------------------------------------------------------------- */
@media (max-width: 1080px) {
  .phero__inner { grid-template-columns: 1fr; gap: var(--space-40); }
  .phero__card { justify-self: center; }
}
@media (max-width: 980px) {
  .pwhy { grid-template-columns: 1fr; gap: var(--space-40); }
  .prange { grid-template-columns: 1fr; gap: var(--space-40); }
  .ptech { grid-template-columns: 1fr; gap: var(--space-40); }
}
@media (max-width: 720px) {
  .pwhy__list { grid-template-columns: 1fr; }
  .gslider__slide { aspect-ratio: 16 / 11; }
  .gslider__bar { flex-wrap: wrap; gap: var(--space-16); }
  .gslider__progress { order: 3; flex-basis: 100%; }
  .gslider__nav { margin-left: auto; }
}
@media (max-width: 560px) {
  .prange__cards { grid-template-columns: 1fr; }
  .phero__actions .btn,
  .pvision__actions .btn { width: 100%; }
  .pvision__actions { align-self: stretch; }
}
