/* ===== OnePager layout, blueprint imagery & animations (ported from design bundle) ===== */
.pg-page{overflow-x:clip}

/* ---------- Header ---------- */
.pg-header{position:sticky;top:0;z-index:var(--z-header);background:rgba(255,255,255,.82);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--border-subtle)}
.pg-header__inner{max-width:var(--container-wide);margin-inline:auto;padding:.85rem var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-5)}
.pg-header__logo{height:42px;width:auto}
.pg-nav{display:flex;gap:var(--sp-5);align-items:center}
.pg-nav a{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:var(--ls-label);text-transform:uppercase;color:var(--steel-600);transition:color var(--dur-fast)}
.pg-nav a:hover{color:var(--pg-indigo)}
@media (max-width:920px){.pg-nav{display:none}}

/* ---------- Section scaffolding ---------- */
.pg-section{padding-block:var(--section-y)}
.pg-section--muted{background:var(--surface-muted)}
.pg-section--dark{background:var(--indigo-900);color:var(--text-on-dark);position:relative}
.pg-section--indigo{background:var(--pg-indigo);color:var(--text-on-dark)}

/* ---------- Blueprint figure ---------- */
.pg-figure{position:relative;overflow:hidden;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--indigo-800),var(--indigo-950));border:1px solid var(--indigo-500);display:grid;place-items:center;min-height:240px;isolation:isolate}
.pg-figure::before{content:"";position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:26px 26px;-webkit-mask-image:radial-gradient(120% 120% at 50% 40%,#000 55%,transparent 100%);mask-image:radial-gradient(120% 120% at 50% 40%,#000 55%,transparent 100%)}
.pg-figure__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);color:var(--indigo-200);text-align:center;padding:var(--sp-6)}
.pg-figure__inner .ic{color:var(--yellow-500)}
.pg-figure__cap{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:var(--ls-label);text-transform:uppercase;color:var(--indigo-300)}
@keyframes pg-spin{to{transform:rotate(360deg)}}
.pg-spin{animation:pg-spin 26s linear infinite}
@media (prefers-reduced-motion:reduce){.pg-spin{animation:none}}

/* ---------- Hero ---------- */
.pg-hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:var(--indigo-950);isolation:isolate}
.pg-hero__media{position:absolute;inset:0;z-index:0}
.pg-hero__slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.05);transition:opacity 1.2s var(--ease-in-out)}
.pg-hero__slide[data-active="true"]{opacity:1;animation:pg-kenburns var(--kb-dur,6s) ease-out forwards}
@keyframes pg-kenburns{from{transform:scale(1.05)}to{transform:scale(var(--kb-to,1.13))}}
@media (prefers-reduced-motion:reduce){.pg-hero__slide{animation:none!important;transform:none}}
.pg-hero__scrim{position:absolute;inset:0;background:linear-gradient(98deg,rgba(13,12,43,.94) 0%,rgba(20,19,63,.82) 34%,rgba(20,19,63,.40) 66%,rgba(13,12,43,.62) 100%),linear-gradient(0deg,rgba(13,12,43,.72) 0%,rgba(13,12,43,0) 42%)}
.pg-hero__inner{position:relative;z-index:2;width:100%;max-width:var(--container-wide);margin-inline:auto;padding:clamp(5rem,9vw,8rem) var(--gutter) clamp(5rem,8vw,7rem)}
.pg-hero__col{display:flex;flex-direction:column;gap:var(--sp-5);max-width:44rem}
.pg-hero__title{font-family:var(--font-display);font-weight:var(--fw-black);font-size:var(--fs-display);line-height:.98;letter-spacing:var(--ls-tight);color:var(--white);margin:0}
.pg-hero__title .hl{position:relative;white-space:nowrap;color:var(--white)}
.pg-hero__title .hl::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.14em;background:var(--pg-yellow);z-index:-1}
.pg-hero__lead{font-size:var(--fs-lead);line-height:var(--lh-normal);color:var(--indigo-100);max-width:46ch}
.pg-hero__caption{position:absolute;right:var(--gutter);bottom:clamp(1.2rem,3vw,2.4rem);z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:var(--sp-2);text-align:right}
.pg-hero__caption-idx{font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:var(--ls-label);color:var(--yellow-500)}
.pg-hero__caption-label{font-family:var(--font-display);font-weight:var(--fw-bold);font-size:1.05rem;color:var(--white)}
.pg-hero__dots{display:inline-flex;gap:7px;margin-top:var(--sp-1)}
.pg-hero__dot{width:22px;height:3px;border:0;padding:0;cursor:pointer;background:rgba(255,255,255,.28);transition:background var(--dur-fast)}
.pg-hero__dot[data-active="true"]{background:var(--pg-yellow)}
@media (max-width:1180px){.pg-hero__caption{right:var(--gutter);bottom:5.5rem}}
@media (max-width:720px){.pg-hero__caption{display:none}}

