/* ============================================================
   Arets.AI — Service detail pages
   Shared styles for /diensten/*.html
   ============================================================ */

/* ---------- Page wrapper & theme ---------- */
.dienst-page {
  --service-color: var(--signal);
  --service-soft: var(--signal-50);
  --service-tint: rgba(0, 78, 120, .06);
}
.dienst-page.theme-sage       { --service-color: var(--sage);       --service-soft: var(--sage-soft);       --service-tint: rgba(47,143,110,.08); }
.dienst-page.theme-terracotta { --service-color: var(--terracotta); --service-soft: var(--terracotta-soft); --service-tint: rgba(201,101,68,.08); }
.dienst-page.theme-plum       { --service-color: var(--plum);       --service-soft: var(--plum-soft);       --service-tint: rgba(107,86,160,.08); }
.dienst-page.theme-amber      { --service-color: var(--amber);      --service-soft: var(--amber-soft);      --service-tint: rgba(198,147,57,.08); }

/* ---------- Back bar ---------- */
.dienst-backbar {
  padding: calc(var(--nav-h) + 24px) 0 0;
  position: relative;
  z-index: 2;
}
.dienst-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--slate);
  padding: 10px 16px 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.7);
  border: 1px solid var(--mist-2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all .25s var(--ease);
}
.dienst-back:hover {
  border-color: var(--service-color);
  color: var(--service-color);
  transform: translateX(-2px);
}
.dienst-back svg { transition: transform .25s var(--ease); }
.dienst-back:hover svg { transform: translateX(-3px); }

/* ---------- Service hero ---------- */
.dienst-hero {
  position: relative;
  padding: 56px 0 80px;
  overflow: hidden;
}
.dienst-hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.dienst-hero__orb {
  position: absolute;
  width: 60vw;
  height: 60vw;
  max-width: 720px;
  max-height: 720px;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .35;
  background: radial-gradient(circle at 50% 50%, var(--service-color) 0%, transparent 60%);
}
.dienst-hero__orb--1 { top: -25%; right: -15%; }
.dienst-hero__orb--2 { bottom: -30%; left: -20%; opacity: .25; }

.dienst-hero__content {
  position: relative;
  max-width: 820px;
}
.dienst-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--service-color);
  background: var(--service-soft);
  padding: 8px 14px;
  border-radius: 999px;
  margin-bottom: 24px;
}
.dienst-hero__eyebrow-num {
  font-weight: 700;
  opacity: .7;
}

.dienst-hero__title {
  font-size: clamp(40px, 6.5vw, 72px);
  letter-spacing: -0.035em;
  font-weight: 600;
  line-height: 1.04;
  margin-bottom: 24px;
}
.dienst-hero__title em {
  font-style: italic;
  color: var(--service-color);
}

.dienst-hero__lead {
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.5;
  color: var(--slate);
  max-width: 640px;
}

/* ---------- Section head (small variant on detail pages) ---------- */
.dienst-section {
  padding: clamp(56px, 8vw, 100px) 0;
  position: relative;
}
.dienst-section--soft { background: var(--service-tint); }
.dienst-section--paper { background: var(--paper); }

.dienst-section__head {
  margin-bottom: clamp(32px, 5vw, 56px);
  max-width: 720px;
}
.dienst-section__eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--service-color);
  margin-bottom: 14px;
}
.dienst-section__title {
  font-size: clamp(28px, 3.6vw, 44px);
  letter-spacing: -0.025em;
  font-weight: 600;
  line-height: 1.08;
  margin-bottom: 14px;
}
.dienst-section__sub {
  color: var(--slate);
  font-size: clamp(16px, 1.5vw, 18px);
  line-height: 1.55;
}

/* ---------- Pillars (AI adoptie: 4 pillars) ---------- */
.pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.pillar {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius-lg);
  padding: 28px;
  position: relative;
  transition: all .3s var(--ease);
}
.pillar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--service-color);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  transform: scaleX(.3);
  transform-origin: left;
  transition: transform .35s var(--ease);
}
.pillar:hover { border-color: var(--service-color); transform: translateY(-3px); box-shadow: var(--shadow); }
.pillar:hover::before { transform: scaleX(1); }
.pillar__num {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--service-color);
  margin-bottom: 16px;
}
.pillar__icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--service-soft);
  color: var(--service-color);
  display: grid; place-items: center;
  margin-bottom: 16px;
}
.pillar__title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 8px;
  line-height: 1.2;
}
.pillar__body {
  font-size: 14px;
  color: var(--slate);
  line-height: 1.55;
}

