:root{
    /* HOME tokens (new) */
    --hero-h: 100svh; /* lepsze na mobile niż 100vh */
    --hero-overlay: rgba(0,0,0,.42);
    --hero-overlay-2: rgba(0,0,0,.18);

    --hero-title: var(--fs-1);
    --hero-lead: var(--fs-3);

    --hero-max: 860px;

    --home-card-bg: rgba(255,255,255,.08);
    --home-card-border: rgba(255,255,255,.14);

    --topbar-hero-fg: #ffffff;
    --topbar-hero-bg: rgba(0,0,0,0); /* transparent */
    --home-sep-h: 1px;

    --home-s-py: var(--space-6, 64px);
    --home-s-gap: var(--space-5, 32px);

    --home-media-radius: var(--radius, 16px);

    --home-sep-gap: var(--home-s-py);

    --portfolio-grid-gap: var(--space-4, 24px);
    --portfolio-card-radius: calc(var(--radius, 16px) + 4px);
    --portfolio-card-overlay: rgba(0,0,0,.45);
    --portfolio-card-overlay-hover: rgba(0,0,0,.30);

    --home-cta-hover-translate: -2px;
    --home-cta-hover-shadow: 0 12px 28px rgba(0,0,0,.18);
    --home-cta-hover-brightness: 1.05;

}

/* Full-bleed section inside .main.container */
.home-hero{
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: auto;
    max-width: 100vw;
}

.home-hero__media{
    position:absolute;
    inset: 0;
}

.home-hero__video{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display:block;
}

.home-hero__overlay{
    position:absolute;
    inset: 0;
    background: linear-gradient(
            180deg,
            var(--hero-overlay),
            var(--hero-overlay-2) 55%,
            rgba(0,0,0,.55)
    );
}

.home-hero__inner{
    position: relative;
    min-height: var(--hero-h);
    display:flex;
    align-items: center;
    justify-content: center;
    padding-bottom: var(--space-5);
    padding-inline: var(--gutter);
}

.home-hero__content{
    max-width: var(--hero-max);
    text-align: center;
    color: #fff;
}

.home-hero__eyebrow{
    margin: 0 0 var(--space-2);
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .85rem;
    opacity: .88;
}

.home-hero__title{
    margin: 0 0 var(--space-2);
    font-size: var(--hero-title);
    line-height: 1.05;
    letter-spacing: -0.02em;
}

.home-hero__lead{
    margin: 0 auto var(--space-4);
    max-width: 56ch;
    font-size: var(--hero-lead);
    line-height: 1.55;
    opacity: .92;
}

.home-hero__actions{
    display:flex;
    gap: var(--space-2);
    justify-content: center;
    flex-wrap: wrap;
}

.main.main--no-topbar-offset{
    padding-top: 0 !important;
}

/* Base section */

.home-s__inner{
    display: grid;
    gap: var(--home-s-gap);
    align-items: center;
}

.home-s--sep-top::before{
    content:"";
    position:absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: var(--home-sep-h);
    background: var(--secondary-color);
    border-radius: 999px;
}

/* Sekcja z separatorem: ma kreskę na górze */
.home-s--sep-top{
    position: relative;
    padding-top: calc(var(--home-s-py) + var(--home-sep-gap));
    padding-bottom: var(--home-s-py);
}

/* Pierwsza sekcja (bez kreski na górze) */
.home-s{
    padding-block: var(--home-s-py);
}

/* Split layout: mobile-first = 1 column */
.home-s--split .home-s__inner{
    grid-template-columns: 1fr;
}

.home-s__title{
    margin: 0 0 var(--space-2, 12px);
    font-size: var(--fs-2);
    letter-spacing: -0.01em;
    color: var(--text);
}

.home-s__lead{
    margin: 0;
    color: var(--text-muted);
    line-height: 1.7;
    max-width: 62ch;
}

.home-s__media{
    margin: 0;
}

.home-s__img{
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--home-media-radius);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    object-fit: cover;
}

/* Desktop split */
@media (min-width: 900px){
    .home-s--split .home-s__inner{
        grid-template-columns: 1.1fr 0.9fr;
    }

    /* lewy tekst ma być bardziej “premium” – mniej rozciągnięty */
    .home-s__lead{
        max-width: 56ch;
    }

    .home-s--reverse .home-s__inner{
        grid-template-columns: 0.9fr 1.1fr;
    }

    .home-s--reverse .home-s__media{
        order: -1;
    }
}

.home-s--portfolio{
    text-align: center;
}

.home-portfolio-head{
    margin: 0 auto var(--space-5, 32px);
    max-width: 70ch;
}

.home-portfolio-title{
    margin: 0;
    font-size: var(--fs-2);
    letter-spacing: -0.01em;
    color: var(--text);
}

.home-portfolio-grid{
    display: grid;
    gap: var(--portfolio-grid-gap);
    grid-template-columns: 1fr;
}

@media (min-width: 720px){
    .home-portfolio-grid{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.home-portfolio-card{
    position: relative;
    display: block;
    border-radius: var(--portfolio-card-radius);
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    text-decoration: none;
    color: #fff;
    aspect-ratio: 1 / 1;
    transform: translateZ(0);
}

.home-portfolio-card__img{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.home-portfolio-card__overlay{
    position: absolute;
    inset: 0;
    background: var(--portfolio-card-overlay);
    transition: background .2s ease;
}

.home-portfolio-card__body{
    position: absolute;
    inset: auto 0 0 0;
    padding: var(--space-4, 24px);
    display: grid;
    gap: 8px;
    text-align: left;
    background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.62));
}

.home-portfolio-card__title{
    font-weight: 600;
    letter-spacing: .01em;
}

.home-portfolio-card__desc{
    line-height: 1.55;
    opacity: .92;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.home-portfolio-card:focus-visible{
    outline: 2px solid var(--secondary-color);
    outline-offset: 3px;
}

@media (hover: hover){
    .home-portfolio-card{
        transition: transform .2s ease;
    }
    .home-portfolio-card:hover{
        transform: translateY(-2px);
    }
    .home-portfolio-card:hover .home-portfolio-card__overlay{
        background: var(--portfolio-card-overlay-hover);
    }
}

.home-portfolio-cta{
    margin-top: var(--space-5, 32px);
    display: flex;
    justify-content: center;
}

/* smooth transition */
.btn--home-cta{
    transition:
            transform .2s ease,
            box-shadow .2s ease,
            filter .2s ease;
}

@media (hover: hover){
    .btn--home-cta:hover{
        transform: translateY(var(--home-cta-hover-translate));
        box-shadow: var(--home-cta-hover-shadow);
        filter: brightness(var(--home-cta-hover-brightness));
    }
}

.btn--home-cta:active{
    transform: translateY(0);
}