/* ---------- generic grids ---------- */
.pg-cta-row{display:flex;flex-wrap:wrap;gap:var(--sp-4)}
.pg-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,3rem);align-items:center}
.pg-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}
.pg-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5)}
@media (max-width:900px){.pg-grid-2,.pg-grid-3,.pg-grid-4{grid-template-columns:1fr}}
@media (max-width:1100px) and (min-width:901px){.pg-grid-4{grid-template-columns:repeat(2,1fr)}}
.pg-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}
@media (max-width:980px){.pg-services-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.pg-services-grid{grid-template-columns:1fr}}
.pg-services-grid>*{display:grid}
.pg-services-grid>*>a>div:last-child{flex:1 1 auto}
.pg-services-grid>*>a>div:last-child>span:last-child{margin-top:auto}

/* trust strip */
.pg-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-6)}
@media (max-width:820px){.pg-trust{grid-template-columns:repeat(2,1fr);gap:var(--sp-7) var(--sp-5)}}

/* pillars */
.pg-pillar{display:flex;flex-direction:column;gap:var(--sp-3)}
.pg-pillar__ic{width:48px;height:48px;border-radius:var(--radius-sm);display:grid;place-items:center;background:var(--indigo-50);color:var(--pg-indigo);border:1px solid var(--indigo-100)}
.pg-pillar h4{font-size:var(--fs-h4);margin:0;color:var(--text-strong)}

/* ---------- Detail cards ---------- */
.pg-details{display:flex;flex-direction:column;gap:clamp(1.5rem,3vw,2.6rem)}
.pg-dcard{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:box-shadow var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out);min-height:360px}
.pg-dcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.pg-dcard__media{position:relative;background-size:cover;background-position:center;min-height:240px;background-color:var(--indigo-950);scroll-margin-top:110px}
.pg-dcard__media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(13,12,43,.20),transparent 55%)}
.pg-dcard__media--empty{display:grid;place-items:center;background:linear-gradient(135deg,var(--indigo-800),var(--indigo-950))}
.pg-dcard__media--empty::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:24px 24px;-webkit-mask-image:radial-gradient(120% 120% at 50% 40%,#000 55%,transparent 100%);mask-image:radial-gradient(120% 120% at 50% 40%,#000 55%,transparent 100%)}
.pg-dcard__ph{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--sp-2)}
.pg-dcard__ph .ic{color:var(--yellow-500)}
.pg-dcard__ph em{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);font-style:normal}
.pg-dcard__tag{position:absolute;top:16px;left:16px;z-index:2;font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:var(--ls-label);color:var(--indigo-900);background:var(--pg-yellow);padding:.3rem .6rem;border-radius:var(--radius-xs);white-space:nowrap}
.pg-dcard__body{padding:clamp(1.6rem,2.6vw,3rem);display:flex;flex-direction:column;justify-content:center;gap:var(--sp-3)}
.pg-dcard__title{font-size:var(--fs-h3);margin:0;color:var(--text-strong)}
.pg-dcard__text{font-size:var(--fs-body);line-height:var(--lh-relaxed);color:var(--text-body);margin:0}
.pg-reveal{opacity:1}
.pg-dcard:nth-child(even) .pg-dcard__media{order:2}
@media (max-width:900px){.pg-dcard{grid-template-columns:1fr;min-height:0}.pg-dcard__media,.pg-dcard:nth-child(even) .pg-dcard__media{order:0}.pg-dcard__media{aspect-ratio:16/10;min-height:0}}
.pg-spec-list{list-style:none;padding:0;margin:var(--sp-4) 0 0;display:flex;flex-direction:column;gap:var(--sp-2)}
.pg-spec-list li{display:flex;gap:var(--sp-3);align-items:baseline;font-size:var(--fs-sm);color:var(--text-body);padding-bottom:var(--sp-2);border-bottom:1px dashed var(--border-subtle)}
.pg-spec-list li b{font-family:var(--font-mono);color:var(--pg-indigo);font-weight:500;font-size:var(--fs-xs);letter-spacing:.04em;min-width:84px}