/* ---------- Outputs grid (AI adoptie: what they can make) ---------- */
.outputs-band {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(56px, 8vw, 96px) 0;
  position: relative;
  overflow: hidden;
}
.outputs-band__glow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  height: 80%;
  background: radial-gradient(ellipse at center, var(--service-color) 0%, transparent 60%);
  opacity: .15;
  filter: blur(80px);
  pointer-events: none;
}
.outputs-band__head {
  text-align: center;
  margin-bottom: 56px;
  position: relative;
}
.outputs-band__title {
  font-size: clamp(28px, 3.6vw, 44px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: 14px;
}
.outputs-band__title em {
  font-style: italic;
  color: var(--service-color);
  filter: brightness(1.4);
}
.outputs-band__sub {
  color: rgba(245,245,247,.65);
  font-size: 17px;
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.5;
}
.outputs-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  position: relative;
}
.output-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  padding: 22px 18px;
  text-align: center;
  transition: all .3s var(--ease);
}
.output-card:hover {
  background: rgba(255,255,255,.07);
  border-color: var(--service-color);
  transform: translateY(-3px);
}
.output-card__icon {
  width: 40px; height: 40px;
  margin: 0 auto 12px;
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  color: var(--service-color);
  display: grid; place-items: center;
  filter: brightness(1.3);
}
.output-card__name {
  font-size: 13px;
  font-weight: 500;
  color: var(--paper);
}
.outputs-band__caption {
  margin-top: 40px;
  text-align: center;
  color: rgba(245,245,247,.6);
  font-size: 14px;
  position: relative;
}
.outputs-band__caption strong {
  color: var(--paper);
  font-weight: 600;
}

/* ---------- Flow diagram (Automatisering) ---------- */
.flow-diagram {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 48px) clamp(20px, 3vw, 32px);
  position: relative;
}
.flow-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  align-items: center;
}
.flow-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  padding: 18px 12px;
  border-radius: var(--radius);
  background: var(--service-soft);
  border: 1px solid color-mix(in srgb, var(--service-color) 18%, transparent);
  position: relative;
  min-height: 140px;
  justify-content: center;
}
.flow-step--trigger { background: var(--service-soft); }
.flow-step--end {
  background: var(--service-color);
  color: var(--white);
  border-color: var(--service-color);
}
.flow-step__icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--white);
  color: var(--service-color);
  display: grid; place-items: center;
  border: 1px solid color-mix(in srgb, var(--service-color) 24%, transparent);
}
.flow-step--end .flow-step__icon { background: rgba(255,255,255,.18); color: var(--white); border-color: rgba(255,255,255,.3); }
.flow-step__label {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.25;
}
.flow-step__hint {
  font-size: 11px;
  color: var(--slate);
  line-height: 1.35;
}
.flow-step--end .flow-step__hint { color: rgba(255,255,255,.85); }

.flow-arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--service-color);
  position: relative;
}
.flow-arrow svg { opacity: .6; }
.flow-arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--service-color), transparent);
  transform: translateY(-50%);
  opacity: .35;
}
.flow-pulse {
  position: absolute;
  top: 50%;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--service-color);
  transform: translateY(-50%);
  box-shadow: 0 0 12px var(--service-color);
  animation: flow-travel 2.4s linear infinite;
}
@keyframes flow-travel {
  0%   { left: 0%;  opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { left: 100%; opacity: 0; }
}

.flow-caption {
  text-align: center;
  margin-top: 28px;
  color: var(--slate);
  font-size: 14px;
  font-style: italic;
}

/* ---------- Compare table (Auto vs Agent) ---------- */
.compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  position: relative;
}
.compare__col {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.compare__col--auto {
  border-color: color-mix(in srgb, var(--terracotta) 35%, var(--mist-2));
  background: linear-gradient(180deg, var(--terracotta-soft) 0%, var(--white) 60%);
}
.compare__col--agent {
  border-color: color-mix(in srgb, var(--plum) 30%, var(--mist-2));
  background: linear-gradient(180deg, var(--plum-soft) 0%, var(--white) 60%);
}
.compare__head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--mist-2);
}
.compare__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
}
.compare__col--auto .compare__chip { background: rgba(201,101,68,.16); color: var(--terracotta); }
.compare__col--agent .compare__chip { background: rgba(107,86,160,.16); color: var(--plum); }
.compare__title {
  font-size: 18px;
  font-weight: 600;
}
.compare__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.compare__item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.5;
}
.compare__bullet {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border-radius: 50%;
  display: grid; place-items: center;
  margin-top: 2px;
}
.compare__col--auto .compare__bullet { background: rgba(201,101,68,.18); color: var(--terracotta); }
.compare__col--agent .compare__bullet { background: rgba(107,86,160,.18); color: var(--plum); }
.compare__bullet svg { width: 11px; height: 11px; }

