.service-hero {
    position: relative;
    min-height: calc(100svh - 72px);
    overflow: hidden;
    isolation: isolate;
    background:
        radial-gradient(
            circle at 72% 46%,
            color-mix(in srgb, var(--color-accent) 18%, transparent),
            transparent 34%
        ),
        linear-gradient(
            135deg,
            var(--color-bg) 0%,
            var(--color-bg-soft) 52%,
            var(--color-surface) 100%
        );
}

.service-hero__inner {
    width: min(100% - var(--space-6), var(--container-xl));
    min-height: calc(100svh - 72px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.72fr);
    align-items: center;
    gap: var(--space-12);
    padding-block: var(--space-20);
}

.service-hero__copy {
    position: relative;
    z-index: 2;
}

.service-hero__copy .section-title {
    max-width: 60ch;
    font-size: clamp(3rem, 4vw, 3.5rem);
    line-height: 1.12;
    text-wrap: balance;
}

.service-hero__copy .section-subtitle {
    max-width: 720px;
}

.service-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-8);
}

.service-hero__points {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-6);
    margin: var(--space-8) 0 0;
    padding: 0;
    color: var(--color-text-muted);
    font-size: var(--font-size-caption);
    list-style: none;
}

.service-hero__points li {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.service-hero__points li::before {
    width: 0.38rem;
    height: 0.38rem;
    background: var(--color-accent);
    border-radius: 999px;
    box-shadow: 0 0 18px color-mix(in srgb, var(--color-accent) 70%, transparent);
    content: "";
}

/*
 * HERO PYTHON
 * A imagem deve ficar solta no Hero.
 * Este bloco não pode ter aparência de card/quadro.
 */
.python-hero .service-hero__inner {
    position: relative;
    display: block;
    width: 100%;
    min-height: calc(100svh - 72px);
    margin: 0;
    padding: 0;
}

.python-hero .service-hero__copy {
    position: relative;
    z-index: 2;
    display: flex;
    width: min(70vw, 860px);
    min-height: calc(100svh - 72px);
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    margin-left: max(var(--space-3), calc((100vw - var(--container-xl)) / 2 - var(--space-20)));
    padding-block: var(--space-20);
}

.python-hero .service-hero__copy .section-title {
    max-width: 60ch;
    font-size: clamp(3rem, 4vw, 3.5rem);
    line-height: 1.12;
    text-wrap: balance;
}

.python-hero .service-hero__copy .section-subtitle {
    max-width: 720px;
}

.python-hero .service-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-8);
}

.python-hero .service-hero__points {
    position: absolute;
    top: calc(50% + 182px);
    left: 0;
    margin-top: 0;
}

.python-hero__media {
    position: absolute;
    top: 50%;
    right: max(var(--space-6), calc((100vw - var(--container-xl)) / 2 - var(--space-20)));
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;

    width: min(40vw, 860px);
    min-width: 0;
    min-height: 0;

    margin: 0;
    padding: 0;

    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;

    pointer-events: none;
    transform: translate(132px, -50%);
}

.python-hero__media::before,
.python-hero__media::after {
    display: none;
    content: none;
}

.python-hero__image {
    display: block;

    width: min(122%, 880px);
    height: auto;
    max-height: min(84svh, 780px);

    margin: 0 auto;
    padding: 0;

    object-fit: contain;
    object-position: center;

    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;

    filter: none;
    mix-blend-mode: normal;
}

.python-hero__image--dark {
    display: none;
}

.python-hero__image--light {
    transform: translateX(60px);
}

html.theme-dark .python-hero__image--light {
    display: none;
}

html.theme-dark .python-hero__image--dark {
    display: block;
    transform: translateX(60px);
}

/*
 * Mantém compatibilidade caso algum HTML antigo ainda esteja usando
 * a classe service-visual por engano dentro da página Python.
 * Aqui ela é neutralizada para não gerar quadro.
 */
.service-hero .service-visual {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;

    width: 100%;
    min-width: 0;
    min-height: 0;

    margin: 0;
    padding: 0;

    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
    backdrop-filter: none;
}

.service-hero .service-visual::before,
.service-hero .service-visual::after {
    display: none;
    content: none;
}

.service-section-link {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    margin-top: auto;
    padding-block: var(--space-1);
    color: var(--color-accent);
    font-weight: 600;
    text-decoration: none;
    text-underline-offset: 5px;
    transition: color 160ms ease, transform 160ms ease;
}

.service-section-link:hover {
    color: color-mix(in srgb, var(--color-accent) 82%, var(--color-text));
    text-decoration: underline;
    transform: translateX(3px);
}

.python-projects {
    background:
        radial-gradient(circle at 82% 8%, color-mix(in srgb, var(--color-accent) 10%, transparent), transparent 32%),
        linear-gradient(180deg, var(--color-bg-soft) 0%, var(--color-bg) 100%);
}

.python-projects .home-portfolio__head {
    display: block;
    margin-bottom: var(--space-20);
    text-align: center;
}

.python-projects .home-portfolio__intro .section-title,
.python-projects .home-portfolio__intro .section-subtitle {
    margin-inline: auto;
}

.python-projects__list {
    width: min(100%, calc(var(--container-xl) + 80px));
    display: flex;
    flex-direction: column;
    gap: var(--space-16);
    margin-inline: auto;
}

.python-project {
    display: flex;
    width: 100%;
    align-items: center;
    gap: clamp(var(--space-5), 3.5vw, var(--space-10));
}

