/* ═══════════════════════════════════════════════════════════════════════════
   SOBRE MIM — Estilos específicos da página Sobre
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── 1. HERO ───────────────────────────────────────────────────────────── */
.about-hero {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-top: var(--nav-height);
    position: relative;
    overflow: hidden;
}

.about-hero__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.about-hero__glow {
    position: absolute;
    border-radius: var(--radius-full);
    filter: blur(100px);
    pointer-events: none;
}

.about-hero__glow--1 {
    width: 45vw;
    height: 45vw;
    background: radial-gradient(circle, rgba(124, 58, 237, .2), transparent 70%);
    top: -10%;
    right: -5%;
    animation: about-glow-1 14s ease-in-out infinite alternate;
}

.about-hero__glow--2 {
    width: 35vw;
    height: 35vw;
    background: radial-gradient(circle, rgba(201, 168, 76, .12), transparent 70%);
    bottom: 0%;
    left: 5%;
    animation: about-glow-2 18s ease-in-out infinite alternate;
}

@keyframes about-glow-1 {
    from {
        transform: translate(0, 0) scale(1);
    }

    to {
        transform: translate(-3%, 5%) scale(1.08);
    }
}

@keyframes about-glow-2 {
    from {
        transform: translate(0, 0) scale(1);
    }

    to {
        transform: translate(4%, -3%) scale(1.1);
    }
}

.about-hero__inner {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: var(--space-4xl);
    padding-block: var(--space-4xl);
    position: relative;
    z-index: 2;
}

/* Foto do hero */
.about-hero__photo-frame {
    position: relative;
    width: clamp(260px, 28vw, 380px);
    aspect-ratio: 3 / 4;
}

.about-hero__photo-placeholder {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-xl);
    background: var(--gradient-card);
    border: 1px solid rgba(124, 58, 237, .2);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
    z-index: 2;
}

.about-hero__photo-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}

/* Acentos decorativos da foto */
.about-hero__photo-accent {
    position: absolute;
    border-radius: var(--radius-xl);
    border: 1px solid transparent;
    z-index: 1;
}

.about-hero__photo-accent--1 {
    inset: -8px -8px -8px -8px;
    border-color: rgba(124, 58, 237, .2);
    transform: rotate(2deg);
}

.about-hero__photo-accent--2 {
    inset: -16px -16px -16px -16px;
    border-color: rgba(201, 168, 76, .1);
    transform: rotate(-1.5deg);
}

/* Conteúdo do hero */
.about-hero__title {
    font-family: var(--font-display);
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: var(--space-lg);
    background: linear-gradient(135deg, var(--text-primary) 30%, var(--color-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.about-hero__title em {
    font-style: italic;
    background: var(--gradient-gold);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    padding: 0px 0 10px 0;
}

.about-hero__subtitle {
    font-family: var(--font-elegant);
    font-size: clamp(1.1rem, 2vw, 1.3rem);
    font-style: italic;
    color: var(--text-secondary);
    line-height: 1.8;
    margin-bottom: var(--space-2xl);
    max-width: 90%;
}

/* Badges */
.about-hero__badges {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
}

.about-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: .5rem 1.25rem;
    border-radius: var(--radius-full);
    border: 1px solid rgba(124, 58, 237, .25);
    background: rgba(124, 58, 237, .08);
    font-family: var(--font-elegant);
    font-size: .9rem;
    font-style: italic;
    color: var(--text-secondary);
    transition: border-color var(--duration-base), background var(--duration-base), transform var(--duration-fast) var(--ease-spring);
}

.about-hero__badge:hover {
    border-color: rgba(168, 85, 247, .5);
    background: rgba(124, 58, 237, .15);
    transform: translateY(-2px);
}

.about-hero__badge-icon {
    color: var(--color-gold);
    font-size: 1rem;
}


/* ── 2. MINHA HISTÓRIA (Timeline) ──────────────────────────────────────── */
.about-story__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4xl);
    align-items: start;
}

.about-story__timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.about-story__block {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-lg);
    padding-bottom: var(--space-2xl);
}

.about-story__block:last-child {
    padding-bottom: 0;
}

.about-story__block:last-child .about-story__marker-line {
    display: none;
}

/* Markers da timeline */
.about-story__marker {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    padding-top: .35rem;
}

.about-story__marker-dot {
    width: 14px;
    height: 14px;
    border-radius: var(--radius-full);
    background: var(--gradient-aurora);
    flex-shrink: 0;
    box-shadow: 0 0 12px rgba(124, 58, 237, .5);
    position: relative;
}

.about-story__marker-dot::after {
    content: '';
    position: absolute;
    inset: 3px;
    border-radius: var(--radius-full);
    background: var(--color-void);
}

.about-story__marker-line {
    width: 1px;
    flex: 1;
    min-height: 30px;
    background: linear-gradient(to bottom, rgba(124, 58, 237, .4), rgba(124, 58, 237, .05));
    margin-top: var(--space-sm);
}