.compare__verdict {
  margin-top: 28px;
  padding: 22px 28px;
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--radius-lg);
  text-align: center;
  font-style: italic;
  line-height: 1.55;
  font-size: 16px;
}
.compare__verdict em {
  color: var(--signal-400);
  font-style: italic;
}

/* ---------- Agent loop visualization ---------- */
.loopviz {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius-lg);
  padding: clamp(32px, 5vw, 60px) clamp(20px, 3vw, 40px);
  position: relative;
  overflow: hidden;
}
.loopviz__steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  align-items: stretch;
  position: relative;
  z-index: 2;
}
.loop-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.loop-step__circle {
  width: 96px; height: 96px;
  border-radius: 50%;
  display: grid; place-items: center;
  border: 2px solid var(--mist-2);
  background: var(--white);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-2);
  text-align: center;
  padding: 8px;
  line-height: 1.2;
  position: relative;
  transition: all .3s var(--ease);
}
.loop-step--active .loop-step__circle {
  background: var(--service-color);
  color: var(--white);
  border-color: var(--service-color);
  box-shadow: 0 0 0 6px var(--service-soft);
}
.loop-step__num {
  font-size: 11px;
  letter-spacing: .14em;
  color: var(--slate);
  text-transform: uppercase;
  font-weight: 600;
}
.loop-step--active .loop-step__num { color: var(--service-color); }

.loopviz__return {
  margin-top: 20px;
  text-align: center;
  position: relative;
  color: var(--slate);
  font-size: 13px;
  font-style: italic;
}
.loopviz__return-arrow {
  margin-top: 16px;
  position: relative;
  height: 36px;
}
.loopviz__return-arrow svg {
  width: 100%;
  height: 100%;
  color: var(--service-color);
  opacity: .55;
}

.loopviz__quote {
  margin-top: 28px;
  padding: 20px 24px;
  background: var(--service-soft);
  border-left: 3px solid var(--service-color);
  border-radius: 8px;
  font-style: italic;
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.55;
}

/* ---------- Runtime cards (4 places we run agents) ---------- */
.runtimes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.runtime {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius-lg);
  padding: 26px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: all .3s var(--ease);
}
.runtime:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.runtime__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
  align-self: flex-start;
}
.runtime--default .runtime__chip { background: rgba(47,143,110,.14); color: var(--sage); }
.runtime--default { border-color: color-mix(in srgb, var(--sage) 30%, var(--mist-2)); }
.runtime--light .runtime__chip { background: rgba(198,147,57,.14); color: var(--amber); }
.runtime--light { border-color: color-mix(in srgb, var(--amber) 30%, var(--mist-2)); }
.runtime--connector .runtime__chip { background: rgba(107,86,160,.14); color: var(--plum); }
.runtime--connector { border-color: color-mix(in srgb, var(--plum) 30%, var(--mist-2)); }
.runtime--custom { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.runtime--custom .runtime__chip { background: rgba(255,255,255,.12); color: var(--paper); }
.runtime__title {
  font-size: 17px;
  font-weight: 600;
  line-height: 1.25;
}
.runtime__body {
  font-size: 14px;
  color: var(--slate);
  line-height: 1.55;
  flex: 1;
}
.runtime--custom .runtime__body { color: rgba(245,245,247,.7); }
.runtime__meta {
  font-size: 12px;
  color: var(--slate-2);
  border-top: 1px solid var(--mist-2);
  padding-top: 12px;
  margin-top: auto;
}
.runtime--custom .runtime__meta { color: rgba(245,245,247,.55); border-top-color: rgba(255,255,255,.1); }

/* ---------- Examples grid (agents) ---------- */
.example-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.example-card {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius);
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: all .3s var(--ease);
}
.example-card:hover { border-color: var(--service-color); transform: translateY(-2px); }
.example-card__icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--service-soft);
  color: var(--service-color);
  display: grid; place-items: center;
}
.example-card__title { font-size: 16px; font-weight: 600; }
.example-card__body { font-size: 13px; color: var(--slate); line-height: 1.5; }

