/* ──────────────────────────────────────────────────────────────
   innobu · Cinematic Editorial Hero  (homepage DE + EN)
   Fully namespaced under .ino-hero to avoid collisions with the
   global stylesheet. Uses site design tokens from variables.css.
   ────────────────────────────────────────────────────────────── */

.ino-hero{
    --ino-ink:10,22,37;                 /* #0a1625 page bg, as rgb for rgba scrims */
    --ino-accent:var(--accent-primary,#40c0f0);
    --ino-teal:var(--accent-secondary,#00b2a9);
    --ino-dur:6500ms;
    position:relative;
    width:100%;
    height:100svh;
    min-height:600px;
    max-height:1100px;
    overflow:hidden;
    isolation:isolate;
    color:var(--color-text,#fff);
    background:#0a1625;
}

/* ── slides ── */
.ino-hero__slides{position:absolute;inset:0;z-index:0}
.ino-hero__slide{
    position:absolute;inset:0;opacity:0;
    background-size:cover;background-position:center;
    transform:scale(1.06);
    transition:opacity 1.25s ease;
}
.ino-hero__slide.is-active{opacity:1;z-index:1;animation:ino-kenburns var(--ino-dur) ease-out forwards}
/* Tamed zoom — limits upscaling softness on large / 4K displays */
@keyframes ino-kenburns{
    from{transform:scale(1.02) translate3d(0,0,0)}
    to{transform:scale(1.10) translate3d(-1%,-1%,0)}
}
/* Image paths are variable-driven so each language can serve its own assets;
   DE uses the /de/bilder defaults, EN overrides --ino-slide-* to /en/images.
   background-position tuned so each subject stays framed when cover-cropped on ultrawide. */
.ino-hero__slide--1{background-image:var(--ino-slide-1,url('/de/bilder/social/KI_Mensch.jpg'));background-position:66% center}
.ino-hero__slide--2{background-image:var(--ino-slide-2,url('/de/bilder/mindset_thinker_humanlike_ultrarealistic.jpg'));background-position:58% center}
.ino-hero__slide--3{background-image:var(--ino-slide-3,url('/de/bilder/enterprise_ki_abstrakt.jpg'));background-position:center}

/* ── scrims (legibility + brand tint + blend into page) ── */
.ino-hero__scrim{position:absolute;inset:0;z-index:2;pointer-events:none}
.ino-hero__scrim--left{background:linear-gradient(100deg,
    rgba(var(--ino-ink),.95) 0%,rgba(var(--ino-ink),.82) 30%,
    rgba(var(--ino-ink),.42) 56%,rgba(var(--ino-ink),.12) 78%,transparent 100%)}
.ino-hero__scrim--bottom{background:linear-gradient(to top,
    #0a1625 0%,rgba(var(--ino-ink),.7) 12%,transparent 42%)}
.ino-hero__scrim--tint{background:radial-gradient(120% 90% at 80% 30%,
    rgba(64,192,240,.10),transparent 55%);mix-blend-mode:screen}
.ino-hero__scrim--grid{
    background-image:linear-gradient(rgba(64,192,240,.04) 1px,transparent 1px),
        linear-gradient(90deg,rgba(64,192,240,.04) 1px,transparent 1px);
    background-size:64px 64px;opacity:.6}

/* ── content column ── */
.ino-hero__wrap{
    position:relative;z-index:5;height:100%;
    display:flex;align-items:center;
    padding:80px clamp(22px,6vw,90px) 0;
    max-width:var(--container-width,1400px);margin:0 auto;
}
.ino-hero__content{max-width:660px}

.ino-hero__eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;
    color:rgba(64,192,240,.9);font-weight:600;margin-bottom:26px;
    padding:7px 14px 7px 12px;border:1px solid rgba(64,192,240,.25);
    border-radius:100px;background:rgba(64,192,240,.06);
    opacity:0;animation:ino-rise .8s .15s both;
}
.ino-hero__dot{width:7px;height:7px;border-radius:50%;background:var(--ino-accent);
    box-shadow:0 0 0 0 rgba(64,192,240,.6);animation:ino-pulse 2.4s infinite}
@keyframes ino-pulse{
    0%{box-shadow:0 0 0 0 rgba(64,192,240,.5)}
    70%{box-shadow:0 0 0 9px rgba(64,192,240,0)}
    100%{box-shadow:0 0 0 0 rgba(64,192,240,0)}}

/* headline — editorial serif over the brand gradient */
.ino-hero h1{
    font-family:'Fraunces',Georgia,serif;font-weight:500;
    font-size:clamp(2.9rem,7vw,6rem);line-height:.98;letter-spacing:-.02em;
    margin:0 0 6px;text-align:left;color:#fff;
    opacity:0;animation:ino-rise .9s .28s both;
}
.ino-hero__grad{
    background:linear-gradient(120deg,#fff 0%,#e3f1ff 28%,var(--ino-accent) 62%,var(--ino-teal) 100%);
    background-size:200% auto;-webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;animation:ino-shimmer 9s ease infinite;
}
@keyframes ino-shimmer{0%,100%{background-position:0% center}50%{background-position:100% center}}
.ino-hero__h2{
    font-family:'Fraunces',Georgia,serif;font-weight:400;font-style:italic;
    font-size:clamp(1.5rem,3.4vw,2.7rem);line-height:1.05;letter-spacing:-.01em;
    color:rgba(235,244,255,.92);margin:0 0 24px;
    opacity:0;animation:ino-rise .9s .4s both;
}
.ino-hero__desc{
    font-size:clamp(1rem,1.4vw,1.18rem);line-height:1.65;
    color:var(--color-text-muted,#a0c0e0);max-width:30em;font-weight:300;
    margin:0 0 36px;opacity:0;animation:ino-rise .9s .52s both;
}

/* CTAs */
.ino-hero__ctas{display:flex;gap:16px;flex-wrap:wrap;align-items:center;
    opacity:0;animation:ino-rise .9s .64s both}
.ino-hero__btn{display:inline-flex;align-items:center;gap:11px;font-weight:600;
    font-size:.92rem;text-decoration:none;border-radius:100px;
    transition:transform .3s,box-shadow .3s,background .3s,border-color .3s,gap .3s}
.ino-hero__btn--primary{padding:15px 28px;color:#03121b;
    background:linear-gradient(120deg,var(--ino-accent),#7ad6f5);
    box-shadow:0 10px 40px -12px rgba(64,192,240,.7)}
.ino-hero__btn--primary:hover{transform:translateY(-2px);gap:15px;
    box-shadow:0 16px 50px -12px rgba(64,192,240,.85)}
.ino-hero__btn--primary .ino-hero__arr{transition:transform .3s}
.ino-hero__btn--primary:hover .ino-hero__arr{transform:translateX(3px)}
.ino-hero__btn--ghost{padding:14px 24px;color:#eaf4ff;border:1px solid rgba(200,225,255,.3)}
.ino-hero__btn--ghost:hover{border-color:var(--ino-accent);color:#fff;background:rgba(64,192,240,.08)}

/* trust row */
.ino-hero__trust{display:flex;gap:30px;margin-top:42px;flex-wrap:wrap;
    opacity:0;animation:ino-rise .9s .8s both}
.ino-hero__trust .ino-hero__item{display:flex;flex-direction:column;gap:3px}
.ino-hero__num{font-family:'Fraunces',Georgia,serif;font-size:1.7rem;font-weight:500;
    color:#fff;line-height:1}
.ino-hero__lbl{font-size:.72rem;letter-spacing:.04em;color:rgba(200,215,240,.5)}
.ino-hero__div{width:1px;align-self:stretch;
    background:linear-gradient(transparent,rgba(64,192,240,.3),transparent)}

/* editorial slide caption */
.ino-hero__caption{
    position:absolute;left:max(clamp(22px,6vw,90px),calc(50% - var(--container-width,1400px)/2 + clamp(22px,6vw,90px)));
    bottom:clamp(28px,5vh,54px);z-index:6;
    max-width:30em;padding-left:18px;border-left:2px solid rgba(64,192,240,.35);margin:0}
.ino-hero__chaplabel{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;
    color:rgba(64,192,240,.75);margin-bottom:7px;display:block}
.ino-hero__captext{font-family:'Fraunces',Georgia,serif;font-style:italic;
    font-size:clamp(1rem,1.7vw,1.32rem);line-height:1.4;color:rgba(235,244,255,.9);
    transition:opacity .5s,transform .5s}

/* chapter rail (right) */
.ino-hero__rail{position:absolute;right:clamp(20px,4vw,52px);top:50%;
    transform:translateY(-50%);z-index:7;display:flex;flex-direction:column;gap:22px}
.ino-hero__chap{display:flex;align-items:center;gap:14px;cursor:pointer;
    background:none;border:0;color:rgba(220,232,255,.5);font-family:inherit;
    text-align:right;transition:color .3s}
.ino-hero__chap .ino-hero__meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.ino-hero__ci{font-size:.62rem;letter-spacing:.16em;color:rgba(64,192,240,.6)}
.ino-hero__ct{font-size:.82rem;font-weight:600;max-width:0;overflow:hidden;
    white-space:nowrap;opacity:0;transition:max-width .45s ease,opacity .35s}
.ino-hero__track{position:relative;width:2px;height:42px;background:rgba(200,225,255,.18);
    border-radius:2px;overflow:hidden}
.ino-hero__fill{position:absolute;inset:0 0 auto 0;height:0;
    background:linear-gradient(var(--ino-accent),var(--ino-teal));border-radius:2px}
.ino-hero__chap:hover{color:#fff}
.ino-hero__chap:hover .ino-hero__ct{max-width:160px;opacity:1}
.ino-hero__chap.is-active{color:#fff}
.ino-hero__chap.is-active .ino-hero__ct{max-width:160px;opacity:1}
.ino-hero__chap.is-active .ino-hero__track{background:rgba(64,192,240,.22)}
.ino-hero__chap.is-active .ino-hero__fill{height:100%;transition:height var(--ino-dur) linear}

@keyframes ino-rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ── responsive ── */
@media(max-width:900px){
    .ino-hero__rail{display:none}
}
@media(max-width:768px){
    .ino-hero{height:auto;min-height:auto;max-height:none}
    .ino-hero__scrim--left{background:linear-gradient(to top,
        rgba(var(--ino-ink),.94) 0%,rgba(var(--ino-ink),.66) 52%,rgba(var(--ino-ink),.4) 100%)}
    .ino-hero__scrim--bottom{background:linear-gradient(to top,#0a1625 0%,rgba(var(--ino-ink),.55) 16%,transparent 46%)}
    /* size to content (+ nav clearance) — no reserved 90svh void below the text */
    .ino-hero__wrap{align-items:flex-start;min-height:auto;padding:100px 20px 34px}
    .ino-hero__caption{display:none}
    .ino-hero__eyebrow{margin-bottom:18px}
    .ino-hero__h2{margin-bottom:18px}
    .ino-hero__desc{margin-bottom:28px}
    .ino-hero__trust{gap:16px;margin-top:30px}
    .ino-hero__num{font-size:1.4rem}
}
@media(max-width:560px){
    /* stack CTAs full-width so tap targets are comfortable */
    .ino-hero__ctas{flex-direction:column;align-items:stretch}
    .ino-hero__btn{width:100%;justify-content:center;padding:15px 22px}
}
@media(max-width:420px){
    .ino-hero h1{font-size:clamp(2.1rem,8.6vw,2.7rem)}
    .ino-hero__h2{font-size:clamp(1.3rem,5.6vw,1.7rem)}
    .ino-hero__trust{gap:14px}
    .ino-hero__trust .ino-hero__div{display:none}
    .ino-hero__num{font-size:1.3rem}
    .ino-hero__lbl{font-size:.68rem}
}

/* respect reduced motion (global rule already throttles; lock final state) */
@media(prefers-reduced-motion:reduce){
    .ino-hero__slide.is-active{opacity:1;transform:scale(1);animation:none}
    .ino-hero__eyebrow,.ino-hero h1,.ino-hero__h2,.ino-hero__desc,
    .ino-hero__ctas,.ino-hero__trust{opacity:1;animation:none}
}
