/* ============================================================
   DBO digitals — section layouts
   ============================================================ */

/* ---- HERO ------------------------------------------------- */
.hero { padding-top: clamp(8rem, 14vw, 12rem); padding-bottom: var(--section-y); position: relative; overflow: hidden; }
.hero__grid { display: grid; grid-template-columns: 1.12fr 0.88fr; gap: clamp(2rem, 4vw, 4.5rem); align-items: center; }
.hero__eyebrow { display:flex; flex-wrap:wrap; gap: 0.5em 0.9em; align-items:center; margin-bottom: 1.8rem; }
.hero__eyebrow .dot { width:4px; height:4px; background: var(--accent); border-radius:50%; display:inline-block; }
.hero h1 { margin-bottom: 1.6rem; }
.hero__sub { max-width: 33rem; margin-bottom: 1.2rem; }
.hero__lead { max-width: 31rem; color: var(--fg-muted); font-size: 1rem; line-height: 1.65; margin-bottom: 2.4rem; }
.hero__cta { display:flex; flex-wrap:wrap; gap: 1rem 1.8rem; align-items:center; }

/* simulation viewport */
.sim {
  position: relative; aspect-ratio: 1 / 1.06; border: 1px solid var(--hairline);
  background: color-mix(in oklab, var(--ink-900) 96%, var(--accent)); overflow: hidden;
}
html[data-accent="mono"] .sim { background: var(--ink-900); }
.sim canvas { position:absolute; inset:0; width:100%; height:100%; display:block; }
.sim__chrome { position:absolute; inset:0; pointer-events:none; display:flex; flex-direction:column; justify-content:space-between; padding: 1.1rem 1.2rem; z-index:2; }
.sim__tag { display:flex; align-items:center; gap:.6em; font-family: var(--mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color: oklch(0.72 0.012 80); }
.sim__live { width:7px; height:7px; border-radius:50%; background: var(--accent-sage-dark); box-shadow:0 0 0 0 var(--accent-sage-dark); animation: pulse 2.4s var(--ease) infinite; }
html[data-accent="mono"] .sim__live { background: oklch(0.85 0.006 85); box-shadow:0 0 0 0 oklch(0.85 0.006 85); }
.sim__foot { display:flex; justify-content:space-between; align-items:flex-end; color: oklch(0.62 0.012 80); font-family: var(--mono); font-size:0.6rem; letter-spacing:0.16em; text-transform:uppercase; }
@keyframes pulse { 0%{ box-shadow:0 0 0 0 color-mix(in oklab, currentColor 60%, transparent);} 70%{ box-shadow:0 0 0 9px transparent;} 100%{ box-shadow:0 0 0 0 transparent;} }

@media (max-width: 940px) {
  .hero__grid { grid-template-columns: 1fr; gap: 2.6rem; }
  .sim { aspect-ratio: 16/12; max-height: 60vh; order: 2; }
}

/* ---- generic section head -------------------------------- */
.shead { display:grid; grid-template-columns: 1fr; gap: 1.4rem; margin-bottom: clamp(2.6rem, 5vw, 4.4rem); }
.shead--split { grid-template-columns: 0.9fr 1.1fr; gap: clamp(1.6rem,4vw,4rem); align-items:end; }
.shead__lead { max-width: 38rem; }
@media (max-width: 820px){ .shead--split{ grid-template-columns:1fr; align-items:start; } }

/* ---- PROBLEM rows ---------------------------------------- */
.rows { border-top: 1px solid var(--hairline); }
.row { display:grid; grid-template-columns: auto 1fr; gap: clamp(1.5rem,4vw,4rem); align-items:baseline;
  padding: clamp(1.6rem,3vw,2.4rem) 0; border-bottom: 1px solid var(--hairline); transition: padding-left .4s var(--ease); }
.row:hover { padding-left: 0.6rem; }
.row__num { font-family: var(--serif); font-style: italic; font-size: clamp(1.4rem,2.4vw,2rem); color: var(--accent); letter-spacing: 0.01em; }
.row__text { font-family: var(--serif); font-size: clamp(1.3rem,2.5vw,2rem); line-height: 1.22; letter-spacing:-0.01em; text-wrap: balance; }
.row__text em { font-style: italic; color: var(--accent); }

/* ---- DIFFERENZIERUNG (contrast) -------------------------- */
.contrast { display:grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--hairline); }
.contrast__col { padding: clamp(1.8rem,3.5vw,3rem); }
.contrast__col + .contrast__col { border-left: 1px solid var(--hairline); }
.contrast__head { display:flex; align-items:center; gap:.7em; margin-bottom: 1.8rem; }
.contrast__head .eyebrow { color: var(--fg-muted); }
.contrast li { display:flex; gap: 0.9em; align-items:flex-start; padding: 0.85rem 0; border-bottom: 1px solid color-mix(in oklab, var(--fg) 8%, transparent); font-size: 1.02rem; }
.contrast li:last-child { border-bottom: none; }
.contrast__col--no li { color: var(--fg-muted); }
.contrast__col--no .mk { color: var(--fg-muted); }
.contrast__col--yes .mk { color: var(--accent); }
.mk { flex:none; font-family: var(--mono); font-size: 0.9em; margin-top: 0.15em; }
.contrast__col--no .lbl { text-decoration: line-through; text-decoration-color: color-mix(in oklab, var(--fg) 35%, transparent); text-decoration-thickness: 1px; }
@media (max-width: 760px){ .contrast{ grid-template-columns:1fr; } .contrast__col + .contrast__col{ border-left:none; border-top:1px solid var(--hairline); } }