/* ---------- Install steps (agents — six steps) ---------- */
.install-steps {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
}
.install-step {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: 12px;
  padding: 16px 14px;
  text-align: center;
  position: relative;
}
.install-step__num {
  display: inline-grid;
  place-items: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--service-soft);
  color: var(--service-color);
  font-size: 12px;
  font-weight: 700;
  margin: 0 auto 10px;
}
.install-step__label {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.3;
}

/* ---------- Before / After (Company OS) ---------- */
.beforeafter {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  gap: 16px;
  align-items: stretch;
}
.beforeafter__side {
  border-radius: var(--radius-lg);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-height: 320px;
}
.beforeafter__side--before {
  background: var(--paper);
  border: 1px dashed var(--mist);
}
.beforeafter__side--after {
  background: linear-gradient(180deg, var(--service-soft) 0%, var(--white) 100%);
  border: 1px solid color-mix(in srgb, var(--service-color) 30%, var(--mist-2));
}
.beforeafter__chip {
  display: inline-flex;
  align-self: flex-start;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
}
.beforeafter__side--before .beforeafter__chip { background: var(--mist-2); color: var(--slate); }
.beforeafter__side--after .beforeafter__chip { background: var(--service-color); color: var(--white); }
.beforeafter__title { font-size: 18px; font-weight: 600; line-height: 1.25; }
.beforeafter__cluster {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.scatter-tool {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: 999px;
  padding: 8px 14px;
  font-size: 13px;
  color: var(--slate);
  transform: rotate(var(--rot, 0deg));
}
.scatter-tool::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--mist);
}
.beforeafter__caption {
  margin-top: auto;
  font-size: 13px;
  color: var(--slate);
  font-style: italic;
}
.beforeafter__side--after .beforeafter__caption { color: var(--service-color); font-weight: 500; font-style: normal; }

.beforeafter__connector {
  align-self: center;
  display: grid;
  place-items: center;
  color: var(--service-color);
  height: 100%;
}

.os-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 16px;
}
.os-feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-2);
}
.os-feature__check {
  display: inline-grid;
  place-items: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--service-color);
  color: var(--white);
  flex-shrink: 0;
}
.os-feature__check svg { width: 10px; height: 10px; }

/* ---------- Platform options (Company OS) ---------- */
.platforms {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.platform {
  background: var(--white);
  border: 1px solid var(--mist-2);
  border-radius: var(--radius);
  padding: 22px;
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  transition: all .3s var(--ease);
}
.platform:hover { transform: translateY(-3px); border-color: var(--service-color); box-shadow: var(--shadow-sm); }
.platform--default {
  background: linear-gradient(180deg, var(--service-soft) 0%, var(--white) 100%);
  border-color: var(--service-color);
}
.platform__badge {
  position: absolute;
  top: -10px;
  right: 14px;
  background: var(--service-color);
  color: var(--white);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 999px;
}
.platform__icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--paper);
  display: grid; place-items: center;
  margin-bottom: 4px;
}
.platform--default .platform__icon { background: var(--white); }
.platform__name { font-size: 15px; font-weight: 600; }
.platform__hint { font-size: 12px; color: var(--slate); line-height: 1.4; }

/* ---------- Why it matters (Company OS / context block) ---------- */
.context-callout {
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 48px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.context-callout::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 20%, var(--service-color) 0%, transparent 50%);
  opacity: .14;
  pointer-events: none;
}
.context-callout__title {
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
  position: relative;
}
.context-callout__title em { color: var(--service-color); filter: brightness(1.4); font-style: italic; }
.context-callout__body {
  color: rgba(245,245,247,.75);
  line-height: 1.6;
  font-size: 15px;
  position: relative;
}
.context-formula {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  padding: 24px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 14px;
}
.context-formula__chip {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  padding: 8px 14px;
  border-radius: 999px;
  color: rgba(245,245,247,.7);
}
.context-formula__chip--highlight {
  background: var(--service-color);
  border-color: var(--service-color);
  color: var(--white);
  font-weight: 600;
}
.context-formula__op { color: rgba(245,245,247,.4); font-size: 18px; }

/* ---------- Reuse hub viz from index ---------- */
@keyframes hub-rotate { to { transform: rotate(360deg); } }
@keyframes hub-rotate-reverse { to { transform: rotate(-360deg); } }

.os-hub-wrap {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}
.os-hub-text h3 {
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
  line-height: 1.15;
}
.os-hub-text p {
  font-size: 15px;
  color: var(--slate);
  line-height: 1.6;
  margin-bottom: 14px;
}
.os-hub-text ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 18px;
}
.os-hub-text li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.5;
}
.os-hub-text li svg {
  flex-shrink: 0;
  margin-top: 4px;
  color: var(--service-color);
}