/* special services */
.pg-special{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
@media (max-width:980px){.pg-special{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.pg-special{grid-template-columns:1fr}}
.pg-special__item{height:100%;padding:var(--sp-5);border:1px solid var(--border-on-dark);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--sp-3);background:rgba(255,255,255,.03);transition:background var(--dur-med),transform var(--dur-med) var(--ease-out)}
.pg-special__item:hover{background:rgba(255,255,255,.07);transform:translateY(-4px)}
.pg-special__item .ic{color:var(--yellow-500)}
.pg-special__item h4{font-size:var(--fs-h4);color:var(--white);margin:0}
.pg-special__item p{font-size:var(--fs-sm);line-height:var(--lh-normal);color:var(--text-on-dark-dim);margin:0}

/* recruiting */
.pg-recruit{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:linear-gradient(120deg,var(--indigo-700),var(--indigo-900) 70%);border:1px solid var(--indigo-500);padding:clamp(2.5rem,5vw,4.5rem);display:grid;grid-template-columns:1.3fr 1fr;gap:var(--sp-7);align-items:center}
@media (max-width:820px){.pg-recruit{grid-template-columns:1fr}}
.pg-recruit__glow{position:absolute;width:420px;height:420px;right:-120px;top:-160px;background:radial-gradient(circle,rgba(247,243,0,.18),transparent 65%);z-index:0}
.pg-recruit__col{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--sp-4)}
.pg-recruit__col--cta{align-items:flex-start;gap:var(--sp-3)}
.pg-recruit h2{font-size:var(--fs-h2);color:var(--white);margin:0}
.pg-recruit p{font-size:var(--fs-lead);line-height:var(--lh-normal);color:var(--text-on-dark-dim);margin:0;max-width:52ch}
.pg-recruit__note{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--indigo-200);letter-spacing:.04em}

/* footer */
.pg-footer{background:var(--steel-950);color:var(--steel-300)}
.pg-footer__inner{max-width:var(--container-wide);margin-inline:auto;padding:var(--sp-8) var(--gutter) var(--sp-6);display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--sp-7)}
@media (max-width:820px){.pg-footer__inner{grid-template-columns:1fr;gap:var(--sp-6)}}
.pg-footer a{color:var(--steel-300);transition:color var(--dur-fast)}
.pg-footer a:hover{color:var(--yellow-500)}
.pg-footer__logo{height:60px;width:auto;margin-bottom:var(--sp-4);background:#fff;padding:10px 14px;border-radius:var(--radius-sm);box-sizing:border-box}
.pg-footer__blurb{font-size:var(--fs-sm);line-height:var(--lh-normal);color:var(--steel-400);max-width:34ch}
.pg-footer__social{display:flex;gap:var(--sp-4);margin-top:var(--sp-4);font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase}
.pg-footer__addr{font-size:var(--fs-sm);line-height:1.8;color:var(--steel-300)}
.pg-footer__links{font-size:var(--fs-sm);line-height:2;color:var(--steel-300);display:flex;flex-direction:column}
.pg-footer__legal{border-top:1px solid rgba(255,255,255,.08);padding:1rem var(--gutter);text-align:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--steel-500)}

/* ---------- Floating contact rail ---------- */
.pg-rail-fixed{position:fixed;right:clamp(12px,1.6vw,24px);top:50%;transform:translateY(-50%);z-index:var(--z-rail)}
@media (max-width:1180px){.pg-rail-fixed{display:none}}
.pg-mobilebar{position:fixed;left:0;right:0;bottom:0;z-index:var(--z-rail);display:none;gap:1px;background:var(--indigo-500);border-top:2px solid var(--pg-yellow)}
@media (max-width:1180px){.pg-mobilebar{display:grid;grid-template-columns:1fr 1fr 1fr}}
.pg-mobilebar a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem;background:var(--pg-indigo);color:#fff;font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase}
.pg-mobilebar a.primary{background:var(--pg-yellow);color:var(--indigo-900)}