/* ---- METHODIK grid --------------------------------------- */
.mgrid { display:grid; grid-template-columns: repeat(2, 1fr); border-top:1px solid var(--hairline); border-left:1px solid var(--hairline); }
.mcell { padding: clamp(1.8rem,3.4vw,2.8rem); border-right:1px solid var(--hairline); border-bottom:1px solid var(--hairline); transition: background .4s var(--ease); position:relative; }
.mcell:hover { background: var(--surface); }
.mcell__num { font-family: var(--mono); font-size:0.66rem; letter-spacing:0.16em; color: var(--accent); margin-bottom: 1.4rem; }
.mcell h3 { font-family: var(--serif); font-size: clamp(1.15rem,1.9vw,1.55rem); letter-spacing:-0.008em; line-height:1.14; margin-bottom: 0.9rem; }
.mcell p { color: var(--fg-muted); font-size: 0.98rem; line-height: 1.6; }
@media (max-width: 720px){ .mgrid{ grid-template-columns:1fr; } }

/* ---- LEISTUNGEN cards ------------------------------------ */
.services { display:grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); }
.svc { background: var(--bg); padding: clamp(1.8rem,3.4vw,2.9rem); display:flex; flex-direction:column; gap: 1rem; min-height: 17rem; transition: background .45s var(--ease); }
.svc:hover { background: var(--surface); }
.svc__tag { font-family: var(--mono); font-size:0.62rem; letter-spacing:0.18em; text-transform: uppercase; color: var(--accent); }
.svc h3 { font-family: var(--serif); font-size: clamp(1.4rem,2.1vw,1.9rem); letter-spacing:-0.01em; line-height:1.1; }
.svc p { color: var(--fg-muted); font-size: 1rem; line-height: 1.6; flex: 1; }
@media (max-width: 720px){ .services{ grid-template-columns:1fr; } }

/* ---- WIRKUNG competence list ----------------------------- */
.comp { border-top: 1px solid var(--hairline); }
.comp__item { display:grid; grid-template-columns: auto 1fr auto; gap: clamp(1rem,3vw,2.5rem); align-items:center;
  padding: clamp(1.3rem,2.6vw,2rem) 0; border-bottom: 1px solid var(--hairline); transition: padding-left .4s var(--ease), color .3s; }
.comp__item:hover { padding-left: 0.6rem; }
.comp__idx { font-family: var(--mono); font-size:0.7rem; letter-spacing:0.16em; color: var(--accent); }
.comp__name { font-family: var(--serif); font-size: clamp(1.2rem,2.5vw,2.1rem); letter-spacing:-0.012em; line-height:1.1; }
.comp__arrow { color: var(--accent); opacity:0; transform: translateX(-8px); transition: opacity .4s var(--ease), transform .4s var(--ease); font-size:1.2rem; }
.comp__item:hover .comp__arrow { opacity:1; transform: translateX(0); }