.python-project--reverse {
    flex-direction: row-reverse;
}

.python-project__content {
    flex: 0 1 40%;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

.python-project__media {
    flex: 0 0 58%;
    min-width: 0;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    display: block;
    padding: 0;
    background: none;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.python-project__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border: 0;
    box-shadow: none;
}

/* Sice (3º card): imagem ancorada à direita (coluna direita) */
.python-project:not(.python-project--reverse) .python-project__image {
    object-position: right center;
}

/* Jarvis (1º card): contain para mostrar o HUD completo sem corte */
.python-projects__list > .python-project:first-child .python-project__media {
    background: #080d18;
}

.python-projects__list > .python-project:first-child .python-project__image {
    object-fit: contain;
    object-position: center;
}

/* Sige e Chatbot: imagem ancorada à esquerda (coluna esquerda) */
.python-project--reverse .python-project__image {
    object-position: left center;
}

.python-project__tag {
    display: none;
}

.python-project__title {
    margin: 0;
    color: var(--color-text);
    font-size: clamp(2rem, 3vw, 2.75rem);
    line-height: 1.12;
}

.python-project__text {
    max-width: 68ch;
    margin: var(--space-5) 0 var(--space-7);
    color: var(--color-text-body);
    font-size: clamp(1rem, 1.25vw, 1.125rem);
    line-height: 1.6;
}

.python-project__text p {
    margin: 0 0 var(--space-4);
}

.python-project__text p:last-child {
    margin-bottom: 0;
}

.python-project__text ul {
    margin: var(--space-4) 0 var(--space-5);
    padding-left: var(--space-6);
}

.python-project__text li {
    margin-bottom: var(--space-2);
    line-height: 1.6;
}

.python-project__text li:last-child {
    margin-bottom: 0;
}

.python-project__image--dark {
    display: none;
}

html.theme-dark .python-project__image--light {
    display: none;
}

html.theme-dark .python-project__image--dark {
    display: block;
}

.python-project__cta {
    align-self: flex-start;
    margin-top: 0;
    color: var(--color-bg);
    background: var(--color-accent);
    border-color: var(--color-accent);
    box-shadow: 0 8px 18px color-mix(in srgb, var(--color-accent) 22%, transparent);
}

.python-project__cta:hover,
.python-project__cta:focus-visible,
.python-project__cta:active {
    color: var(--color-bg);
    background: var(--color-accent);
    border-color: var(--color-accent);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--color-accent) 28%, transparent);
}

@media (max-width: 900px) {
    .service-hero,
    .service-hero__inner {
        min-height: calc(100svh - 96px);
    }

    .service-hero__inner {
        grid-template-columns: 1fr;
        gap: var(--space-8);
        padding-block: var(--space-16);
    }

    .python-hero .service-hero__inner {
        width: min(100% - var(--space-6), var(--container-xl));
        min-height: calc(100svh - 96px);
        margin-inline: auto;
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-8);
        padding-block: var(--space-16);
    }

    .python-hero .service-hero__copy {
        width: 100%;
        min-height: auto;
        margin-left: 0;
        padding-block: 0;
    }

    .service-hero__copy .section-title {
        max-width: 100%;
        font-size: clamp(2.4rem, 8.8vw, 3.4rem);
    }

    .service-hero__copy .section-subtitle {
        max-width: 100%;
    }

    .python-hero__media,
    .service-hero .service-visual {
        width: 100%;
    }

    .python-hero .python-hero__media {
        position: relative;
        top: auto;
        right: auto;
        transform: none;
    }

    .python-hero .service-hero__points {
        position: static;
        margin-top: var(--space-8);
    }

    .python-hero__image {
        width: min(108%, 700px);
        max-height: min(62svh, 580px);
    }

    .python-projects__list {
        gap: var(--space-12);
    }

    .python-project,
    .python-project--reverse {
        flex-direction: column;
        align-items: stretch;
        gap: var(--space-6);
    }

    .python-project__content,
    .python-project__media {
        flex: 1 1 auto;
        width: 100%;
    }

    .python-project__media {
        aspect-ratio: 16 / 9;
    }

    .python-project__image,
    .python-project:not(.python-project--reverse) .python-project__image,
    .python-project--reverse .python-project__image {
        object-fit: cover;
        object-position: center;
    }
}

@media (max-width: 640px) {
    .service-hero,
    .service-hero__inner {
        min-height: calc(100svh - 120px);
    }

    .service-hero__inner {
        width: min(100% - var(--space-4), var(--container-xl));
        padding-block: var(--space-12);
    }

    .python-hero .service-hero__inner {
        width: min(100% - var(--space-4), var(--container-xl));
        padding-block: var(--space-12);
    }

    .service-hero__points {
        flex-direction: column;
        gap: var(--space-2);
    }

    .python-hero__media,
    .service-hero .service-visual {
        padding: 0;
    }

    .python-hero__image {
        width: 112%;
        max-width: none;
        max-height: min(56svh, 460px);
    }

    .python-projects .home-portfolio__head {
        margin-bottom: var(--space-10);
    }

    .python-projects__list {
        gap: var(--space-10);
    }

    .python-project__title {
        font-size: clamp(1.65rem, 9vw, 2.15rem);
    }

    .python-project__text {
        font-size: var(--font-size-body);
    }

    .python-project__image {
        max-width: 100%;
    }
}