.about-story__heading {
    font-family: var(--font-display);
    font-size: 1.2rem;
    background: linear-gradient(135deg, var(--text-primary), var(--color-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: var(--space-sm);
}

.about-story__text p {
    color: var(--text-secondary);
    font-size: 1rem;
    line-height: 1.8;
}

/* Aside — citação */
.about-story__aside {
    position: sticky;
    top: calc(var(--nav-height) + var(--space-2xl));
}

.about-story__quote {
    background: rgba(22, 15, 51, .6);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(124, 58, 237, .2);
    border-radius: var(--radius-lg);
    padding: var(--space-2xl);
    position: relative;
    overflow: hidden;
}

.about-story__quote::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--gradient-gold);
}

.about-story__quote-mark {
    font-size: 3.5rem;
    line-height: 1;
    background: var(--gradient-aurora);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    opacity: .35;
    display: block;
    margin-bottom: var(--space-md);
}

.about-story__quote p {
    font-family: var(--font-elegant);
    font-size: clamp(1.15rem, 2vw, 1.4rem);
    font-style: italic;
    color: var(--text-secondary);
    line-height: 1.75;
    margin-bottom: var(--space-lg);
}

.about-story__quote cite {
    font-family: var(--font-elegant);
    font-size: .9rem;
    font-style: normal;
    color: var(--color-gold);
    letter-spacing: .1em;
}

/* TEMA ESPAÇO — Estrelas com CSS puro e tons lilás */
.about-stars-theme {
    background-color: #11051f;
    background-image: 
        radial-gradient(circle at 15% 50%, rgba(139, 92, 246, 0.15), transparent 50%),
        radial-gradient(circle at 85% 30%, rgba(196, 168, 245, 0.15), transparent 50%),
        radial-gradient(1.5px 1.5px at 10% 20%, #e8d9fe, transparent),
        radial-gradient(1px 1px at 20% 80%, #fff, transparent),
        radial-gradient(2px 2px at 30% 40%, #d8b4fe, transparent),
        radial-gradient(1px 1px at 40% 10%, #fff, transparent),
        radial-gradient(1.5px 1.5px at 50% 90%, #e8d9fe, transparent),
        radial-gradient(1px 1px at 60% 30%, #fff, transparent),
        radial-gradient(2px 2px at 70% 70%, #d8b4fe, transparent),
        radial-gradient(1.5px 1.5px at 80% 50%, #fff, transparent),
        radial-gradient(1px 1px at 90% 15%, #e8d9fe, transparent);
    background-size: 100% 100%, 100% 100%, 250px 250px, 150px 150px, 300px 300px, 200px 200px, 350px 350px, 180px 180px, 400px 400px, 220px 220px, 280px 280px;
    position: relative;
    z-index: 1;
    border-top: 1px solid rgba(196, 168, 245, 0.15);
    border-bottom: 1px solid rgba(196, 168, 245, 0.15);
}


/* ── 3. FACETAS ────────────────────────────────────────────────────────── */
.about-facets {
    position: relative;
    overflow: hidden;
}

.about-facets__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.about-facets__glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 50% at 50% 50%, rgba(124, 58, 237, .08), transparent);
}

.about-facets__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-xl);
    max-width: 920px;
    margin-inline: auto;
}

.about-facet {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    text-align: center;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.about-facet::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--gradient-aurora);
    transform: scaleX(0);
    transition: transform var(--duration-slow) var(--ease-smooth);
}

.about-facet:hover::before {
    transform: scaleX(1);
}

.about-facet__icon-wrap {
    width: 4.5rem;
    height: 4.5rem;
    border-radius: var(--radius-full);
    background: rgba(124, 58, 237, .1);
    border: 1px solid rgba(124, 58, 237, .2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-purple);
    transition: transform var(--duration-base) var(--ease-spring), background var(--duration-base), box-shadow var(--duration-base);
}

.about-facet:hover .about-facet__icon-wrap {
    transform: scale(1.1) rotate(5deg);
    background: rgba(124, 58, 237, .2);
    box-shadow: 0 0 25px rgba(124, 58, 237, .25);
}

.about-facet__title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    background: linear-gradient(135deg, var(--text-primary), var(--color-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1.5;
}

.about-facet__desc {
    color: var(--text-secondary);
    font-size: .95rem;
    line-height: 1.75;
    flex: 1;
}

.about-facet__highlight {
    font-family: var(--font-elegant);
    font-size: .8rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--color-gold);
    font-style: italic;
    padding-top: var(--space-md);
    border-top: 1px solid rgba(124, 58, 237, .12);
    width: 100%;
}


/* ── 4. FORMAÇÕES / CERTIFICAÇÕES ──────────────────────────────────────── */
.about-certs__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
    max-width: 1100px;
    margin-inline: auto;
}

.about-cert {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--space-lg);
    position: relative;
    overflow: hidden;
}

.about-cert::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--gradient-aurora);
    transform: scaleY(0);
    transform-origin: bottom;
    transition: transform var(--duration-slow) var(--ease-smooth);
}

.about-cert:hover::before {
    transform: scaleY(1);
}