/* ---- QUOTE band ------------------------------------------ */
.quote { text-align: left; }
.quote__mark { font-family: var(--serif); font-size: clamp(3rem,7vw,6rem); line-height:0; color: var(--accent); display:block; height: 0.6em; }
.quote blockquote { font-size: clamp(1.6rem,3.6vw,3rem); max-width: 24ch; margin: 0 0 1.8rem; }
.quote cite { font-style: normal; font-family: var(--sans); font-size:0.72rem; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color: var(--fg-muted); }

/* ---- AGENTUR --------------------------------------------- */
.agency { display:grid; grid-template-columns: 0.62fr 1fr; gap: clamp(2rem,5vw,5rem); align-items:center; }
.agency__portrait { aspect-ratio: 3/4; position: relative; width: 100%; max-width: 360px; }
/* graded version sits on top; original color image crossfades in on hover (like the crew cards) */
.agency__portrait .ph__img { position: absolute; inset: 0; transition: transform .6s var(--ease); will-change: transform; }
.agency__portrait .ph__img--hover { opacity: 0; transition: opacity .6s var(--ease), transform .6s var(--ease); }
.agency__portrait:hover .ph__img--hover { opacity: 1; }
.agency__portrait:hover .ph__img { transform: scale(1.035); }
@media (hover: none){ .agency__portrait .ph__img--hover { display: none; } }
.agency__body p { margin-bottom: 1.3rem; max-width: 36rem; }
.agency__pivot { display:inline-flex; align-items:center; gap: 1.1rem; margin: 1.4rem 0 2rem; padding: 1rem 1.4rem; border:1px solid var(--hairline); }
.agency__pivot b { font-family: var(--serif); font-style: italic; letter-spacing:-0.01em; font-weight:500; font-size:1.15rem; white-space:nowrap; }
.agency__pivot .sep { color: var(--accent); font-size:1.2rem; }
@media (max-width: 820px){ .agency{ grid-template-columns:1fr; } .agency__portrait{ max-width: 22rem; } }

/* ---- FINAL CTA ------------------------------------------- */
.fcta { text-align: center; display:flex; flex-direction:column; align-items:center; gap: 1.6rem; }
.fcta h2 { max-width: 18ch; }
.fcta__row { display:flex; flex-wrap:wrap; gap: 1rem; justify-content:center; margin-top: 0.8rem; }

/* ---- FOOTER ---------------------------------------------- */
.foot { padding-block: clamp(3.5rem,6vw,5.5rem); border-top: 1px solid var(--hairline); }
.foot__top { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(2rem,4vw,4rem); margin-bottom: 3.5rem; }
.foot__brand .brand__name { font-size: 1.9rem; }
.foot__desc { color: var(--fg-muted); max-width: 26rem; margin: 1.2rem 0 1.4rem; font-size: 0.98rem; }
.foot__tags { display:flex; flex-wrap:wrap; gap:.5em .9em; align-items:center; }
.foot__tags .dot { width:4px;height:4px;background:var(--accent);border-radius:50%;display:inline-block; }
.foot__col h4 { font-family: var(--sans); font-size:0.68rem; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color: var(--fg-muted); margin-bottom: 1.2rem; }
.foot__col a { display:block; padding: 0.4rem 0; font-size: 0.96rem; color: color-mix(in oklab, var(--fg) 82%, transparent); transition: color .3s; }
.foot__col a:hover { color: var(--accent); }
.foot__bottom { display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; padding-top: 2rem; border-top:1px solid var(--hairline); font-size:0.78rem; color: var(--fg-muted); letter-spacing:0.04em; }
.foot__bottom a:hover { color: var(--accent); }
@media (max-width: 820px){ .foot__top{ grid-template-columns:1fr 1fr; } .foot__brand{ grid-column:1/-1; } }
@media (max-width: 520px){ .foot__top{ grid-template-columns:1fr; } }

/* section divider accent line on heads */
.eyebrow-line { display:flex; align-items:center; gap: 1rem; }
.eyebrow-line::before { content:""; width: 2.4rem; height:1px; background: var(--accent); flex:none; }