.os-hub {
  position: relative;
  aspect-ratio: 1;
  width: 100%;
  max-width: 460px;
  margin: 0 auto;
  background: var(--ink);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.os-hub svg { width: 100%; height: 100%; }

/* ---------- Big quote / closing principle ---------- */
.dienst-quote {
  background: var(--white);
  border-left: 4px solid var(--service-color);
  padding: clamp(28px, 4vw, 40px);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.5;
  color: var(--ink-2);
  letter-spacing: -0.01em;
  font-weight: 500;
}
.dienst-quote em {
  color: var(--service-color);
  font-style: italic;
}

/* ---------- Result band ---------- */
.result-band {
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--radius-xl);
  padding: clamp(36px, 5vw, 60px);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.result-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center top, var(--service-color) 0%, transparent 60%);
  opacity: .2;
  pointer-events: none;
}
.result-band__eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--service-color);
  filter: brightness(1.3);
  margin-bottom: 16px;
  position: relative;
}
.result-band__title {
  font-size: clamp(24px, 3.2vw, 38px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.15;
  max-width: 720px;
  margin: 0 auto 24px;
  position: relative;
}
.result-band__cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

/* ---------- Mini CTA at bottom ---------- */
.dienst-cta {
  padding: clamp(56px, 8vw, 96px) 0;
  text-align: center;
}
.dienst-cta h2 {
  font-size: clamp(26px, 3.4vw, 40px);
  font-weight: 600;
  letter-spacing: -0.025em;
  margin-bottom: 14px;
}
.dienst-cta p {
  color: var(--slate);
  font-size: 17px;
  margin-bottom: 28px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

/* ---------- Service cards as anchor links ---------- */
.service.service--link {
  cursor: pointer;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.service.service--link .service__result {
  margin-top: auto;
}

.service__more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 18px;
  font-size: 13px;
  font-weight: 500;
  color: var(--service-color);
  letter-spacing: -0.005em;
}
.service__more svg { transition: transform .25s var(--ease); }
.service:hover .service__more svg { transform: translateX(3px); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .pillars { grid-template-columns: repeat(2, 1fr); }
  .outputs-grid { grid-template-columns: repeat(3, 1fr); }
  .runtimes { grid-template-columns: repeat(2, 1fr); }
  .example-grid { grid-template-columns: repeat(2, 1fr); }
  .install-steps { grid-template-columns: repeat(3, 1fr); }
  .platforms { grid-template-columns: repeat(2, 1fr); }
  .compare { grid-template-columns: 1fr; }
  .context-callout { grid-template-columns: 1fr; gap: 24px; }
  .os-hub-wrap { grid-template-columns: 1fr; }
  .beforeafter { grid-template-columns: 1fr; gap: 16px; }
  .beforeafter__connector { transform: rotate(90deg); height: 40px; }

  /* Flow diagram: convert to 2-row layout on tablet */
  .flow-row {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  .flow-arrow { display: none; }
  .flow-step { min-height: 120px; }
}

@media (max-width: 640px) {
  .dienst-hero { padding: 36px 0 56px; }
  .dienst-hero__title { font-size: clamp(34px, 9vw, 48px); }
  .dienst-hero__lead { font-size: 17px; }

  .pillars { grid-template-columns: 1fr; gap: 12px; }
  .pillar { padding: 22px; }

  .outputs-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .output-card { padding: 18px 12px; }

  .runtimes { grid-template-columns: 1fr; gap: 12px; }
  .runtime { padding: 22px; }

  .example-grid { grid-template-columns: 1fr; gap: 12px; }

  .install-steps { grid-template-columns: repeat(2, 1fr); }

  .platforms { grid-template-columns: 1fr; gap: 10px; }

  .flow-row { grid-template-columns: 1fr; }
  .flow-step { min-height: 100px; padding: 16px; }

  .loopviz__steps {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px 12px;
  }
  .loop-step__circle { width: 80px; height: 80px; font-size: 12px; }

  .compare__col { padding: 22px; }
  .compare__verdict { padding: 18px 22px; font-size: 15px; }

  .os-features { grid-template-columns: 1fr; }
  .beforeafter__side { padding: 22px; min-height: 0; }

  .context-formula { padding: 18px; gap: 8px; font-size: 13px; }
  .context-formula__chip { padding: 6px 10px; }

  .dienst-back { padding: 8px 14px 8px 10px; font-size: 13px; }

  .dienst-section { padding: clamp(48px, 10vw, 72px) 0; }
}
