/*
 * Krause editorial layer
 * Shared visual roles for numbering, process sections, icon markers and section rhythm.
 * Loaded after feature styles so future tuning happens here, not per page.
 */
:root {
  --art-display: "Barlow Condensed", sans-serif;
  --art-number-display: clamp(4rem, 6vw, 6.4rem);
  --art-number-card: clamp(3rem, 4vw, 4.5rem);
  --art-number-nav: clamp(2rem, 2.8vw, 3rem);
  --art-watermark: clamp(8rem, 18vw, 19rem);
  --art-heading: clamp(3.15rem, 4.8vw, 5.15rem);
  --art-line-light: #d8e1e6;
  --art-line-dark: rgba(255,255,255,.18);
  --art-blue: #0a609d;
  --art-blue-light: #91c3e5;
  --art-ink: #071d33;
}

/* One typographic rhythm across all subpage families. */
:is(.detail-section-head,.company-section-head,.service-master-head,.service-journey__head,.location-section-head,.location-service-flow__head,.location-command__head,.offer-process header) h2 {
  font-family: var(--art-display);
  font-size: var(--art-heading);
  font-weight: 800;
  line-height: .92;
  letter-spacing: 0;
}
:is(.detail-kicker,.company-kicker,.service-journey__head span,.service-story header > span) {
  letter-spacing: 0;
  text-transform: none;
}