/* section kicker number */
.pg-kicker-num{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--steel-400);letter-spacing:.1em}
.pg-section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--sp-5);margin-bottom:var(--sp-8);flex-wrap:wrap}

/* ---------- Editorial motifs ---------- */
.pg-scrollcue{position:absolute;left:var(--gutter);bottom:clamp(1rem,3vw,2.2rem);z-index:1;display:flex;align-items:center;gap:var(--sp-3);font-family:var(--font-mono);font-size:var(--fs-xs);letter-spacing:var(--ls-eyebrow);text-transform:uppercase;color:var(--steel-400)}
.pg-scrollcue__track{position:relative;width:1px;height:46px;background:var(--border-strong);overflow:hidden}
.pg-scrollcue__dot{position:absolute;left:-1.5px;top:0;width:4px;height:10px;background:var(--pg-yellow);animation:pg-scrolldown 1.8s var(--ease-in-out) infinite;animation-play-state:var(--cue-play,running)}
@keyframes pg-scrolldown{0%{transform:translateY(-12px);opacity:0}35%{opacity:1}100%{transform:translateY(46px);opacity:0}}
@media (prefers-reduced-motion:reduce){.pg-scrollcue__dot{animation:none;top:18px}}
@media (max-width:940px){.pg-scrollcue{display:none}}
.pg-bignum{font-family:var(--font-display);font-weight:var(--fw-black);line-height:.8;font-size:clamp(3.2rem,5vw,4.6rem);letter-spacing:var(--ls-tight);color:var(--pg-yellow)}
.pg-marquee{position:relative;overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.pg-marquee__track{display:flex;width:max-content;gap:0;animation:pg-marquee var(--marquee-dur,32s) linear infinite}
.pg-marquee:hover .pg-marquee__track{animation-play-state:paused}
@keyframes pg-marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.pg-marquee__track{animation:none}}
.pg-marquee__item{display:inline-flex;align-items:center;gap:var(--sp-4);padding:0 var(--sp-6);font-family:var(--font-display);font-weight:var(--fw-bold);font-size:clamp(1.4rem,2.4vw,2.2rem);color:var(--white);white-space:nowrap;letter-spacing:var(--ls-tight)}
.pg-marquee__item::after{content:"";width:9px;height:9px;background:var(--pg-yellow);border-radius:50%}

/* ---------- Tweaks (data attributes on <html>) ---------- */
html[data-energie="ruhig"]{--kb-to:1.035;--kb-dur:9s;--marquee-dur:54s;--cue-play:paused}
html[data-energie="standard"]{--kb-to:1.13;--kb-dur:6s;--marquee-dur:32s;--cue-play:running}
html[data-energie="lebhaft"]{--kb-to:1.2;--kb-dur:4.5s;--marquee-dur:17s;--cue-play:running}
html[data-foto="grau"] .pg-hero__slide,html[data-foto="grau"] .pg-card__img,html[data-foto="grau"] .pg-dcard__media{filter:grayscale(1) contrast(1.06)}
html[data-foto="indigo"] .pg-hero__slide,html[data-foto="indigo"] .pg-card__img,html[data-foto="indigo"] .pg-dcard__media{filter:grayscale(1) sepia(1) hue-rotate(202deg) saturate(2.4) brightness(.92) contrast(1.05)}

/* ---------- Scroll-entrance (JS-driven) ---------- */
@media (prefers-reduced-motion:no-preference){
  html.pg-anim-ready .pg-reveal{opacity:0;translate:0 24px;transition:opacity var(--dur-slow) var(--ease-out),translate var(--dur-slow) var(--ease-out);transition-delay:var(--pg-reveal-delay,0ms);will-change:opacity,translate}
  html.pg-anim-ready .pg-reveal.is-in{opacity:1;translate:0 0}
}
@media print{.pg-reveal{opacity:1!important;translate:0 0!important}}