.about-cert__number {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    background: var(--gradient-aurora);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    opacity: .25;
    line-height: 1;
}

.about-cert__title {
    font-family: var(--font-display);
    font-size: 1.05rem;
    background: linear-gradient(135deg, var(--text-primary), var(--color-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: .25rem;
}

.about-cert__institution {
    font-family: var(--font-elegant);
    font-size: .9rem;
    font-style: italic;
    color: var(--text-muted);
}

.about-cert__icon {
    color: var(--color-gold);
    opacity: .4;
    transition: opacity var(--duration-fast), transform var(--duration-fast) var(--ease-spring);
}

.about-cert:hover .about-cert__icon {
    opacity: .8;
    transform: scale(1.15);
}




/* ── 5. FORMA DE TRABALHAR (Valores) ───────────────────────────────────── */
.about-values {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, #130a2a 0%, #170d33 100%);
    /* Roxo escuro luxuoso, porém mais leve */
}

.about-values__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.about-values__glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 50% at 50% 50%, rgba(124, 58, 237, 0.15), transparent);
}

.about-values__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-xl);
    max-width: 920px;
    margin-inline: auto;
    position: relative;
    z-index: 2;
}

.about-value {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-xl);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(168, 85, 247, 0.3);
    background: rgba(45, 25, 80, 0.65);
    box-shadow: 0 10px 30px rgba(5, 2, 10, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transition: border-color var(--duration-base), background var(--duration-base), transform var(--duration-base) var(--ease-spring), box-shadow var(--duration-base);
}

.about-value:hover {
    border-color: rgba(201, 168, 76, 0.5);
    background: rgba(65, 40, 110, 0.8);
    transform: translateY(-3px);
    box-shadow: 0 15px 40px rgba(5, 2, 10, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.about-value__icon {
    width: 3.2rem;
    height: 3.2rem;
    border-radius: var(--radius-md);
    background: var(--gradient-iridescent);
    background-size: 300% 300%;
    animation: iridescent-shift 6s ease infinite;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin-bottom: var(--space-sm);
    box-shadow: 0 0 15px rgba(124, 58, 237, 0.3);
    transition: transform var(--duration-fast) var(--ease-spring);
}

.about-value:hover .about-value__icon {
    transform: scale(1.1);
    box-shadow: 0 0 25px rgba(201, 168, 76, 0.5);
}

.about-value__title {
    font-family: var(--font-display);
    font-size: 1.15rem;
    background: linear-gradient(135deg, var(--text-primary), var(--color-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: 0.02em;
    line-height: 1.5;
}

.about-value__desc {
    color: var(--text-secondary);
    font-size: .95rem;
    line-height: 1.75;
}


/* ── 6. CTA (reutiliza .cta-band do home.css) ──────────────────────────── */
/* Os estilos do CTA já estão definidos no home.css como .cta-band.
   Caso a página sobre seja carregada sem home.css, incluímos aqui
   os estilos do CTA como fallback. */

.page-about .cta-band {
    position: relative;
    overflow: hidden;
    padding-block: var(--space-5xl);
    border-top: 1px solid rgba(124, 58, 237, .15);
    border-bottom: 1px solid rgba(124, 58, 237, .15);
}

.page-about .cta-band__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.page-about .cta-band__glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(124, 58, 237, .12), transparent);
}

.page-about .cta-band__inner {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--space-3xl);
    position: relative;
    z-index: 2;
}

.page-about .cta-band__title {
    font-size: 2.5rem;
    background: linear-gradient(135deg, var(--text-primary), var(--color-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-block: var(--space-md);
    line-height: 1.5;
}

.page-about .cta-band__desc {
    color: var(--text-secondary);
    font-size: 1.05rem;
    line-height: 1.7;
}

.page-about .cta-band__action {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    flex-shrink: 0;
}


/* ── RESPONSIVIDADE ────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .about-hero__inner {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .about-hero__photo {
        display: flex;
        justify-content: center;
        order: -1;
    }

    .about-hero__photo-frame {
        width: clamp(200px, 50vw, 300px);
    }

    .about-hero__subtitle {
        margin-inline: auto;
    }

    .about-hero__badges {
        justify-content: center;
    }

    .about-story__content {
        grid-template-columns: 1fr;
    }

    .about-story__aside {
        position: static;
    }

    .about-facets__grid {
        grid-template-columns: 1fr;
        max-width: 460px;
        margin-inline: auto;
    }

    .about-certs__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .about-values__grid {
        grid-template-columns: 1fr;
    }

    .page-about .cta-band__inner {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .page-about .cta-band__action {
        align-items: center;
    }

    .about-hero__title {
        font-size: 1.5rem;
        line-height: 1.5;
    }

    .page-about .cta-band__title {
        font-size: 2rem;
        line-height: 1.5;
    }

}

@media (max-width: 600px) {
    .about-hero__photo-frame {
        width: 220px;
    }

    .about-certs__grid {
        grid-template-columns: 1fr;
    }

    .about-cert {
        grid-template-columns: auto 1fr;
    }

    .about-cert__icon {
        display: none;
    }
}