/* Editorial watermarks only on major orientation sections. */
:is(.detail-section.is-dark,.service-master-process,.offer-process,.location-hub-method,.company-flow) {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
:is(.detail-section.is-dark,.service-master-process,.offer-process,.location-hub-method,.company-flow)::before {
  position: absolute;
  z-index: 0;
  top: 28px;
  right: max(18px,calc((100vw - min(1320px,calc(100vw - 48px))) / 2));
  color: rgba(255,255,255,.042);
  content: "ABLAUF";
  font-family: var(--art-display);
  font-size: var(--art-watermark);
  font-weight: 900;
  line-height: .72;
  pointer-events: none;
  white-space: nowrap;
}
.location-hub-method.location-hub-method::before { content: "ROUTE"; }
.company-flow.company-flow::before { z-index: 0; color: rgba(7,29,51,.035); content: "01—05"; }
:is(.detail-section.is-dark,.service-master-process,.offer-process,.location-hub-method,.company-flow) > .eco-container { position: relative; z-index: 1; }

/* Display numbers: process grids and sequential stories. */
:is(.detail-process,.company-process,.service-master-process ol,.location-process__steps,.offer-process ol) > :is(article,li) > span {
  display: block;
  color: var(--art-blue-light);
  font-family: var(--art-display);
  font-size: var(--art-number-display);
  font-weight: 900;
  line-height: .72;
  letter-spacing: 0;
}
:is(.detail-process,.company-process) > article {
  display: flex;
  min-height: 330px;
  flex-direction: column;
  padding: 32px 30px;
}
:is(.detail-process,.company-process) > article h3 { margin-top: auto; }
.company-process.is-light > article > span { color: rgba(10,96,157,.72); }

/* Narrative numbers: still prominent, but subordinate to the title. */
:is(.company-values,.offer-benefits > div,.service-story__cases,.company-flow__stages) article > span,
.article-section-number {
  color: rgba(10,96,157,.68);
  font-family: var(--art-display);
  font-size: var(--art-number-card);
  font-weight: 900;
  line-height: .75;
  letter-spacing: 0;
}
.company-values article { display: flex; min-height: 270px; flex-direction: column; padding: 31px 28px; }
.company-values h3 { margin-top: auto; }
.offer-benefits article { grid-template-columns: 76px minmax(0,1fr); }
.service-story__cases article { grid-template-columns: 90px 48px minmax(0,1fr); }
.company-flow__stages article { grid-template-columns: 88px minmax(0,1fr) 52px; min-height: 220px; align-items: center; }
.company-flow__stages article > svg {
  display: grid;
  width: 44px;
  height: 44px;
  padding: 11px;
  border-radius: 50%;
  background: #eef4f7;
  color: var(--art-blue);
}
.article-section-number { display: block; margin-bottom: 18px; }

/* Signal grids: icon, sequence and copy behave as one editorial unit. */
:is(.detail-use-grid,.company-role-grid) {
  counter-reset: art-signal;
  border-top: 1px solid var(--art-line-light);
  border-bottom: 1px solid var(--art-line-light);
}
:is(.detail-use-grid,.company-role-grid) > article {
  position: relative;
  display: flex;
  min-height: 300px;
  flex-direction: column;
  counter-increment: art-signal;
  padding: 30px 34px 34px;
  overflow: hidden;
}
:is(.detail-use-grid,.company-role-grid) > article::after {
  position: absolute;
  top: 24px;
  right: 27px;
  color: rgba(7,29,51,.075);
  content: "0" counter(art-signal);
  font-family: var(--art-display);
  font-size: clamp(4.5rem,6vw,6.4rem);
  font-weight: 900;
  line-height: .7;
  pointer-events: none;
}
.detail-signal__icon,
.company-role-grid > article > svg {
  position: relative;
  z-index: 1;
  display: grid;
  width: 58px;
  height: 58px;
  flex: 0 0 auto;
  padding: 0;
  border-radius: 50%;
  background: var(--art-ink);
  color: #fff;
  place-items: center;
}
.detail-signal__icon > svg { width: 24px; height: 24px; color: #fff; }
.company-role-grid > article > svg { padding: 17px; }
.detail-signal__copy { margin-top: auto; }
:is(.detail-use-grid,.company-role-grid) h3 {
  margin: 0 0 10px;
  font-family: var(--art-display);
  font-size: clamp(1.9rem,2.35vw,2.45rem);
  line-height: .95;
}
.company-role-grid h3 { margin-top: auto; }
:is(.detail-use-grid,.company-role-grid) p {
  max-width: 330px;
  margin: 0;
  color: var(--sp-muted);
  font-size: .8rem;
  line-height: 1.65;
}

/* Navigation numbers: confident, but never louder than the selected route. */
:is(.location-service-flow__tabs,.location-command__tabs) button > span,
.service-journey__routes > a > small {
  font-family: var(--art-display);
  font-size: var(--art-number-nav);
  font-weight: 900;
  line-height: .75;
}
:is(.location-service-flow__tabs,.location-command__tabs) button > svg {
  width: 38px;
  height: 38px;
  padding: 9px;
  border-radius: 50%;
  background: rgba(10,96,157,.09);
  color: var(--art-blue);
}
.location-command__tabs button > svg { background: rgba(255,255,255,.1); color: #a9d0e9; }

/* Route and method blocks share the same number/icon relationship. */
:is(.location-hub-method li,.location-route__copy ol li) > span {
  color: var(--art-blue-light);
  font-family: var(--art-display);
  font-size: var(--art-number-card);
  font-weight: 900;
  line-height: .75;
}
.location-hub-method li > svg {
  width: 44px;
  height: 44px;
  padding: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.09);
}

/* Two intentional centered compositions break the left-aligned rhythm. */
.location-hub-method header,
.offer-process header {
  display: block;
  max-width: 900px;
  margin-inline: auto;
  text-align: center;
}
.location-hub-method header p,
.offer-process header > p { max-width: 680px; margin: 20px auto 0; }
.location-hub-method header .detail-kicker { display: block; margin-bottom: 12px; }

/* Preserve hierarchy on smaller screens instead of shrinking numbers into labels. */
@media (max-width: 991.98px) {
  :root { --art-number-display: clamp(3.7rem,9vw,5.2rem); --art-number-card: clamp(2.8rem,7vw,4rem); }
  .company-flow__stages article { grid-template-columns: 76px minmax(0,1fr) 48px; }
  :is(.detail-use-grid,.company-role-grid) > article { min-height: 270px; padding-inline: 26px; }
}
@media (max-width: 640px) {
  :root { --art-watermark: 7.2rem; --art-heading: clamp(2.8rem,12vw,3.65rem); }
  :is(.detail-section.is-dark,.service-master-process,.offer-process,.location-hub-method,.company-flow)::before { top: 24px; right: 18px; }
  :is(.detail-process,.company-process) > article { min-height: 250px; padding: 28px 4px; }
  .company-values article { min-height: 230px; padding-inline: 4px; }
  .offer-benefits article { grid-template-columns: 64px minmax(0,1fr); padding-inline: 4px; }
  .service-story__cases article { grid-template-columns: 64px 38px minmax(0,1fr); }
  .company-flow__stages article { grid-template-columns: 66px minmax(0,1fr) 42px; gap: 12px; }
  .company-flow__stages article > svg { display: grid; width: 38px; height: 38px; padding: 9px; }
  :is(.location-service-flow__tabs,.location-command__tabs) button > svg { display: grid; width: 34px; height: 34px; }
  :is(.detail-use-grid,.company-role-grid) > article { min-height: 230px; padding: 26px 4px 28px; }
  :is(.detail-use-grid,.company-role-grid) > article::after { top: 24px; right: 4px; font-size: 4.6rem; }
  .detail-signal__icon,.company-role-grid > article > svg { width: 52px; height: 52px; }
  .company-role-grid > article > svg { padding: 15px; }
  :is(.detail-use-grid,.company-role-grid) p { max-width: none; }
}

@media (prefers-reduced-motion: reduce) {
  :is(.detail-process,.company-process,.service-master-process,.offer-process) * { scroll-behavior: auto; }
}

/* Action stages: image, decision and contact belong to one composition. */
.action-stage { overflow: hidden; background: #071d33; color: #fff; }
.action-stage__grid { display: grid; min-height: 620px; grid-template-columns: minmax(360px,.86fr) minmax(0,1.14fr); align-items: stretch; }
.action-stage__visual { position: relative; min-height: 620px; margin: 0 0 0 calc((100vw - min(100vw,1320px))/ -2); overflow: hidden; }
.action-stage__visual::after { position: absolute; inset: 0; background: linear-gradient(90deg,transparent 56%,rgba(7,29,51,.62)); content: ""; }
.action-stage__visual img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.action-stage:hover .action-stage__visual img { transform: scale(1.018); }
.action-stage__visual figcaption { position: absolute; z-index: 1; right: 28px; bottom: 28px; display: flex; align-items: center; gap: 9px; padding: 12px 15px; border-radius: 6px; background: rgba(255,255,255,.94); color: #071d33; font-size: .68rem; font-weight: 800; }
.action-stage__visual figcaption svg { width: 17px; color: #0a609d; }
.action-stage__copy { position: relative; display: flex; max-width: 780px; flex-direction: column; justify-content: center; padding: 86px clamp(42px,6vw,100px); }
.action-stage__copy::before { position: absolute; top: 38px; right: 12px; color: rgba(255,255,255,.055); content: "K"; font-family: var(--art-display); font-size: 12rem; font-weight: 900; line-height: 1; }
.action-stage__copy .detail-kicker { color: #9bc9ed; }
.action-stage__copy h2 { position: relative; max-width: 760px; margin: 15px 0 20px; font-family: var(--art-display); font-size: clamp(3.5rem,5vw,5.8rem); line-height: .9; text-wrap: balance; }
.action-stage__copy > p { max-width: 650px; margin: 0; color: rgba(255,255,255,.67); font-size: .91rem; line-height: 1.8; }
.action-stage__actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: stretch; margin-top: 38px; }
.action-stage__actions > a { min-height: 58px; border-radius: 6px; text-decoration: none; }
.action-stage__actions .action-primary { display: inline-flex; align-items: center; gap: 11px; padding: 0 20px; }
.action-stage__actions .action-primary svg { width: 18px; }
.action-stage__actions .action-primary svg:last-child { margin-left: 5px; }
.action-stage__phone { display: flex; align-items: center; gap: 11px; padding: 0 18px; border: 1px solid rgba(255,255,255,.25); color: #fff; }
.action-stage__phone > svg { width: 18px; color: #9bc9ed; }
.action-stage__phone span { display: grid; }
.action-stage__phone small { color: rgba(255,255,255,.56); font-size: .6rem; }
.action-stage__phone b { font-size: .76rem; }
.action-stage.is-reverse .action-stage__visual { order: 2; margin-right: calc((100vw - min(100vw,1320px))/ -2); margin-left: 0; }
.action-stage.is-reverse .action-stage__visual::after { background: linear-gradient(270deg,transparent 56%,rgba(7,29,51,.62)); }
.action-stage.is-reverse .action-stage__copy { order: 1; padding-right: clamp(42px,6vw,100px); padding-left: 0; }

/* One lead form language across service, offer and contact pages. */
.lead-form { align-self: center; width: 100%; padding: 36px; border-radius: 8px; background: #fff; box-shadow: 0 24px 64px rgba(0,0,0,.2); color: #071d33; }
.lead-form__head { position: relative; margin-bottom: 25px; padding-right: 58px; }
.lead-form__head::after { position: absolute; top: -7px; right: 0; color: #dce6ec; content: "01"; font-family: var(--art-display); font-size: 3.8rem; font-weight: 900; line-height: 1; }
.lead-form__head > span { color: #0a609d; font-size: .66rem; font-weight: 820; letter-spacing: .08em; text-transform: uppercase; }
.lead-form__head h2 { margin: 8px 0; font-family: var(--art-display); font-size: 2.45rem; line-height: .94; }
.lead-form__head p { max-width: 390px; margin: 0; color: #637483; font-size: .73rem; line-height: 1.55; }
.lead-form__prefill { display: flex; align-items: center; gap: 9px; margin: -8px 0 20px; padding: 11px 13px; border-radius: 6px; background: #eaf3f8; color: #174e72; font-size: .65rem; font-weight: 750; }
.lead-form__prefill[hidden] { display: none; }
.lead-form__prefill svg { width: 16px; flex: 0 0 auto; }
.lead-form label { display: block; margin: 0 0 7px; color: #425467; font-size: .65rem; font-weight: 800; }
.lead-form__field { margin-bottom: 16px; }
.lead-form__row { display: grid; grid-template-columns: minmax(0,1fr) minmax(105px,.7fr); gap: 12px; margin-bottom: 16px; }
.lead-form__row--contact > :only-child { grid-column: 1/-1; }
.lead-form input,.lead-form select,.lead-form textarea { width: 100%; border: 1px solid #cbd6de; border-radius: 6px; outline: 0; background: #f5f8fa; color: #071d33; font: inherit; font-size: .76rem; transition: border-color .2s ease,box-shadow .2s ease,background .2s ease; }
.lead-form input,.lead-form select { height: 52px; padding: 0 13px; }
.lead-form textarea { min-height: 88px; padding: 13px; resize: vertical; }
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus { border-color: #0a609d; background: #fff; box-shadow: 0 0 0 3px rgba(10,96,157,.1); }
.lead-form__select { position: relative; }
.lead-form__select > svg { position: absolute; z-index: 1; top: 50%; width: 17px; color: #547086; pointer-events: none; transform: translateY(-50%); }
.lead-form__select > svg:first-child { left: 14px; }
.lead-form__select > svg:last-child { right: 14px; }
.lead-form__select select { padding-inline: 42px; appearance: none; }
.lead-form > button { display: flex; width: 100%; min-height: 54px; justify-content: center; align-items: center; gap: 9px; border: 0; border-radius: 6px; background: #cf1262; color: #fff; font-size: .76rem; font-weight: 820; transition: background .2s ease,transform .2s ease; }
.lead-form > button:hover { background: #a90e50; transform: translateY(-1px); }
.lead-form > button:disabled { cursor: wait; opacity: .72; transform: none; }
.lead-form > button svg { width: 17px; }
.lead-form__trap { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; opacity: 0 !important; pointer-events: none !important; }
.lead-form__status { margin: 13px 0 0; padding: 12px 14px; border-radius: 6px; font-size: .67rem; font-weight: 700; line-height: 1.5; }
.lead-form__status.is-success { background: #e8f4ed; color: #155d39; }
.lead-form__status.is-error { background: #fbecef; color: #8c1832; }
.lead-form__footer { display: flex; justify-content: space-between; gap: 14px; align-items: center; margin-top: 14px; padding-top: 15px; border-top: 1px solid #dde5ea; }
.lead-form__footer > * { display: flex; align-items: center; gap: 7px; margin: 0; color: #687987; font-size: .59rem; line-height: 1.4; text-decoration: none; }
.lead-form__footer svg { width: 15px; color: #0a609d; }
.lead-form__footer a { color: #071d33; font-weight: 800; }
.service-lead .lead-form,.offer-hero .lead-form { max-width: 470px; justify-self: end; }

.contact-stage { padding: 112px 0 124px; background: #edf2f5; }
.contact-stage__grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(390px,480px); gap: clamp(60px,8vw,120px); align-items: center; }
.contact-stage__story { display: grid; grid-template-columns: minmax(260px,.88fr) minmax(300px,1.12fr); gap: clamp(30px,4vw,64px); align-items: center; }
.contact-stage__story figure { position: relative; height: 620px; margin: 0; overflow: hidden; border-radius: 8px; }
.contact-stage__story figure img { width: 100%; height: 100%; object-fit: cover; object-position: 45% center; }
.contact-stage__story figcaption { position: absolute; right: 18px; bottom: 18px; left: 18px; display: flex; align-items: center; gap: 9px; padding: 13px 15px; border-radius: 6px; background: rgba(255,255,255,.94); color: #071d33; font-size: .65rem; font-weight: 800; }
.contact-stage__story figcaption svg { width: 17px; color: #0a609d; }
.contact-stage__story h2 { margin: 14px 0 20px; font-family: var(--art-display); font-size: clamp(3rem,4.2vw,4.8rem); line-height: .9; }
.contact-stage__story p { color: #5e7180; line-height: 1.78; }
.contact-stage__story ul { margin: 28px 0 0; padding: 0; border-top: 1px solid #c9d5dd; list-style: none; }
.contact-stage__story li { display: flex; min-height: 70px; align-items: center; gap: 13px; border-bottom: 1px solid #c9d5dd; }
.contact-stage__story li > svg { width: 19px; color: #0a609d; }
.contact-stage__story li span { display: grid; min-width: 0; }
.contact-stage__story li b { overflow-wrap: anywhere; font-size: .73rem; }
.contact-stage__story li small { color: #70808d; font-size: .61rem; }
.contact-stage .lead-form { box-shadow: 0 20px 50px rgba(7,29,51,.1); }

@media (max-width: 1100px) {
  .action-stage__grid { grid-template-columns: minmax(300px,.8fr) minmax(0,1.2fr); }
  .contact-stage__grid { grid-template-columns: 1fr 420px; gap: 45px; }
  .contact-stage__story { grid-template-columns: 1fr; }
  .contact-stage__story figure { height: 370px; }
}
@media (max-width: 767.98px) {
  .action-stage__grid { display: flex; min-height: 0; flex-direction: column; }
  .action-stage__visual,.action-stage.is-reverse .action-stage__visual { order: 1; min-height: 330px; margin: 0 -20px; }
  .action-stage__visual::after,.action-stage.is-reverse .action-stage__visual::after { background: linear-gradient(0deg,rgba(7,29,51,.45),transparent 55%); }
  .action-stage__visual figcaption { right: 18px; bottom: 18px; }
  .action-stage__copy,.action-stage.is-reverse .action-stage__copy { order: 2; padding: 58px 0 68px; }
  .action-stage__copy::before { top: 20px; right: 0; font-size: 8rem; }
  .action-stage__copy h2 { font-size: clamp(3rem,14vw,4rem); }
  .action-stage__actions { flex-direction: column; }
  .action-stage__actions > a { width: 100%; justify-content: center; }
  .lead-form { padding: 28px 20px; }
  .lead-form__row { grid-template-columns: 1fr; }
  .lead-form__footer { align-items: stretch; flex-direction: column; }
  .contact-stage { padding: 72px 0; }
  .contact-stage__grid { grid-template-columns: 1fr; }
  .contact-stage__story { grid-template-columns: 1fr; }
  .contact-stage__story figure { height: 430px; }
}

/* Ratgeber hub: a searchable knowledge desk, not a generic blog grid. */
.guide-hub-hero { position: relative; overflow: hidden; padding: 86px 0 0; background: #071d33; color: #fff; }
.guide-hub-hero__watermark { position: absolute; top: 40px; left: max(24px,calc((100vw - min(1320px,calc(100vw - 48px))) / 2)); color: rgba(255,255,255,.045); font-family: var(--art-display); font-size: clamp(8rem,15vw,14rem); font-weight: 900; line-height: .75; pointer-events: none; }
.guide-hub-hero__grid { position: relative; display: grid; grid-template-columns: minmax(0,1.05fr) minmax(420px,.95fr); gap: clamp(55px,8vw,120px); align-items: center; }
.guide-hub-hero__copy { position: relative; z-index: 1; padding-bottom: 110px; }
.guide-hub-hero .guide-kicker { color: #9bc9ed; }
.guide-hub-hero__copy h1 { max-width: 760px; margin: 17px 0 25px; font-family: var(--art-display); font-size: clamp(4.6rem,6.8vw,7.3rem); line-height: .86; text-wrap: balance; }
.guide-hub-hero__copy > p { max-width: 690px; margin: 0; color: rgba(255,255,255,.7); font-size: 1rem; line-height: 1.8; }
.guide-hub-hero__copy ul { display: flex; flex-wrap: wrap; gap: 12px 25px; margin: 34px 0 0; padding: 22px 0 0; border-top: 1px solid rgba(255,255,255,.2); list-style: none; }
.guide-hub-hero__copy li { display: inline-flex; align-items: center; gap: 7px; color: rgba(255,255,255,.82); font-size: .69rem; font-weight: 730; }
.guide-hub-hero__copy li svg { width: 15px; color: #9bc9ed; }
.guide-hub-feature { position: relative; display: block; align-self: stretch; min-height: 650px; overflow: hidden; color: #fff; text-decoration: none; }
.guide-hub-feature::after { position: absolute; inset: 25% 0 0; background: linear-gradient(transparent,rgba(3,16,28,.94)); content: ""; }
.guide-hub-feature > img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.guide-hub-feature:hover > img { transform: scale(1.025); }
.guide-hub-feature > span { position: absolute; z-index: 1; top: 24px; left: 24px; display: inline-flex; align-items: center; gap: 8px; padding: 10px 13px; border-radius: 5px; background: rgba(255,255,255,.95); color: #071d33; font-size: .65rem; font-weight: 820; text-transform: uppercase; }
.guide-hub-feature > span svg { width: 16px; color: #cf1765; }
.guide-hub-feature > div { position: absolute; z-index: 1; right: 34px; bottom: 112px; left: 34px; display: grid; }
.guide-hub-feature small { color: #acd3ed; font-size: .65rem; font-weight: 800; text-transform: uppercase; }
.guide-hub-feature strong { max-width: 520px; margin: 10px 0 20px; font-family: var(--art-display); font-size: 2.75rem; line-height: .96; }
.guide-hub-feature b { display: inline-flex; align-items: center; gap: 8px; font-size: .7rem; }
.guide-hub-feature b svg { width: 16px; }
.guide-hub-search { position: absolute; z-index: 3; right: 0; bottom: 0; left: 0; display: grid; min-height: 92px; grid-template-columns: 28px minmax(0,1fr) 38px auto; gap: 14px; align-items: center; padding: 15px 20px; border-radius: 8px 8px 0 0; background: #fff; box-shadow: 0 -16px 45px rgba(0,0,0,.12); color: #071d33; }
.guide-hub-search > svg { width: 22px; color: #07539b; }
.guide-hub-search > div { display: grid; }
.guide-hub-search label { color: #526975; font-size: .58rem; font-weight: 820; text-transform: uppercase; }
.guide-hub-search input { min-width: 0; border: 0; outline: 0; background: transparent; color: #071d33; font: 650 .95rem var(--eco-body); }
.guide-hub-search input::placeholder { color: #84919a; font-weight: 500; }
.guide-hub-search button { display: grid; width: 36px; height: 36px; border: 0; border-radius: 50%; background: #edf2f5; color: #294553; place-items: center; }
.guide-hub-search button[hidden] { display: none; }
.guide-hub-search button:hover { background: #dfe8ed; }
.guide-hub-search button svg { width: 16px; }
.guide-hub-search > span { padding-left: 20px; border-left: 1px solid #d7e0e5; color: #07539b; font-size: .65rem; font-weight: 800; white-space: nowrap; }

.guide-journeys { padding: 116px 0 126px; background: #fff; }
.guide-journeys > div > header { display: grid; grid-template-columns: 1.1fr .9fr; gap: 80px; align-items: end; margin-bottom: 52px; }
.guide-journeys header h2 { max-width: 760px; margin: 13px 0 0; font-family: var(--art-display); font-size: clamp(3.7rem,5.4vw,5.8rem); line-height: .9; }
.guide-journeys header > p { max-width: 520px; margin: 0; color: var(--sp-muted); line-height: 1.8; }
.guide-journeys__grid { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid #cad5dc; border-bottom: 1px solid #cad5dc; }
.guide-journeys__grid > a { position: relative; display: grid; min-height: 430px; grid-template-columns: 58px 48px minmax(0,1fr); gap: 15px; align-content: start; padding: 34px 28px; overflow: hidden; border-right: 1px solid #cad5dc; color: #071d33; text-decoration: none; transition: background .2s ease; }
.guide-journeys__grid > a:last-child { border-right: 0; }
.guide-journeys__grid > a:hover { background: #eef4f7; }
.guide-journeys__grid > a > span { color: #afbdc6; font-family: var(--art-display); font-size: 3.2rem; font-weight: 900; line-height: .85; }
.guide-journeys__grid > a > svg { width: 44px; height: 44px; padding: 11px; border-radius: 50%; background: #071d33; color: #fff; }
.guide-journeys__grid > a > div { display: flex; min-width: 0; min-height: 355px; flex-direction: column; padding-top: 4px; }
.guide-journeys__grid small { color: #07539b; font-size: .61rem; font-weight: 820; text-transform: uppercase; }
.guide-journeys__grid h3 { margin: 24px 0 14px; font-family: var(--art-display); font-size: 2.25rem; line-height: .95; }
.guide-journeys__grid p { margin: 0; color: var(--sp-muted); font-size: .75rem; line-height: 1.65; }
.guide-journeys__grid b { display: inline-flex; align-items: center; gap: 8px; margin-top: auto; color: #07539b; font-size: .69rem; }
.guide-journeys__grid b svg { width: 15px; }

.guide-library-v2 { padding: 120px 0 132px; background: #eef3f6; }
.guide-library-v2__head { display: grid; grid-template-columns: 1fr auto; gap: 50px; align-items: end; margin-bottom: 34px; }
.guide-library-v2__head h2 { margin: 13px 0 0; font-family: var(--art-display); font-size: clamp(3.8rem,5.4vw,5.8rem); line-height: .9; }
.guide-library-v2__head > p { display: grid; margin: 0; text-align: right; }
.guide-library-v2__head strong { color: #071d33; font-size: .78rem; }
.guide-library-v2__head p span { margin-top: 4px; color: var(--sp-muted); font-size: .65rem; }
.guide-filterbar { display: flex; gap: 4px; overflow-x: auto; padding: 8px 0 22px; border-bottom: 1px solid #c8d4dc; scrollbar-width: thin; }
.guide-filterbar button { display: inline-grid; min-width: max-content; min-height: 54px; grid-template-columns: 19px auto auto; gap: 8px; align-items: center; padding: 0 13px; border: 0; border-radius: 6px; background: transparent; color: #4f6470; font: 750 .69rem var(--eco-body); }
.guide-filterbar button:hover { background: #fff; color: #071d33; }
.guide-filterbar button.is-active { background: #071d33; color: #fff; }
.guide-filterbar button > svg { width: 17px; color: #07539b; }
.guide-filterbar button.is-active > svg { color: #9bc9ed; }
.guide-filterbar button small { display: grid; min-width: 22px; height: 22px; border-radius: 50%; background: rgba(7,29,51,.08); color: inherit; font-size: .56rem; place-items: center; }
.guide-filterbar button.is-active small { background: rgba(255,255,255,.13); }
.guide-editorial-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 28px 22px; padding-top: 38px; }
.guide-editorial-card { display: grid; min-width: 0; grid-template-rows: 230px 1fr; overflow: hidden; border-radius: 8px; background: #fff; }
.guide-editorial-card[hidden] { display: none; }
.guide-editorial-card.is-lead { grid-column: span 2; grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); grid-template-rows: 1fr; }
.guide-editorial-card.is-tail { grid-column: 1/-1; grid-template-columns: minmax(300px,.62fr) minmax(0,1.38fr); grid-template-rows: 1fr; }
.guide-editorial-card__image { position: relative; min-height: 250px; overflow: hidden; background: #dfe7ec; }
.guide-editorial-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.guide-editorial-card:hover .guide-editorial-card__image img { transform: scale(1.025); }
.guide-editorial-card__image > span { position: absolute; top: 18px; left: 18px; color: rgba(255,255,255,.92); font-family: var(--art-display); font-size: 3.4rem; font-weight: 900; line-height: 1; text-shadow: 0 2px 18px rgba(0,0,0,.2); }
.guide-editorial-card__body { display: flex; min-height: 320px; flex-direction: column; padding: 27px 28px 30px; }
.guide-editorial-card.is-lead .guide-editorial-card__body { min-height: 550px; justify-content: center; padding: 42px; }
.guide-editorial-card.is-tail .guide-editorial-card__body { min-height: 390px; justify-content: center; padding: 40px; }
.guide-editorial-card.is-tail h3 { font-size: clamp(2.6rem,3.2vw,3.7rem); }
.guide-editorial-card__body > div { display: flex; justify-content: space-between; gap: 14px; color: var(--sp-muted); font-size: .61rem; }
.guide-editorial-card__body > div span { color: #07539b; font-weight: 820; text-transform: uppercase; }
.guide-editorial-card h3 { margin: 18px 0 13px; font-family: var(--art-display); font-size: 2.25rem; line-height: .95; }
.guide-editorial-card.is-lead h3 { font-size: clamp(2.8rem,3.5vw,4rem); }
.guide-editorial-card h3 a { color: #071d33; text-decoration: none; }
.guide-editorial-card h3 a:hover { color: #07539b; }
.guide-editorial-card p { margin: 0 0 24px; color: var(--sp-muted); font-size: .75rem; line-height: 1.7; }
.guide-editorial-card__body > a { display: inline-flex; width: fit-content; align-items: center; gap: 8px; margin-top: auto; color: #07539b; font-size: .69rem; font-weight: 820; text-decoration: none; }
.guide-editorial-card__body > a svg { width: 15px; }

.guide-principles { padding: 118px 0; background: #fff; }
.guide-principles header { display: grid; grid-template-columns: 300px minmax(0,1fr); gap: 80px; align-items: start; margin-bottom: 54px; }
.guide-principles header h2 { max-width: 900px; margin: 0; font-family: var(--art-display); font-size: clamp(3.5rem,5vw,5.3rem); line-height: .9; }
.guide-principles > div > div { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid #cbd6de; border-bottom: 1px solid #cbd6de; }
.guide-principles article { display: grid; min-height: 330px; grid-template-columns: 66px 48px minmax(0,1fr); gap: 16px; align-content: start; padding: 34px 28px; border-right: 1px solid #cbd6de; }
.guide-principles article:last-child { border-right: 0; }
.guide-principles article > span { color: #b1bec7; font-family: var(--art-display); font-size: 3.3rem; font-weight: 900; }
.guide-principles article > svg { width: 44px; height: 44px; padding: 11px; border-radius: 50%; background: #071d33; color: #fff; }
.guide-principles article h3 { grid-column: 1/-1; margin: 62px 0 10px; font-family: var(--art-display); font-size: 2rem; line-height: 1; }
.guide-principles article p { grid-column: 1/-1; max-width: 330px; margin: 0; color: var(--sp-muted); font-size: .76rem; line-height: 1.7; }

@media (max-width: 991.98px) {
  .guide-hub-hero { padding-top: 70px; }
  .guide-hub-hero__grid { grid-template-columns: 1fr; }
  .guide-hub-hero__copy { padding-bottom: 20px; }
  .guide-hub-feature { min-height: 540px; }
  .guide-hub-search { position: relative; grid-column: 1; margin-top: -92px; }
  .guide-journeys > div > header,.guide-principles header { grid-template-columns: 1fr; gap: 24px; }
  .guide-journeys__grid,.guide-principles > div > div { grid-template-columns: 1fr; }
  .guide-journeys__grid > a,.guide-principles article { min-height: 290px; border-right: 0; border-bottom: 1px solid #cad5dc; }
  .guide-journeys__grid > a > div { min-height: 220px; }
  .guide-editorial-grid { grid-template-columns: 1fr 1fr; }
  .guide-editorial-card.is-lead,.guide-editorial-card.is-tail { grid-column: 1/-1; }
}
@media (max-width: 640px) {
  .guide-hub-hero { padding-top: 58px; }
  .guide-hub-hero__copy h1 { font-size: 4rem; }
  .guide-hub-feature { min-height: 480px; margin-inline: -20px; }
  .guide-hub-feature > div { right: 22px; bottom: 122px; left: 22px; }
  .guide-hub-feature strong { font-size: 2.35rem; }
  .guide-hub-search { grid-template-columns: 23px minmax(0,1fr) 36px; min-height: 106px; margin-top: -106px; padding-inline: 14px; }
  .guide-hub-search > span { grid-column: 1/-1; padding: 7px 0 0; border-top: 1px solid #d7e0e5; border-left: 0; }
  .guide-journeys,.guide-library-v2,.guide-principles { padding-block: 76px; }
  .guide-journeys__grid > a { min-height: 390px; grid-template-columns: 50px 42px minmax(0,1fr); padding-inline: 4px; }
  .guide-library-v2__head { grid-template-columns: 1fr; gap: 14px; }
  .guide-library-v2__head > p { text-align: left; }
  .guide-editorial-grid { grid-template-columns: 1fr; }
  .guide-editorial-card,.guide-editorial-card.is-lead,.guide-editorial-card.is-tail { grid-column: auto; grid-template-columns: 1fr; grid-template-rows: 250px 1fr; }
  .guide-editorial-card.is-lead .guide-editorial-card__body { min-height: 380px; justify-content: flex-start; padding: 28px; }
  .guide-editorial-card.is-tail .guide-editorial-card__body { min-height: 350px; justify-content: flex-start; padding: 28px; }
  .guide-editorial-card.is-lead h3 { font-size: 2.5rem; }
  .guide-principles article { grid-template-columns: 58px 44px minmax(0,1fr); padding-inline: 4px; }
}

/* Ratgeber UX correction: visible search, compact scanning, stable filter states. */
.guide-hub-hero { padding: 56px 0; }
.guide-hub-hero__grid { min-height: 520px; align-items: center; }
.guide-hub-hero__copy { padding-bottom: 0; }
.guide-hub-hero__copy h1 { margin-block: 14px 20px; font-size: clamp(4rem,5.5vw,5.8rem); }
.guide-hub-hero__copy > p { line-height: 1.65; }
.guide-hub-search { position: relative; right: auto; bottom: auto; left: auto; max-width: 700px; min-height: 82px; grid-template-columns: 24px minmax(0,1fr) 36px; margin-top: 24px; padding: 11px 16px; border-radius: 8px; box-shadow: none; }
.guide-hub-search > span { grid-column: 1/-1; padding: 7px 0 0; border-top: 1px solid #d7e0e5; border-left: 0; }
.guide-hub-hero__copy ul { margin-top: 18px; padding-top: 16px; }
.guide-hub-visual { position: relative; min-height: 520px; margin: 0; overflow: hidden; border-radius: 8px; }
.guide-hub-visual::after { position: absolute; inset: 38% 0 0; background: linear-gradient(transparent,rgba(3,16,28,.88)); content: ""; }
.guide-hub-visual img { width: 100%; height: 100%; object-fit: cover; object-position: center 42%; }
.guide-hub-visual figcaption { position: absolute; z-index: 1; right: 28px; bottom: 28px; left: 28px; display: grid; color: #fff; }
.guide-hub-visual figcaption span { color: #acd3ed; font-size: .61rem; font-weight: 820; text-transform: uppercase; }
.guide-hub-visual figcaption strong { margin-top: 7px; font-family: var(--art-display); font-size: 2.5rem; line-height: .96; }
.guide-hub-visual figcaption small { margin-top: 14px; color: rgba(255,255,255,.68); font-size: .64rem; }
.guide-journeys { padding: 82px 0 90px; }
.guide-journeys > div > header { margin-bottom: 34px; }
.guide-journeys__grid > a { min-height: 330px; grid-template-columns: 52px 44px minmax(0,1fr); padding: 28px 24px; }
.guide-journeys__grid > a > span { font-size: 2.8rem; }
.guide-journeys__grid > a > div { min-height: 274px; }
.guide-journeys__grid h3 { margin-top: 18px; font-size: 2rem; }
.guide-library-v2 { padding: 88px 0 98px; }
.guide-editorial-grid { grid-template-columns: 1fr 1fr; gap: 20px; padding-top: 30px; }
.guide-editorial-card,.guide-editorial-card.is-tail { grid-column: auto; grid-template-columns: 190px minmax(0,1fr); grid-template-rows: 1fr; min-height: 300px; }
.guide-editorial-card.is-lead { grid-column: 1/-1; grid-template-columns: minmax(360px,.9fr) minmax(0,1.1fr); min-height: 430px; }
.guide-editorial-card__image { min-height: 100%; }
.guide-editorial-card__body,.guide-editorial-card.is-tail .guide-editorial-card__body { min-height: 300px; justify-content: flex-start; padding: 25px 25px 27px; }
.guide-editorial-card.is-lead .guide-editorial-card__body { min-height: 430px; padding: 38px 42px; }
.guide-editorial-card h3 { margin: 15px 0 11px; font-size: 1.85rem; }
.guide-editorial-card.is-lead h3 { font-size: clamp(2.7rem,3.5vw,3.9rem); }
.guide-editorial-card p { display: -webkit-box; overflow: hidden; margin-bottom: 18px; -webkit-box-orient: vertical; -webkit-line-clamp: 3; }
.guide-editorial-card.is-lead p { display: block; max-width: 650px; }
.guide-editorial-grid.has-single-result .guide-editorial-card:not([hidden]) { grid-column: 1/-1; grid-template-columns: minmax(280px,.65fr) minmax(0,1.35fr); min-height: 340px; }
.guide-editorial-grid.has-single-result .guide-editorial-card:not([hidden]) .guide-editorial-card__body { min-height: 340px; justify-content: center; }

@media (max-width: 991.98px) {
  .guide-hub-hero__grid { grid-template-columns: 1fr; }
  .guide-hub-visual { min-height: 480px; margin-top: 36px; }
  .guide-editorial-card { grid-template-columns: 160px minmax(0,1fr); }
}
@media (max-width: 640px) {
  .guide-hub-hero { padding: 48px 0 0; }
  .guide-hub-hero__copy h1 { font-size: 3.5rem; }
  .guide-hub-search { grid-template-columns: 22px minmax(0,1fr) 34px; margin-top: 24px; }
  .guide-hub-visual { min-height: 410px; margin: 34px -20px 0; border-radius: 0; }
  .guide-journeys,.guide-library-v2 { padding-block: 68px; }
  .guide-journeys__grid > a { min-height: 320px; grid-template-columns: 48px 40px minmax(0,1fr); padding-inline: 4px; }
  .guide-editorial-grid { grid-template-columns: 1fr; }
  .guide-editorial-card,.guide-editorial-card.is-lead,.guide-editorial-grid.has-single-result .guide-editorial-card:not([hidden]) { grid-column: auto; grid-template-columns: 1fr; grid-template-rows: 210px 1fr; min-height: 0; }
  .guide-editorial-card__body,.guide-editorial-card.is-lead .guide-editorial-card__body,.guide-editorial-grid.has-single-result .guide-editorial-card:not([hidden]) .guide-editorial-card__body { min-height: 300px; justify-content: flex-start; padding: 25px 22px 28px; }
  .guide-editorial-card.is-lead h3 { font-size: 2.45rem; }
}

/* Anliegen system: urgency, observation, route and conversion as one journey. */
.issue-triage { padding: 112px 0; background: #fff; }
.issue-triage__grid { display: grid; grid-template-columns: minmax(0,.9fr) minmax(0,1.1fr); gap: 54px clamp(70px,9vw,145px); align-items: start; }
.issue-triage header h2 { max-width: 650px; margin: 13px 0 22px; font-family: var(--art-display); font-size: clamp(3.4rem,5vw,5.4rem); line-height: .9; }
.issue-triage header > p { max-width: 570px; margin: 0; color: var(--sp-muted); line-height: 1.8; }
.issue-triage ol { margin: 0; padding: 0; border-top: 1px solid #cbd6de; list-style: none; counter-reset: none; }
.issue-triage ol li { display: grid; min-height: 102px; grid-template-columns: 82px minmax(0,1fr); gap: 20px; align-items: center; border-bottom: 1px solid #cbd6de; }
.issue-triage ol span { color: #aebdc8; font-family: var(--art-display); font-size: 3.4rem; font-weight: 900; line-height: 1; }
.issue-triage ol p { max-width: 520px; margin: 0; color: #18384c; font-size: .86rem; font-weight: 720; line-height: 1.55; }
.issue-triage aside { display: grid; grid-column: 1/-1; grid-template-columns: 58px minmax(0,1fr) auto; gap: 22px; align-items: center; min-height: 128px; padding: 28px 32px; border-radius: 8px; background: #071d33; color: #fff; }
.issue-triage aside > svg { width: 50px; height: 50px; padding: 13px; border-radius: 50%; background: rgba(255,255,255,.1); color: #ffb6d3; }
.issue-triage aside span { color: #9bc9ed; font-size: .65rem; font-weight: 820; text-transform: uppercase; }
.issue-triage aside p { max-width: 800px; margin: 6px 0 0; color: rgba(255,255,255,.72); font-size: .78rem; line-height: 1.65; }
.issue-triage aside a { display: inline-flex; min-height: 50px; align-items: center; gap: 9px; padding: 0 17px; border: 1px solid rgba(255,255,255,.26); border-radius: 6px; color: #fff; font-size: .7rem; font-weight: 800; text-decoration: none; white-space: nowrap; }
.issue-triage aside a:hover { border-color: #cf1765; background: #cf1765; }
.issue-triage aside a svg { width: 17px; }

.issue-observe { padding: 118px 0; background: #eef3f6; }
.issue-observe__grid { display: grid; grid-template-columns: minmax(360px,.8fr) minmax(0,1.2fr); gap: clamp(60px,8vw,130px); align-items: stretch; }
.issue-observe figure { position: relative; min-height: 720px; margin: 0; overflow: hidden; border-radius: 8px; }
.issue-observe figure::after { position: absolute; inset: 52% 0 0; background: linear-gradient(transparent,rgba(5,24,40,.78)); content: ""; }
.issue-observe figure img { width: 100%; height: 100%; object-fit: cover; }
.issue-observe figcaption { position: absolute; z-index: 1; right: 28px; bottom: 28px; left: 28px; display: grid; color: #fff; }
.issue-observe figcaption span { color: #afd5ee; font-size: .65rem; font-weight: 820; text-transform: uppercase; }
.issue-observe figcaption b { margin-top: 6px; font-family: var(--art-display); font-size: 2.1rem; line-height: 1; }
.issue-observe__content { align-self: center; }
.issue-observe__content header h2 { max-width: 700px; margin: 13px 0 20px; font-family: var(--art-display); font-size: clamp(3.4rem,5vw,5.3rem); line-height: .9; }
.issue-observe__content header > p { max-width: 620px; margin: 0; color: var(--sp-muted); line-height: 1.8; }
.issue-observe__signals { margin-top: 40px; border-top: 1px solid #c7d3db; }
.issue-observe__signals article { display: grid; min-height: 128px; grid-template-columns: 64px 48px minmax(0,1fr); gap: 18px; align-items: center; border-bottom: 1px solid #c7d3db; }
.issue-observe__signals article > span { color: #b3c0c9; font-family: var(--art-display); font-size: 2.8rem; font-weight: 900; }
.issue-observe__signals article > svg { width: 42px; height: 42px; padding: 10px; border-radius: 50%; background: #071d33; color: #fff; }
.issue-observe__signals h3 { margin: 0 0 7px; font-family: var(--art-display); font-size: 1.9rem; line-height: 1; }
.issue-observe__signals p { max-width: 520px; margin: 0; color: var(--sp-muted); font-size: .75rem; line-height: 1.6; }

.issue-process { padding-block: 124px; }
.issue-process .detail-process article { min-height: 330px; }
.issue-process .detail-process article h3 { margin-top: auto; }

.issue-route { padding: 118px 0; background: #fff; }
.issue-route__grid { display: grid; grid-template-columns: minmax(0,1.1fr) minmax(360px,.9fr); gap: clamp(70px,9vw,145px); align-items: end; }
.issue-route__lead h2 { margin: 13px 0 20px; font-family: var(--art-display); font-size: clamp(3.5rem,5vw,5.5rem); line-height: .9; }
.issue-route__lead > p { max-width: 680px; color: var(--sp-muted); line-height: 1.8; }
.issue-route__lead ul { display: grid; margin: 30px 0 32px; padding: 0; border-top: 1px solid #d3dce2; list-style: none; }
.issue-route__lead li { display: grid; min-height: 56px; grid-template-columns: 22px 1fr; gap: 10px; align-items: center; border-bottom: 1px solid #d3dce2; color: #294553; font-size: .76rem; font-weight: 700; }
.issue-route__lead li svg { width: 16px; color: #07539b; }
.issue-route__lead > a { display: inline-flex; min-height: 53px; align-items: center; gap: 10px; padding: 0 18px; border-radius: 6px; background: #07539b; color: #fff; font-size: .73rem; font-weight: 800; text-decoration: none; }
.issue-route__lead > a:hover { background: #043f78; }
.issue-route__lead > a svg { width: 17px; }
.issue-route nav { border-top: 1px solid #cbd6de; }
.issue-route nav a { display: grid; min-height: 104px; grid-template-columns: 44px minmax(0,1fr) 22px; gap: 18px; align-items: center; border-bottom: 1px solid #cbd6de; color: #071d33; text-decoration: none; transition: padding .2s ease,color .2s ease; }
.issue-route nav a:hover { padding-left: 10px; color: #07539b; }
.issue-route nav a > svg:first-child { width: 42px; height: 42px; padding: 10px; border-radius: 50%; background: #eaf2f7; color: #07539b; }
.issue-route nav a > svg:last-child { width: 18px; }
.issue-route nav span { display: grid; }
.issue-route nav small { color: #72818c; font-size: .61rem; }
.issue-route nav b { margin-top: 4px; font-family: var(--art-display); font-size: 1.35rem; line-height: 1; }

.issue-request { padding: 118px 0; background: #eaf0f4; }
.issue-request__grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(410px,480px); gap: clamp(60px,8vw,120px); align-items: center; }
.issue-request__story { display: grid; grid-template-columns: minmax(280px,.8fr) minmax(300px,1.2fr); gap: clamp(34px,5vw,72px); align-items: center; }
.issue-request__story figure { position: relative; height: 650px; margin: 0; overflow: hidden; border-radius: 8px; }
.issue-request__story figure img { width: 100%; height: 100%; object-fit: cover; }
.issue-request__story figcaption { position: absolute; right: 18px; bottom: 18px; left: 18px; display: flex; align-items: center; gap: 8px; padding: 12px 14px; border-radius: 6px; background: rgba(255,255,255,.94); color: #071d33; font-size: .63rem; font-weight: 800; }
.issue-request__story figcaption svg { width: 16px; color: #07539b; }
.issue-request__story h2 { margin: 13px 0 20px; font-family: var(--art-display); font-size: clamp(3.2rem,4.5vw,5rem); line-height: .9; }
.issue-request__story p { color: var(--sp-muted); line-height: 1.8; }
.issue-request__story ul { margin: 28px 0 0; padding: 0; border-top: 1px solid #c7d3db; list-style: none; }
.issue-request__story li { display: grid; min-height: 58px; grid-template-columns: 22px 1fr; gap: 10px; align-items: center; border-bottom: 1px solid #c7d3db; color: #294553; font-size: .7rem; font-weight: 720; }
.issue-request__story li svg { width: 16px; color: #07539b; }
.issue-request .lead-form { box-shadow: 0 20px 54px rgba(7,29,51,.11); }

.issue-hub { padding: 120px 0 132px; background: #f0f4f6; }
.issue-hub__head { display: grid; grid-template-columns: 1.15fr .85fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.issue-hub__head h2 { margin: 13px 0 0; font-family: var(--art-display); font-size: clamp(3.8rem,5.5vw,6rem); line-height: .9; }
.issue-hub__head > p { max-width: 530px; margin: 0; color: var(--sp-muted); line-height: 1.8; }
.issue-hub__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.issue-hub__grid > a { display: grid; min-height: 390px; grid-template-columns: minmax(190px,.82fr) minmax(0,1.18fr); overflow: hidden; border-radius: 8px; background: #fff; color: #071d33; text-decoration: none; transition: transform .25s ease,box-shadow .25s ease; }
.issue-hub__grid > a:hover { box-shadow: 0 20px 44px rgba(7,29,51,.1); transform: translateY(-4px); }
.issue-hub__grid figure { min-height: 100%; margin: 0; overflow: hidden; }
.issue-hub__grid figure img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.issue-hub__grid > a:hover figure img { transform: scale(1.03); }
.issue-hub__grid > a > div { display: flex; min-width: 0; flex-direction: column; padding: 34px 30px; }
.issue-hub__grid span { color: #07539b; font-size: .62rem; font-weight: 820; text-transform: uppercase; }
.issue-hub__grid h2 { margin: 28px 0 12px; font-family: var(--art-display); font-size: 2.55rem; line-height: .92; }
.issue-hub__grid p { margin: 0; color: var(--sp-muted); font-size: .73rem; line-height: 1.65; }
.issue-hub__grid b { display: flex; align-items: center; gap: 8px; margin-top: auto; color: #07539b; font-size: .68rem; }
.issue-hub__grid b svg { width: 15px; }
.issue-hub__emergency { background: #fff; }
.issue-hub__emergency > div { display: flex; min-height: 128px; justify-content: space-between; gap: 32px; align-items: center; }
.issue-hub__emergency > div > div { display: flex; align-items: center; gap: 17px; }
.issue-hub__emergency > div > div > svg { width: 48px; height: 48px; padding: 13px; border-radius: 50%; background: #071d33; color: #fff; }
.issue-hub__emergency span { display: grid; }
.issue-hub__emergency small { color: #07539b; font-size: .62rem; font-weight: 820; text-transform: uppercase; }
.issue-hub__emergency b { margin-top: 5px; font-family: var(--art-display); font-size: 1.5rem; }
.issue-hub__emergency a { display: inline-flex; min-height: 52px; align-items: center; gap: 9px; padding: 0 18px; border-radius: 6px; background: #cf1765; color: #fff; font-size: .72rem; font-weight: 820; text-decoration: none; }
.issue-hub__emergency a:hover { background: #a80f50; }
.issue-hub__emergency a svg { width: 17px; }

@media (max-width: 1100px) {
  .issue-observe__grid { grid-template-columns: minmax(320px,.75fr) minmax(0,1.25fr); gap: 55px; }
  .issue-request__grid { grid-template-columns: 1fr 420px; gap: 48px; }
  .issue-request__story { grid-template-columns: 1fr; }
  .issue-request__story figure { height: 360px; }
  .issue-hub__grid > a { grid-template-columns: 1fr; grid-template-rows: 230px 1fr; }
}
@media (max-width: 767.98px) {
  .issue-triage,.issue-observe,.issue-route,.issue-request,.issue-hub { padding-block: 76px; }
  .issue-triage__grid,.issue-observe__grid,.issue-route__grid,.issue-request__grid,.issue-hub__head { grid-template-columns: 1fr; gap: 44px; }
  .issue-triage ol li { grid-template-columns: 62px minmax(0,1fr); }
  .issue-triage aside { grid-template-columns: 48px minmax(0,1fr); padding: 24px 20px; }
  .issue-triage aside > svg { width: 44px; height: 44px; }
  .issue-triage aside a { grid-column: 1/-1; justify-content: center; }
  .issue-observe figure { min-height: 500px; }
  .issue-observe__signals article { grid-template-columns: 52px 42px minmax(0,1fr); gap: 12px; }
  .issue-request__story { grid-template-columns: 1fr; }
  .issue-request__story figure { height: 460px; }
  .issue-hub__grid { grid-template-columns: 1fr; }
  .issue-hub__grid > a { grid-template-columns: 1fr; grid-template-rows: 270px 1fr; min-height: 560px; }
  .issue-hub__emergency > div { align-items: stretch; flex-direction: column; padding-block: 30px; }
  .issue-hub__emergency a { justify-content: center; }
}

@media (max-width: 640px) {
  main .company-intro h2,main .company-section-head h2 { font-size: 2.6rem; }
  .company-intro-grid > *,.company-section-head > * { min-width: 0; }
  .action-stage__visual,.action-stage.is-reverse .action-stage__visual {
    width: 100vw;
    margin-inline: calc((100% - 100vw) / 2);
  }
}

/* Company story system: image-led compositions instead of repeated text grids. */
.company-story-stage { position: relative; overflow: hidden; padding: 112px 0; background: #fff; }
.company-story-stage::before { position: absolute; top: 38px; right: max(20px,calc((100vw - 1320px)/2)); color: rgba(7,29,51,.035); content: attr(data-watermark); font-family: var(--art-display); font-size: clamp(8rem,14vw,14rem); font-weight: 900; line-height: .75; pointer-events: none; white-space: nowrap; }
.company-story-stage.is-soft { background: #eef3f6; }
.company-story-stage.is-dark { background: #071d33; color: #fff; }
.company-story-stage.is-dark::before { color: rgba(255,255,255,.045); }
.company-story-stage__grid { position: relative; display: grid; grid-template-columns: minmax(380px,.92fr) minmax(0,1.08fr); gap: clamp(68px,9vw,150px); align-items: center; }
.company-story-stage.is-reverse .company-story-stage__media { order: 2; }
.company-story-stage.is-reverse .company-story-stage__copy { order: 1; }
.company-story-stage__media { position: relative; min-height: 690px; margin: 0; overflow: hidden; border-radius: 8px; }
.company-story-stage__media::after { position: absolute; inset: 48% 0 0; background: linear-gradient(transparent,rgba(3,18,31,.78)); content: ""; }
.company-story-stage__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.company-story-stage:hover .company-story-stage__media img { transform: scale(1.018); }
.company-story-stage__media figcaption { position: absolute; z-index: 1; right: 24px; bottom: 24px; left: 24px; display: flex; align-items: center; gap: 10px; color: #fff; font-size: .7rem; font-weight: 800; }
.company-story-stage__media figcaption svg { width: 18px; color: #a8d1ed; }
.company-story-stage__copy { position: relative; min-width: 0; }
.company-story-stage.is-dark .company-kicker { color: #a8d1ed; }
.company-story-stage__copy h2 { max-width: 760px; margin: 14px 0 26px; color: #071d33; font-family: var(--art-display); font-size: clamp(4rem,5.4vw,6rem); font-weight: 800; line-height: .88; }
.company-story-stage.is-dark .company-story-stage__copy h2 { color: #fff; }
.company-story-stage__text { max-width: 690px; }
.company-story-stage__text p { margin: 0 0 17px; color: #506772; font-size: .92rem; line-height: 1.82; }
.company-story-stage.is-dark .company-story-stage__text p { color: rgba(255,255,255,.68); }
.company-story-stage__facts { display: grid; grid-template-columns: repeat(3,1fr); margin: 40px 0 0; border-top: 1px solid #cbd7de; border-bottom: 1px solid #cbd7de; }
.company-story-stage.is-dark .company-story-stage__facts { border-color: rgba(255,255,255,.18); }
.company-story-stage__facts div { min-width: 0; padding: 24px 18px 24px 0; border-right: 1px solid #cbd7de; }
.company-story-stage.is-dark .company-story-stage__facts div { border-color: rgba(255,255,255,.18); }
.company-story-stage__facts div:last-child { padding-left: 18px; border-right: 0; }
.company-story-stage__facts div:nth-child(2) { padding-left: 18px; }
.company-story-stage__facts dt { color: #0a609d; font-family: var(--art-display); font-size: 3.4rem; font-weight: 900; line-height: .8; }
.company-story-stage.is-dark .company-story-stage__facts dt { color: #9bc9ed; }
.company-story-stage__facts dd { margin: 10px 0 0; color: #536b77; font-size: .66rem; font-weight: 750; line-height: 1.45; }
.company-story-stage.is-dark .company-story-stage__facts dd { color: rgba(255,255,255,.62); }
.company-story-stage__links { margin-top: 34px; border-top: 1px solid #cbd7de; }
.company-story-stage.is-dark .company-story-stage__links { border-color: rgba(255,255,255,.18); }
.company-story-stage__links a { display: grid; min-height: 66px; grid-template-columns: 28px minmax(0,1fr) 18px; gap: 13px; align-items: center; border-bottom: 1px solid #cbd7de; color: #071d33; font-size: .76rem; font-weight: 800; text-decoration: none; }
.company-story-stage.is-dark .company-story-stage__links a { border-color: rgba(255,255,255,.18); color: #fff; }
.company-story-stage__links a:hover { color: #0a609d; }
.company-story-stage.is-dark .company-story-stage__links a:hover { color: #b3d7ef; }
.company-story-stage__links svg { width: 18px; }
.company-story-stage__links a > svg:first-child { color: #0a609d; }

.company-route-stage { position: relative; overflow: hidden; padding: 110px 0 122px; background: #eef3f6; }
.company-route-stage.is-dark { background: #071d33; color: #fff; }
.company-route-stage::before { position: absolute; top: 36px; right: max(20px,calc((100vw - 1320px)/2)); color: rgba(7,29,51,.035); content: attr(data-watermark); font-family: var(--art-display); font-size: clamp(8rem,15vw,15rem); font-weight: 900; line-height: .74; pointer-events: none; }
.company-route-stage.is-dark::before { color: rgba(255,255,255,.045); }
.company-route-stage > .eco-container { position: relative; }
.company-route-stage__head { display: grid; grid-template-columns: 1.1fr .9fr; gap: 80px; align-items: end; margin-bottom: 46px; }
.company-route-stage__head h2 { max-width: 800px; margin: 13px 0 0; color: #071d33; font-family: var(--art-display); font-size: clamp(4rem,5.4vw,5.8rem); line-height: .9; }
.company-route-stage.is-dark .company-route-stage__head h2 { color: #fff; }
.company-route-stage.is-dark .company-kicker { color: #9bc9ed; }
.company-route-stage__head > p { max-width: 580px; margin: 0; color: #536b77; line-height: 1.8; }
.company-route-stage.is-dark .company-route-stage__head > p { color: rgba(255,255,255,.64); }
.company-route-stage__grid { display: grid; grid-template-columns: minmax(390px,.92fr) minmax(0,1.08fr); border-top: 1px solid #c8d4dc; border-bottom: 1px solid #c8d4dc; }
.company-route-stage.is-dark .company-route-stage__grid { border-color: rgba(255,255,255,.18); }
.company-route-stage__item { display: grid; min-height: 190px; grid-template-columns: 1fr; color: #071d33; text-decoration: none; }
.company-route-stage__item:not(.is-feature) { border-bottom: 1px solid #c8d4dc; }
.company-route-stage__item:not(.is-feature):last-child { border-bottom: 0; }
.company-route-stage.is-dark .company-route-stage__item { color: #fff; border-color: rgba(255,255,255,.18); }
.company-route-stage__item > div { position: relative; display: grid; min-width: 0; grid-template-columns: 58px minmax(0,1fr) 18px; gap: 7px 18px; align-content: center; padding: 26px 34px; }
.company-route-stage__item > div > small { grid-column: 2; color: #0a609d; font-size: .61rem; font-weight: 820; text-transform: uppercase; }
.company-route-stage.is-dark .company-route-stage__item > div > small { color: #9bc9ed; }
.company-route-stage__item > div > svg { grid-row: 1/5; width: 48px; height: 48px; padding: 13px; border-radius: 50%; background: #071d33; color: #fff; }
.company-route-stage.is-dark .company-route-stage__item > div > svg { background: rgba(255,255,255,.1); }
.company-route-stage__item h3 { grid-column: 2; margin: 3px 0 2px; font-family: var(--art-display); font-size: 2.15rem; line-height: .95; }
.company-route-stage__item p { grid-column: 2; max-width: 600px; margin: 0; color: #536b77; font-size: .75rem; line-height: 1.6; }
.company-route-stage.is-dark .company-route-stage__item p { color: rgba(255,255,255,.62); }
.company-route-stage__item b { position: absolute; right: 30px; bottom: 28px; display: inline-flex; align-items: center; gap: 7px; color: #0a609d; font-size: .65rem; opacity: 0; transform: translateY(5px); transition: opacity .2s ease,transform .2s ease; }
.company-route-stage__item:hover b { opacity: 1; transform: none; }
.company-route-stage__item b svg { width: 14px; }
.company-route-stage__item.is-feature { grid-row: span 3; grid-template-rows: minmax(360px,1fr) auto; border-right: 1px solid #c8d4dc; }
.company-route-stage.is-dark .company-route-stage__item.is-feature { border-color: rgba(255,255,255,.18); }
.company-route-stage__item.is-feature figure { min-height: 0; margin: 0; overflow: hidden; }
.company-route-stage__item.is-feature img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.company-route-stage__item.is-feature:hover img { transform: scale(1.02); }
.company-route-stage__item.is-feature > div { min-height: 250px; }

@media (max-width: 991.98px) {
  .company-story-stage__grid,.company-route-stage__head,.company-route-stage__grid { grid-template-columns: 1fr; }
  .company-story-stage.is-reverse .company-story-stage__media,.company-story-stage.is-reverse .company-story-stage__copy { order: initial; }
  .company-story-stage__media { min-height: 560px; }
  .company-route-stage__item.is-feature { grid-row: auto; grid-template-rows: 430px auto; border-right: 0; border-bottom: 1px solid #c8d4dc; }
}
@media (max-width: 640px) {
  .company-story-stage,.company-route-stage { padding-block: 72px; }
  .company-story-stage__grid { gap: 52px; }
  .company-story-stage__media { min-height: 480px; }
  .company-story-stage__copy h2,.company-route-stage__head h2 { font-size: 3.25rem; }
  .company-story-stage__facts { grid-template-columns: 1fr; }
  .company-story-stage__facts div,.company-story-stage__facts div:nth-child(2),.company-story-stage__facts div:last-child { padding: 20px 0; border-right: 0; border-bottom: 1px solid #cbd7de; }
  .company-story-stage__facts div:last-child { border-bottom: 0; }
  .company-route-stage__head { gap: 20px; margin-bottom: 34px; }
  .company-route-stage__item.is-feature { grid-template-rows: 300px auto; }
  .company-route-stage__item > div { min-height: 230px; grid-template-columns: 48px minmax(0,1fr); padding: 24px 4px; }
  .company-route-stage__item > div > svg { width: 42px; height: 42px; padding: 11px; }
  .company-route-stage__item h3 { font-size: 1.9rem; }
  .company-route-stage__item b { position: static; grid-column: 2; margin-top: 16px; opacity: 1; transform: none; }
}
