/*
Theme Name: GV Psicólogo
Theme URI: https://luisantoniodev.com.br
Author: Luis Antonio
Author URI: https://luisantoniodev.com.br
Description: Tema WordPress premium desenvolvido para psicólogos e profissionais da saúde mental. Possui páginas exclusivas para apresentação profissional, serviços, feedbacks, blog avançado, área Psicocrânio para vídeos, layouts modernos, personalização completa através do WordPress Customizer, design responsivo, otimização para SEO e estrutura focada em autoridade, conversão e experiência do usuário.
Version: 1.0.0
Text Domain: GUSTAVO-VINICIUS-THEME
*/

/* =========================================


/* RESET */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: Arial, sans-serif;
    overflow-x: hidden;
}

/* CONTAINER */

.container {
    width: 100%;
    max-width: 1280px;
    margin: auto;
    padding: 0 30px;
}

/* ================= HEADER ================= */

.main-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 95px;
    z-index: 9999;
    transition: .3s;
    backdrop-filter: blur(8px);
    background-color: #101216;
}

.main-header.scrolled {
    box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
}

/* header interno */

.main-header .container {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* logo */

.logo {
    flex: 0 0 350px;
    /* largura fixa */
    display: flex;
    justify-content: flex-start;
}

.custom-logo{
    width: 350px;
    max-width: 100%;
    height: auto;
    display: block;
}

/* menu */

.main-nav {
    flex: 1;
    display: flex;
    justify-content: center;
    min-width: 0;
}

/* HEADER INTERNO */

.main-header .container {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* MENU */

.main-nav {
    flex: 1;
    display: flex;
    justify-content: center;
    min-width: 0;
}

.main-nav ul {
    display: flex;
    align-items: center;
    list-style: none;
    gap: 34px;
    padding: 0;
    margin: 0;
    flex-wrap: nowrap;
}

.main-nav a {
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    color: white;
    white-space: nowrap;
    transition: .3s;
    font-family: "Bricolage Grotesque", sans-serif;
}

.main-nav a:hover {
    transform: translateY(-2px);
    color: #D4B46A;
}

/* REDES */

.social-icons {
    flex: 0 0 170px;
    display: flex;
    justify-content: flex-end;
    gap: 14px;
}

.social-icons a {
    width: 42px;
    height: 42px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    text-decoration: none;
    font-size: 18px;

    /* visual premium */
    background: transparent;
    border: 1.5px solid #D4B46A;
    color: #D4B46A;

    /* animação suave */
    transition: all 0.35s ease;
}

/* hover */
.social-icons a:hover {
    transform: scale(1.12);
    background: #D4B46A;
    color: #101216;
    box-shadow: 0 0 18px rgba(212, 180, 106, 0.35);
}

.social-icons i {
    transform: translateY(1px);
}

/* botão mobile */

.menu-toggle {
    display: none;
    background: none;
    border: none;
    font-size: 25px;
    cursor: pointer;
}

.menu-toggle i {
    color: #D4B46A;
}

/* ================= HERO ================= */

.hero {
    position: relative;
    height: 800px;
    /* altura fixa */
    padding-top: 95px;
    display: flex;
    align-items: center;
    overflow: hidden;
    /* background direto no container */
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    /* mostra tudo sem cortar */
    background-color: #f5f5f5;
    /* cor de fundo caso sobrem espaços */
}

.hero::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;

    width: 100%;
    height: 3px;

    background: linear-gradient(to right,
            transparent,
            rgba(212, 180, 106, 0.15),
            rgba(212, 180, 106, 0.55),
            rgba(212, 180, 106, 0.15),
            transparent);

    filter: blur(0.4px);
}

/* layout */

.hero-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 60px;
}

/* texto */

.hero-content {
    max-width: 620px;
    padding-left: 20px;
    margin-top: -40px;
}

.hero-content h1 {
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 55px;
    font-weight: 500;
    line-height: 0.95;
    letter-spacing: -3px;
    color: #D4B46A;
    margin-top: 120px;
    margin-bottom: 28px;
}

.hero-content p {
    font-family: "Montserrat", sans-serif;
    font-size: 24px;
    font-weight: 400;
    line-height: 1.55;
    margin-bottom: 28px;
    color: #D8D8D8;
    max-width: 540px;
}

.crm {
    display: inline-block;
    padding: 8px 18px;
    margin-bottom: 35px;
    border: 1px solid rgba(212, 180, 106, 0.35);
    border-radius: 30px;
    background: rgba(212, 180, 106, 0.08);

    font-size: 18px;
    font-weight: 500;
    color: #D4B46A;
}

/* botão */

.hero-btn {
    width: 360px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;

    text-decoration: none;
    font-weight: 700;
    font-size: 18px;

    color: #101216;
    background: #D4B46A;

    border-radius: 40px;
    padding: 18px;

    transition: all .3s ease;
}

.hero-btn:hover {
    transform: scale(1.04);
    background: #E3C784;
    box-shadow: 0 0 25px rgba(212, 180, 106, 0.25);
}

/* escondido por padrão */
.mobile-extra {
    display: none;
}

/* ================= PROCESSO ================= */

/* ================= PROCESSO ================= */

.therapy-process {
    position: relative;
    padding: 80px 0;
    overflow: hidden;
    z-index: 1;

    /* FUNDO PREMIUM */
    background:
        /* glow central principal */
        radial-gradient(circle at 50% 45%,
            rgba(212, 180, 106, 0.28) 0%,
            rgba(212, 180, 106, 0.10) 22%,
            rgba(212, 180, 106, 0.04) 38%,
            transparent 60%),

        /* glow lateral esquerda */
        radial-gradient(circle at 18% 35%,
            rgba(212, 180, 106, 0.12) 0%,
            transparent 30%),

        /* glow lateral direita */
        radial-gradient(circle at 82% 65%,
            rgba(212, 180, 106, 0.10) 0%,
            transparent 32%),

        /* degradê principal */
        linear-gradient(180deg,
            #fcfbf8 0%,
            #f8f5ef 30%,
            #f4efe6 55%,
            #f7f3ec 75%,
            #fbfaf7 100%);
}

/* textura gráfica esquerda */
.therapy-process::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: .25;

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='600' viewBox='0 0 1200 600'%3E%3Cg fill='none' stroke='%23d4b46a' stroke-width='1' stroke-opacity='0.25'%3E%3Cpath d='M0 300 Q180 80 400 300 T800 300 T1200 300'/%3E%3Cpath d='M0 340 Q180 120 400 340 T800 340 T1200 340'/%3E%3Cpath d='M0 380 Q180 160 400 380 T800 380 T1200 380'/%3E%3Cpath d='M0 260 Q180 40 400 260 T800 260 T1200 260'/%3E%3C/g%3E%3C/svg%3E");

    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

/* brilho extra no centro */
.therapy-process::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 900px;
    height: 500px;
    z-index: 0;
    pointer-events: none;

    background:
        radial-gradient(ellipse,
            rgba(255, 255, 255, 0.75) 0%,
            rgba(255, 255, 255, 0.25) 35%,
            rgba(212, 180, 106, 0.06) 55%,
            transparent 75%);

    filter: blur(40px);
}

/* conteúdo acima do background */
.therapy-process .container {
    position: relative;
    z-index: 2;
}

/* esquerda */
.therapy-process::before {
    left: -170px;

    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.35' stroke-width='1.2'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");
}

/* direita */
.therapy-process::after {
    right: -170px;
    transform: scaleX(-1);

    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.35' stroke-width='1.2'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");
}

.therapy-process .container {
    position: relative;
    z-index: 2;
}

.process-top,
.process-cards {
    position: relative;
    z-index: 3;
}

.therapy-process::before {
    filter: blur(0.5px);
}

.therapy-process::after {
    filter: blur(0.5px);
}

/* glow central atrás dos cards */
.therapy-process .container::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 58%;
    transform: translate(-50%, -50%);
    width: 1100px;
    height: 500px;
    pointer-events: none;
    z-index: 1;

    background:
        radial-gradient(ellipse,
            rgba(212, 180, 106, 0.22) 0%,
            rgba(212, 180, 106, 0.10) 35%,
            rgba(212, 180, 106, 0.04) 55%,
            transparent 75%);
}

/* topo */

.process-top {
    display: flex;
    justify-content: space-between;
    gap: 80px;
    margin-bottom: 90px;
    align-items: center;
}

.process-heading {
    max-width: 520px;
}

.process-heading span {
    display: inline-block;
    color: #B9934E;
    font-size: 14px;
    letter-spacing: 2px;
    margin-bottom: 18px;
    font-family: "Montserrat", sans-serif;
    position: relative;
}

.process-heading span::after {
    content: '';
    display: block;
    width: 60px;
    height: 2px;
    background: #D4B46A;
    margin-top: 12px;
}

.process-heading h2 {
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 36px;
    line-height: 0.95;
    color: #101216;
    letter-spacing: -3px;
}

.process-heading h2 strong {
    color: #D4B46A;
    font-weight: 500;
}

.process-description {
    max-width: 520px;
    padding-left: 50px;
    border-left: 2px solid rgba(212, 180, 106, .4);
}

.process-description p {
    font-size: 18px;
    line-height: 1.6;
    color: #333;
    font-family: "Montserrat", sans-serif;
}

/* cards */

.process-cards {
    position: relative;
    display: grid;

    /* cards mais largos */
    grid-template-columns: repeat(4, minmax(0, 1fr));

    gap: 20px;
    align-items: start;
}

.process-line {
    position: absolute;
    top: 32px;
    left: 10%;
    width: 80%;
    height: 70px;
    z-index: 1;
    pointer-events: none;
}

/* linha principal ondulada */
.process-line::before {
    content: '';
    position: absolute;
    inset: 0;

    background:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='70' viewBox='0 0 1200 70'%3E%3Cpath d='M0 35 C120 5, 180 65, 300 35 S480 5, 600 35 S780 65, 900 35 S1080 5, 1200 35' fill='none' stroke='%23d4b46a' stroke-width='2' stroke-opacity='0.35'/%3E%3C/svg%3E");

    background-size: cover;
    background-repeat: no-repeat;
}

/* brilhos nos pontos */
.process-line::after {
    content: '';
    position: absolute;
    inset: 0;

    background:
        radial-gradient(circle at 17% 50%, rgba(212, 180, 106, .9) 0, rgba(212, 180, 106, .15) 8px, transparent 14px),
        radial-gradient(circle at 39% 50%, rgba(212, 180, 106, .9) 0, rgba(212, 180, 106, .15) 8px, transparent 14px),
        radial-gradient(circle at 61% 50%, rgba(212, 180, 106, .9) 0, rgba(212, 180, 106, .15) 8px, transparent 14px),
        radial-gradient(circle at 83% 50%, rgba(212, 180, 106, .9) 0, rgba(212, 180, 106, .15) 8px, transparent 14px);
}

.process-card {
    isolation: isolate;
    position: relative;
    background: #101216;
    border-radius: 26px;

    /* MAIS LARGOS / QUASE QUADRADOS */
    min-height: 350px;

    padding: 30px 20px 2px;

    text-align: left;
    z-index: 2;

    /* IMPORTANTE */
    overflow: visible;

    border: 1px solid rgba(212, 180, 106, .12);

    box-shadow:
        0 12px 30px rgba(0, 0, 0, .12),
        0 0 30px rgba(212, 180, 106, .08),
        inset 0 1px 0 rgba(255, 255, 255, .04);

    transition:
        transform .35s ease,
        box-shadow .35s ease,
        border-color .35s ease;
}

.process-card::before {
    content: '';
    position: absolute;

    top: -90px;
    left: 50%;
    transform: translateX(-50%);

    width: 260px;
    height: 180px;

    background: radial-gradient(ellipse,
            rgba(212, 180, 106, .18) 0%,
            rgba(212, 180, 106, .09) 35%,
            rgba(212, 180, 106, .03) 55%,
            transparent 75%);

    pointer-events: none;
}

.process-card::after {
    content: '';

    position: absolute;

    top: 0;
    left: 50%;

    transform: translateX(-50%);

    width: 0%;
    height: 2px;

    border-radius: 999px;

    background: linear-gradient(90deg,
            transparent,
            rgba(212, 180, 106, .95),
            transparent);

    transition: width .45s ease;

    z-index: 3;
}

.process-card:hover {
    transform: translateY(-14px);

    border-color: rgba(212, 180, 106, .30);

    box-shadow:
        0 24px 55px rgba(0, 0, 0, .20),
        0 0 30px rgba(212, 180, 106, .10);

}

.process-card:hover::after {
    width: 82%;
}

.step-badge {
    position: absolute;

    top: -34px;
    left: 50%;

    transform: translateX(-50%);

    width: 72px;
    height: 72px;

    border-radius: 50%;

    background: #D4B46A;
    color: #101216;

    font-weight: 700;
    font-size: 30px;

    display: flex;
    align-items: center;
    justify-content: center;

    z-index: 5;

    box-shadow:
        0 8px 20px rgba(212, 180, 106, .20),
        0 0 0 8px #f5f3ef;

    transition:
        transform .35s ease,
        box-shadow .35s ease,
        background .35s ease;
}

/* animação */
@keyframes pulseBadge {

    0% {
        transform: translateX(-50%) scale(1);
        background: #D4B46A;

        box-shadow:
            0 8px 20px rgba(212, 180, 106, .20),
            0 0 0 8px #f5f3ef;
    }

    50% {
        transform: translateX(-50%) scale(1.12);
        background: #E3C784;

        box-shadow:
            0 12px 28px rgba(212, 180, 106, .45),
            0 0 35px rgba(212, 180, 106, .30),
            0 0 0 8px #f5f3ef;
    }

    100% {
        transform: translateX(-50%) scale(1);
        background: #D4B46A;

        box-shadow:
            0 8px 20px rgba(212, 180, 106, .20),
            0 0 0 8px #f5f3ef;
    }
}

.process-card i {
    display: block;
    font-size: 28px;
    color: #D4B46A;
    margin-bottom: 25px;
    transition:
        transform .35s ease,
        color .35s ease;
}

.process-card:hover i {
    transform: scale(1.08);
    color: #E3C784;
}

.process-card h3 {
    color: white;
    font-size: 22px;
    line-height: 1.15;
    margin-bottom: 18px;
    font-family: "Bricolage Grotesque", sans-serif;
}

.mini-divider {
    width: 50px;
    height: 2px;
    background: #D4B46A;
    display: block;
    margin: 0 0 22px;
}

.process-card p {
    color: #d7d7d7;
    font-size: 16px;
    line-height: 1.8;
    font-family: "Montserrat", sans-serif;
}

/* botão */

.process-btn-wrap {
    margin-top: 60px;
    display: flex;
    justify-content: center;
}

.process-btn {
    width: 360px;
    padding: 18px;

    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;

    text-decoration: none;
    font-weight: 700;
    font-size: 18px;

    color: #101216;
    background: #D4B46A;
    border-radius: 40px;

    transition: .3s;
}

.process-btn:hover {
    transform: scale(1.04);
    background: #E3C784;
    box-shadow: 0 0 25px rgba(212, 180, 106, .25);
}

/* ================= PARA QUEM É ================= */

.psychology-audience {
    position: relative;
    background: #101216;
    padding: 60px 0;
    overflow: hidden;
}

/* glow suave */

.audience-bg-glow {
    position: absolute;
    inset: 0;
    pointer-events: none;

    background:
        radial-gradient(circle at 15% 30%,
            rgba(212, 180, 106, .08),
            transparent 28%),
        radial-gradient(circle at 85% 70%,
            rgba(212, 180, 106, .06),
            transparent 32%);
}

/* ondas laterais */

.psychology-audience::before,
.psychology-audience::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 420px;
    height: 500px;
    transform: translateY(-50%);
    pointer-events: none;
    opacity: .35;
}

/* esquerda */

.psychology-audience::before {
    left: -180px;

    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.25' stroke-width='1'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");
}

/* direita */

.psychology-audience::after {
    right: -180px;
    transform: translateY(-50%) scaleX(-1);

    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.25' stroke-width='1'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");
}

/* header */

.audience-header {
    text-align: center;
    max-width: 850px;
    margin: auto;
    margin-bottom: 70px;
    position: relative;
    z-index: 2;
}

.audience-header span {
    color: #D4B46A;
    letter-spacing: 2px;
    font-size: 14px;
    display: inline-block;
    margin-bottom: 20px;
}

.audience-header h2 {
    color: white;
    font-size: 36px;
    line-height: 1.05;
    font-family: "Bricolage Grotesque", sans-serif;
    margin-bottom: 25px;
}

.audience-header h2 strong {
    color: #D4B46A;
    font-weight: 500;
}

.audience-header p {
    color: #d6d6d6;
    font-size: 18px;
    line-height: 1.6;
    max-width: 700px;
    margin: auto;
}

/* grid */

.audience-grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

/* cards */

.reveal-left {
    transform: translateX(-80px);
}

.reveal-right {
    transform: translateX(80px);
}

.reveal-top {
    transform: translateY(-80px);
}

.reveal-bottom {
    transform: translateY(80px);
}

.audience-card:nth-child(1) {
    transition-delay: .1s;
}

.audience-card:nth-child(2) {
    transition-delay: .2s;
}

.audience-card:nth-child(3) {
    transition-delay: .3s;
}

.audience-card:nth-child(4) {
    transition-delay: .4s;
}

.audience-card:nth-child(5) {
    transition-delay: .5s;
}

.audience-card:nth-child(6) {
    transition-delay: .6s;
}

.audience-card.active {
    opacity: 1;
    transform: translate(0, 0);
}

.audience-card {
    opacity: 0;
    transition:
        transform .9s cubic-bezier(.22, 1, .36, 1),
        opacity .9s ease;
    background: rgba(255, 255, 255, .02);
    border: 1px solid rgba(212, 180, 106, .22);
    border-radius: 24px;
    padding: 45px 35px;
    text-align: center;

    backdrop-filter: blur(10px);
}

.audience-card:hover {
    transform: translateY(-10px);
    border-color: rgba(212, 180, 106, .45);

    box-shadow:
        0 20px 35px rgba(0, 0, 0, .25),
        0 0 25px rgba(212, 180, 106, .08);
}

.audience-card i {
    font-size: 42px;
    color: #D4B46A;
    margin-bottom: 25px;
}

.audience-card h3 {
    color: white;
    font-size: 22px;
    margin-bottom: 18px;
    font-family: "Bricolage Grotesque", sans-serif;
}

.audience-card p {
    color: #d7d7d7;
    line-height: 1.7;
    font-size: 16px;
}

/* botão */

.audience-btn-wrap {
    margin-top: 60px;
    display: flex;
    justify-content: center;
}

/* ================= FORMAS DE ATENDIMENTO ================= */

/* ================= FORMAS DE ATENDIMENTO ================= */

.service-modes {
    position: relative;
    padding: 80px 0;
    background: #f8f5ef;
    overflow: hidden;
}

/* ondas douradas esquerda */
.service-modes::before {
    content: '';
    position: absolute;
    top: 50%;
    left: -180px;
    transform: translateY(-50%);

    width: 500px;
    height: 500px;

    pointer-events: none;
    opacity: .45;
    z-index: 0;

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-width='1.4' stroke-opacity='0.55'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");

    background-repeat: no-repeat;
    background-size: contain;
}

/* ondas douradas direita */
.service-modes::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -180px;
    transform: translateY(-50%) scaleX(-1);

    width: 500px;
    height: 500px;

    pointer-events: none;
    opacity: .65;
    z-index: 0;

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-width='1.4' stroke-opacity='0.55'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");

    background-repeat: no-repeat;
    background-size: contain;
}

/* garante conteúdo acima das ondas */
.service-modes .container {
    position: relative;
    z-index: 2;
}

.service-modes .container::before,
.service-modes .container::after {
    content: '';
    position: absolute;
    width: 180px;
    height: 180px;
    pointer-events: none;
    opacity: .35;
}

/* canto superior direito */

.service-modes .container::before {
    top: -40px;
    right: -40px;

    background-image:
        radial-gradient(rgba(212, 180, 106, .35) 1px,
            transparent 1px);

    background-size: 14px 14px;
}

/* canto inferior esquerdo */

.service-modes .container::after {
    bottom: -40px;
    left: -40px;

    background-image:
        radial-gradient(rgba(212, 180, 106, .25) 1px,
            transparent 1px);

    background-size: 14px 14px;
}

.service-modes::after {
    filter: blur(.5px);
}

.service-modes .soft-glow {
    position: absolute;
    inset: 0;
    pointer-events: none;

    background:
        radial-gradient(circle at 50% 30%,
            rgba(255, 255, 255, .45),
            transparent 30%);
}

.reveal-fade {
    opacity: 0;
    transition: opacity .8s ease;
}

.reveal-fade.active {
    opacity: 1;
}

.reveal-image {
    opacity: 0;
    transform: translateX(80px);
    transition:
        opacity 1s ease,
        transform 1s cubic-bezier(.22, 1, .36, 1);
}

.reveal-image.active {
    opacity: 1;
    transform: translateX(0);
}

.reveal-shrink {
    opacity: 0;
    transform: scale(.75);
    transition:
        opacity .7s ease,
        transform .7s cubic-bezier(.22, 1, .36, 1);
}

.reveal-shrink.active {
    opacity: 1;
    transform: scale(1);
}

.reveal-drop {
    opacity: 0;
    transform: translateY(-35px);
    transition:
        opacity .7s ease,
        transform .7s cubic-bezier(.22, 1, .36, 1);
}

.reveal-drop.active {
    opacity: 1;
    transform: translateY(0);
}

.tab-panel li:nth-child(1) {
    transition-delay: .10s;
}

.tab-panel li:nth-child(2) {
    transition-delay: .20s;
}

.tab-panel li:nth-child(3) {
    transition-delay: .30s;
}

.tab-panel li:nth-child(4) {
    transition-delay: .40s;
}

.tab-panel li:nth-child(5) {
    transition-delay: .50s;
}

/* linhas decorativas */

.mode-layout::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .08;

    background:
        radial-gradient(circle at 20% 25%,
            rgba(212, 180, 106, .18) 0%,
            transparent 28%),

        radial-gradient(circle at 80% 75%,
            rgba(212, 180, 106, .10) 0%,
            transparent 30%);
}

.modes-box {
    position: relative;
}

.mode-layout {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 520px;
    gap: 45px;
    align-items: stretch;

    padding: 70px;
    border-radius: 38px;
    overflow: hidden;
    border: 1px solid rgba(212, 180, 106, .18);

    background:
        radial-gradient(circle at 50% 30%,
            rgba(212, 180, 106, .10),
            transparent 35%),

        radial-gradient(circle at 20% 70%,
            rgba(212, 180, 106, .05),
            transparent 30%),

        linear-gradient(180deg,
            #101216 0%,
            #15181d 100%);

    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, .03),
        0 20px 50px rgba(0, 0, 0, .15);
}

.mode-left {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.mode-tabs {
    margin-top: 40px;
    margin-bottom: 30px;
    display: flex;
    gap: 14px;
}

.mode-card {
    flex: 1;
    background: rgba(255, 255, 255, .03);
    border: 1px solid rgba(212, 180, 106, .12);
    border-radius: 28px;
    padding: 45px;
}

/* IMAGEM */

.mode-image {
    height: 100%;
}

.mode-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 28px;
    display: block;
}

/* header */

.modes-header span {
    color: #B9934E;
    letter-spacing: 2px;
    font-size: 14px;
    display: flex;
    gap: 10px;
    align-items: center;
    margin-bottom: 18px;
}

.modes-header h2 {
    font-size: 36px;
    color: white;
    line-height: 1;
    font-family: "Bricolage Grotesque", sans-serif;
    max-width: 650px;
    margin-bottom: 20px;
}

.modes-header strong {
    color: #D4B46A;
    font-weight: 500;
}

.modes-header p {
    font-size: 18px;
    color: #d7d7d7;
    max-width: 620px;
    line-height: 1.5;
}

/* tabs */

.mode-btn {
    padding: 18px 35px;
    border-radius: 999px;
    border: 1px solid rgba(212, 180, 106, .18);

    background: rgba(255, 255, 255, .03);
    color: white;

    cursor: pointer;
    font-size: 18px;
    font-weight: 600;

    transition: .3s;

    display: flex;
    gap: 12px;
    align-items: center;

    backdrop-filter: blur(10px);
}

.mode-btn.active {
    background: #D4B46A;
    color: #101216;
    box-shadow: 0 0 25px rgba(212, 180, 106, .25);
}

.mode-btn:hover {
    transform: translateY(-2px);
}

/* conteúdo */



.tab-panel {
    display: none;
}

.tab-panel.active {
    display: block;
    animation: fade .4s ease;
}

.tab-panel h3 {
    color: white;
    font-size: 22px;
    margin-bottom: 20px;
    font-family: "Bricolage Grotesque", sans-serif;
}

.tab-panel p {
    font-size: 16px;
    line-height: 1.6;
    color: #d7d7d7;
}

.mode-divider {
    width: 80px;
    height: 2px;
    background: #D4B46A;
    margin: 30px 0;
}

.tab-panel ul {
    list-style: none;
}

.tab-panel li {
    margin-bottom: 18px;
    font-size: 16px;
    position: relative;
    padding-left: 28px;
    color: #f1f1f1;
}

.tab-panel li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #D4B46A;
}

/* imagem */

.mode-image:hover img {
    transform: scale(1.03);
}

/* ======================================
   BLOCO BENEFÍCIOS TERAPIA
====================================== */

.therapy-benefits-box {
    position: relative;
    overflow: hidden;
    margin-top: 40px;
    padding: 50px 55px;

    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 60px;
    align-items: center;

    border-radius: 32px;
    border: 1px solid rgba(212, 180, 106, .18);

    background:
        radial-gradient(circle at 50% 50%,
            rgba(212, 180, 106, .06),
            transparent 45%),

        radial-gradient(circle at 20% 20%,
            rgba(212, 180, 106, .10),
            transparent 28%),

        radial-gradient(circle at 80% 70%,
            rgba(212, 180, 106, .08),
            transparent 30%),

        linear-gradient(180deg,
            #101216 0%,
            #15181d 100%);

    backdrop-filter: blur(8px);

    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, .7),
        0 10px 30px rgba(0, 0, 0, .04);
}

/* ondas decorativas laterais */

.therapy-benefits-box::before,
.therapy-benefits-box::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 340px;
    height: 420px;

    transform: translateY(-50%);
    pointer-events: none;
    opacity: .22;
}

/* esquerda */

.therapy-benefits-box::before {
    left: -180px;

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.35' stroke-width='1.1'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");

    background-repeat: no-repeat;
    background-size: contain;
}

/* direita */

.therapy-benefits-box::after {
    right: -180px;
    transform: translateY(-50%) scaleX(-1);

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.35' stroke-width='1.1'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");

    background-repeat: no-repeat;
    background-size: contain;
}

/* esquerda */

.benefits-left span {
    display: flex;
    align-items: center;
    gap: 10px;

    color: #B9934E;
    font-size: 13px;
    letter-spacing: 2px;
    margin-bottom: 20px;
}

.benefits-left span i {
    color: #D4B46A;
}

.benefits-left h3 {
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 34px;
    line-height: 1.05;
    color: white;
    margin-bottom: 22px;
    max-width: 620px;
}

.benefits-left h3 strong {
    color: #D4B46A;
    font-weight: 500;
}

.benefits-left p {
    font-size: 17px;
    line-height: 1.8;
    color: #d6d6d6;
    max-width: 600px;
}

/* direita */

.benefits-right {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.benefit-item {
    display: flex;
    align-items: center;
    gap: 18px;

    padding: 22px 24px;

    border-radius: 20px;
    border: 1px solid rgba(212, 180, 106, .15);

    background:
        rgba(255, 255, 255, .03);

    backdrop-filter: blur(10px);

    transition: .3s;
}

.benefit-item:hover {
    transform: translateY(-4px);

    border-color: rgba(212, 180, 106, .35);

    box-shadow:
        0 10px 25px rgba(212, 180, 106, .08);
}

.benefit-item i {
    width: 46px;
    height: 46px;
    flex-shrink: 0;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;

    background: rgba(212, 180, 106, .12);
    color: #D4B46A;

    font-size: 18px;
}

.benefit-item span {
    font-size: 16px;
    color: #f1f1f1;
    line-height: 1.5;
    font-weight: 500;
}

/* =========================================
   VÍDEOS DO PSICÓLOGO
========================================= */

.psychology-videos {
    position: relative;
    padding: 100px 0;
    background: #101216;
    overflow: hidden;
}

/* glow */

.videos-bg-glow {
    position: absolute;
    inset: 0;
    pointer-events: none;

    background:
        radial-gradient(circle at 15% 30%,
            rgba(212, 180, 106, .08),
            transparent 28%),

        radial-gradient(circle at 85% 70%,
            rgba(212, 180, 106, .06),
            transparent 32%);
}

/* ondas laterais */

.psychology-videos::before,
.psychology-videos::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 420px;
    height: 500px;
    transform: translateY(-50%);
    pointer-events: none;
    opacity: .30;
}

.psychology-videos::before {
    left: -180px;

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.25' stroke-width='1'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");
}

.psychology-videos::after {
    right: -180px;
    transform: translateY(-50%) scaleX(-1);

    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 500'%3E%3Cg fill='none' stroke='%23D4B46A' stroke-opacity='0.25' stroke-width='1'%3E%3Cpath d='M0 250 Q180 40 380 250 T760 250'/%3E%3Cpath d='M0 280 Q180 70 380 280 T760 280'/%3E%3Cpath d='M0 310 Q180 100 380 310 T760 310'/%3E%3Cpath d='M0 340 Q180 130 380 340 T760 340'/%3E%3C/g%3E%3C/svg%3E");
}

/* conteúdo */

.psychology-videos .container {
    position: relative;
    z-index: 2;
}

/* header */

.videos-header {
    max-width: 800px;
    margin: auto;
    text-align: center;
    margin-bottom: 70px;
}

.videos-header span {
    color: #D4B46A;
    letter-spacing: 2px;
    font-size: 14px;
    display: inline-block;
    margin-bottom: 20px;
}

.videos-header h2 {
    color: white;
    font-size: 38px;
    line-height: 1.05;
    margin-bottom: 25px;
    font-family: "Bricolage Grotesque", sans-serif;
}

.videos-header strong {
    color: #D4B46A;
    font-weight: 500;
}

.videos-header p {
    color: #d6d6d6;
    font-size: 18px;
    line-height: 1.6;
    max-width: 700px;
    margin: auto;
}

/* grid */

.videos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

/* card */

.video-card {
    background: rgba(255, 255, 255, .03);
    border: 1px solid rgba(212, 180, 106, .15);
    border-radius: 26px;
    padding: 14px;

    backdrop-filter: blur(10px);

    transition: .35s;
}

.video-card:hover {
    transform: translateY(-8px);

    border-color: rgba(212, 180, 106, .35);

    box-shadow:
        0 20px 35px rgba(0, 0, 0, .30),
        0 0 25px rgba(212, 180, 106, .08);
}

/* player */

.video-frame {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 16/9;
}

.video-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: .45s;
}

.video-card:hover img {
    transform: scale(1.05);
    filter: brightness(.7);
}

/* botão play */

.video-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    width: 76px;
    height: 76px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    background: rgba(16, 18, 22, .82);
    border: 2px solid #D4B46A;

    color: #D4B46A;
    font-size: 24px;

    transition: .3s;
}

.video-card:hover .video-play {
    background: #D4B46A;
    color: #101216;
    transform: translate(-50%, -50%) scale(1.08);
}

/* título */

.video-title {
    margin-top: 16px;
    color: white;
    text-align: center;
    font-size: 16px;
    line-height: 1.5;
    padding: 0 10px;
}

/* iframe quando clicar */

.video-frame iframe {
    width: 100%;
    height: 100%;
    border: none;
}

/* CTA canal */

.videos-channel-cta {
    margin-top: 55px;
    display: flex;
    justify-content: center;
}

.videos-channel-btn {
    width: 450px;
    max-width: 100%;
    padding: 18px 24px;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;

    text-decoration: none;
    border-radius: 40px;

    background: #D4B46A;
    color: #101216;

    font-weight: 700;
    font-size: 17px;
    letter-spacing: .3px;

    transition: all .35s ease;
}

.videos-channel-btn i {
    font-size: 20px;
}

.videos-channel-btn:hover {
    transform: scale(1.04);
    background: #E3C784;

    box-shadow:
        0 0 25px rgba(212, 180, 106, .25);
}

/* ====================================
   SECTION TRATAMENTOS
==================================== */

.psychology-services {
    position: relative;
    padding: 120px 0;
    overflow: hidden;

    /* mesma cor da seção anterior */
    background: #101216;

}

.psychology-services::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;

    background:
        radial-gradient(circle at left center,
            rgba(212, 176, 92, 0.08) 0,
            rgba(212, 176, 92, 0.05) 2px,
            transparent 2px,
            transparent 24px);

    background-size: 24px 24px;
    opacity: .35;

    mask-image: radial-gradient(circle at left center,
            rgba(0, 0, 0, 1),
            transparent 70%);
}

.psychology-services::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 900px;
    height: 900px;
    transform: translate(-50%, -50%);
    pointer-events: none;

    background: radial-gradient(circle,
            rgba(212, 176, 92, 0.08) 0%,
            transparent 70%);
}

.psychology-services .container {
    position: relative;
    z-index: 2;
}


/* ondas */

.services-wave-left,
.services-wave-right {
    position: absolute;
    width: 450px;
    height: 450px;
    opacity: .07;
    pointer-events: none;
    background-image:
        repeating-radial-gradient(circle at center,
            transparent 0,
            transparent 10px,
            rgba(255, 255, 255, .22) 11px,
            transparent 12px);
}

.services-wave-left {
    top: 80px;
    left: -250px;
}

.services-wave-right {
    right: -220px;
    bottom: 60px;
}


/* glow */

.services-glow {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top center,
            rgba(255, 255, 255, .04),
            transparent 45%);
}


/* header */

.services-header {
    text-align: center;
    max-width: 820px;
    margin: auto;
    margin-bottom: 70px;
    position: relative;
    z-index: 2;
}

.services-header span {
    color: #d9b46a;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 2px;
}

.services-header span i {
    margin-right: 8px;
}

.services-header h2 {
    color: #fff;
    font-size: 38px;
    line-height: 1.15;
    margin-top: 25px;
}

.services-header h2 span{
color: #d9b46a;
font-size: 38px;
}

.services-header strong {
    color: #d9b46a;
    font-weight: 500;
}

.title-line {
    width: 220px;
    height: 2px;
    margin: 28px auto;
    background:
        linear-gradient(90deg,
            transparent,
            #d9b46a,
            transparent);
}

.services-header p {
    color: rgba(255, 255, 255, .75);
    font-size: 20px;
    line-height: 1.7;
}


/* grid */

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
    margin-top: 40px;
    position: relative;
    z-index: 2;
}


/* cards */

.service-box {
    background: #ffffff;
    border-radius: 26px;
    padding: 35px;
    display: flex;
    gap: 22px;
    align-items: flex-start;
    transition: .35s;
    box-shadow:
        0 8px 30px rgba(0, 0, 0, .12);
}

.service-box:hover {
    transform: translateY(-8px);
}


.icon-circle {
    width: 65px;
    height: 65px;
    border-radius: 50%;
    flex-shrink: 0;

    border: 1px solid #ecd9a7;

    display: flex;
    align-items: center;
    justify-content: center;
}

.icon-circle i {
    color: #c79b41;
    font-size: 26px;
}


.service-content h3 {
    font-size: 23px;
    color: #0d1c35;
    margin-bottom: 12px;
}

.service-content span {
    display: block;
    width: 50px;
    height: 2px;
    background: #d9b46a;
    margin-bottom: 18px;
}

.service-content p {
    color: #666;
    line-height: 1.7;
}


/* botão */

.services-btn {
    margin: 60px auto 0;
    width: fit-content;
    display: flex;
    align-items: center;
    gap: 14px;

    padding: 20px 42px;
    border-radius: 50px;

    background: linear-gradient(90deg,
            #c89b3c,
            #e8c76d);

    color: #111;
    text-decoration: none;
    font-weight: 700;

    transition: .3s;
}

.services-btn:hover {
    transform: scale(1.05);
    box-shadow:
        0 12px 30px rgba(217, 180, 106, .25);
}


/* RESPONSIVO */

@media(max-width:992px) {

    .services-grid {
        grid-template-columns: 1fr;
    }

    .services-header h2 {
        font-size: 42px;
    }

        .services-header h2 span{
            font-size: 42px;
        }


}

@media(max-width:768px) {

    .psychology-services {
        padding: 90px 0;
    }

    .services-header h2 {
        font-size: 34px;
    }

    .services-header h2 span {
        font-size: 34px;
    }

    .services-header p {
        font-size: 17px;
    }

    .service-box {
        flex-direction: column;
    }
}

/* ===================================
   SOBRE O PSICÓLOGO
=================================== */

.about-psychologist {
    position: relative;
    padding: 120px 0;
    background: #111111;
    overflow: hidden;
}

.about-glow {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top left,
            rgba(177, 138, 74, .18),
            transparent 40%);
    pointer-events: none;
}

/* layout */

.about-wrapper {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 70px;
    align-items: center;
    margin-bottom: 70px;
}

/* texto */

.about-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 22px;
    border: 1px solid rgba(177, 138, 74, .35);
    border-radius: 50px;
    color: #b18a4a;
    font-size: .85rem;
    letter-spacing: .12em;
    margin-bottom: 28px;
}

.about-left h2 {
    color: #f8f6f2;
    font-size: 4rem;
    line-height: 1.1;
    font-weight: 300;
    margin-bottom: 25px;
}

.about-left h2 strong {
    display: block;
    color: #b18a4a;
    font-weight: 600;
}

.about-line {
    width: 180px;
    height: 1px;
    background: linear-gradient(to right,
            #b18a4a,
            transparent);
    margin-bottom: 35px;
}

.gv-services-container .about-line{
    height: 2px;
    background: #b18a4a;
}

.about-left p {
    color: #d6d0c5;
    font-size: 1.1rem;
    line-height: 1.9;
    margin-bottom: 24px;
}

.about-left strong {
    color: #b18a4a;
}

/* quote */

.about-quote {
    margin-top: 40px;
    padding-left: 30px;
    border-left: 2px solid #b18a4a;
    display: flex;
    gap: 18px;
    align-items: flex-start;
}

.about-quote i {
    color: #b18a4a;
    font-size: 2rem;
    margin-top: 6px;
}

.about-quote p {
    margin: 0;
    font-style: italic;
}

/* imagem */

.about-image img {
    width: 100%;
    border-radius: 28px;
    border: 1px solid rgba(177, 138, 74, .25);
    display: block;
}

/* benefícios */

.about-features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border: 1px solid rgba(177, 138, 74, .25);
    border-radius: 28px;
    overflow: hidden;
    background: rgba(255, 255, 255, .02);
    backdrop-filter: blur(20px);
}

.feature-item {
    padding: 40px;
    border-right: 1px solid rgba(177, 138, 74, .15);
}

.feature-item:last-child {
    border-right: none;
}

.feature-item i {
    color: #b18a4a;
    font-size: 2rem;
    margin-bottom: 18px;
}

.feature-item h3 {
    color: #f8f6f2;
    font-size: 1.15rem;
    margin-bottom: 12px;
}

.feature-item p {
    color: #d6d0c5;
    line-height: 1.7;
}

/* botão */

.about-cta {
    text-align: center;
    margin-top: 45px;
}

.about-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 20px 48px;
    border-radius: 60px;
    background: #b18a4a;
    color: #111;
    font-weight: 700;
    text-decoration: none;
    transition: .3s;
}

.about-btn:hover {
    transform: scale(.96);
}

/* =========================================
   CTA PSICÓLOGO PREMIUM
========================================= */

.mental-cta {
    position: relative;
    padding: 120px 20px;
    background: #f7f4ef;
    overflow: hidden;
    z-index: 1;
}

/* linhas douradas */
.mental-lines {
    position: absolute;
    inset: 0;
    z-index: 1;
    overflow: hidden;
}

/* linhas diagonais */
.mental-lines::before {
    content: "";

    position: absolute;
    inset: -200px;

    background-image:
        repeating-linear-gradient(125deg,
            transparent 0px,
            transparent 60px,
            rgba(201, 157, 74, .08) 61px,
            rgba(201, 157, 74, .08) 62px,
            transparent 63px);

    animation: linesMove 18s linear infinite;
}

.mental-lines::after {
    content: "";

    position: absolute;
    inset: 0;

    background-image:
        repeating-linear-gradient(0deg,
            transparent 0px,
            transparent 120px,
            rgba(201, 157, 74, .04) 121px,
            transparent 122px);
}

@keyframes linesMove {

    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(120px);
    }

}

/* card */
.mental-cta-card {
    position: relative;
    z-index: 3;

    max-width: 1100px;
    margin: auto;

    background:
        linear-gradient(145deg,
            #0d0d0d,
            #161616,
            #0a0a0a);

    border-radius: 40px;

    padding: 95px 70px;

    text-align: center;

    border: 1px solid rgba(201, 157, 74, .18);

    overflow: hidden;

    box-shadow:
        0 35px 80px rgba(0, 0, 0, .12),
        inset 0 0 0 1px rgba(255, 255, 255, .02);
}

/* glow dourado */
.mental-cta-card::before {
    content: "";

    position: absolute;

    width: 550px;
    height: 550px;

    background:
        radial-gradient(circle,
            rgba(201, 157, 74, .12),
            transparent 70%);

    top: -250px;
    right: -180px;

    z-index: -1;
}

/* =========================================
   EFEITO SOL NASCENDO
========================================= */

.mental-sun-glow {
    position: absolute;

    width: 900px;
    height: 300px;

    left: 50%;
    bottom: -180px;

    transform: translateX(-50%);

    background:
        radial-gradient(ellipse at center,
            rgba(201, 157, 74, .45) 0%,
            rgba(201, 157, 74, .18) 35%,
            rgba(201, 157, 74, .08) 55%,
            transparent 75%);

    filter: blur(40px);

    z-index: -1;
}

/* mini topo */
.mental-mini-title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 22px;

    margin-bottom: 38px;
}

.mental-mini-title span {
    width: 80px;
    height: 1px;

    background:
        linear-gradient(90deg,
            transparent,
            rgba(201, 157, 74, .8),
            transparent);
}

.mental-mini-title div {
    display: flex;
    align-items: center;
    gap: 12px;

    color: #c99d4a;

    font-size: 14px;
    letter-spacing: 3px;
    font-weight: 600;
}

.mental-mini-title i {
    font-size: 18px;
}

/* título */
.mental-cta-card h2 {
    color: #f4f4f4;

    font-size: 38px;
    line-height: 1.08;

    max-width: 920px;
    margin: auto;

    font-weight: 300;

    position: relative;
}

/* dourado */
.mental-cta-card h2 strong {
    color: #c99d4a;
    font-weight: 500;
}

/* brilho abaixo do título */
.mental-cta-card h2::after {
    content: "";

    position: absolute;

    width: 340px;
    height: 120px;

    left: 50%;
    bottom: -55px;

    transform: translateX(-50%);

    background:
        radial-gradient(ellipse at center,
            rgba(201, 157, 74, .45),
            rgba(201, 157, 74, .18),
            transparent 75%);

    filter: blur(22px);

    z-index: -1;
}

/* divisor */
.mental-divider {
    width: 180px;
    height: 1px;

    margin: 55px auto 40px;

    background:
        linear-gradient(90deg,
            transparent,
            rgba(201, 157, 74, .9),
            transparent);

    position: relative;
}

.mental-divider::after {
    content: "";

    position: absolute;

    width: 10px;
    height: 10px;

    border-radius: 50%;

    background: #c99d4a;

    left: 50%;
    top: 50%;

    transform: translate(-50%, -50%);

    box-shadow:
        0 0 25px rgba(201, 157, 74, .9);
}

/* texto */
.mental-cta-card p {
    color: rgba(255, 255, 255, .74);

    font-size: 18px;
    line-height: 1.9;

    max-width: 760px;
    margin: auto auto 55px;
}

/* botão */
.mental-cta-btn {
    position: relative;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 18px;

    padding: 22px 22px;

    border-radius: 80px;

    background:
        linear-gradient(135deg,
            #d8b36b,
            #c99d4a);

    color: #111;
    text-decoration: none;

    font-size: 17px;
    font-weight: 700;
    letter-spacing: .5px;

    overflow: hidden;

    transition: .35s ease;

    box-shadow:
        0 10px 30px rgba(201, 157, 74, .28);
}

.mental-cta-btn span {
    width: 42px;
    height: 42px;

    border-radius: 50%;

    background: rgba(0, 0, 0, .08);

    display: flex;
    align-items: center;
    justify-content: center;

    transition: .35s ease;
}

.mental-cta-btn:hover {
    transform: translateY(-6px) scale(1.03);

    box-shadow:
        0 18px 45px rgba(201, 157, 74, .4);
}

.mental-cta-btn:hover span {
    transform: translateX(5px);
}

/* iluminação passando */
.mental-cta-btn::before {
    content: "";

    position: absolute;

    width: 140px;
    height: 220%;

    background:
        linear-gradient(90deg,
            transparent,
            rgba(255, 255, 255, .5),
            transparent);

    top: -50%;
    left: -160px;

    transform: rotate(20deg);

    transition: .7s ease;
}

.mental-cta-btn:hover::before {
    left: 130%;
}

/* =========================================
   BLOG + CONTATO
========================================= */

.psychology-blog-contact{
    position: relative;
    padding: 140px 20px;
    background: #0f0f10;
    overflow: hidden;
}

/* linhas douradas */
.blog-contact-lines{
    position: absolute;
    inset: 0;
    z-index: 1;
    opacity: .55;
}

.blog-contact-lines::before{
    content: "";

    position: absolute;
    inset: -300px;

    background-image:
    repeating-linear-gradient(
        125deg,
        transparent 0px,
        transparent 75px,
        rgba(201,157,74,.07) 76px,
        transparent 77px
    );

    animation: lineMove 18s linear infinite;
}

@keyframes lineMove{

    from{
        transform: translateX(0);
    }

    to{
        transform: translateX(120px);
    }

}

/* glow */
.blog-contact-glow{
    position: absolute;

    width: 900px;
    height: 500px;

    top: -250px;
    left: 50%;

    transform: translateX(-50%);

    background:
    radial-gradient(
        circle,
        rgba(201,157,74,.12),
        transparent 70%
    );

    filter: blur(40px);

    z-index: 1;
}

/* container */
.psychology-blog-contact .container{
    position: relative;
    z-index: 3;
}

/* =========================================
   TOPO
========================================= */

.section-top{
    text-align: center;
    margin-bottom: 70px;
}

.section-top span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #c99d4a;

    font-size: 13px;
    letter-spacing: 3px;
    font-weight: 600;

    margin-bottom: 20px;
}

.section-top h2{
    color: #f5f5f5;

    font-size: 58px;
    line-height: 1.1;

    max-width: 850px;
    margin: auto auto 25px;

    font-weight: 300;
}

.section-top h2 strong{
    color: #c99d4a;
    font-weight: 500;
}

.section-top p{
    color: rgba(255,255,255,.68);

    font-size: 18px;
    line-height: 1.8;

    max-width: 720px;
    margin: auto;
}

/* =========================================
   POSTS
========================================= */

.blog-grid{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 30px;
}

.blog-card{
    position: relative;
    height: 500px;

    border-radius: 30px;
    overflow: hidden;

    text-decoration: none;

    border: 1px solid rgba(201,157,74,.12);

    transition: .45s ease;
}

.blog-card:hover{
    transform: translateY(-12px);
}

.blog-image,
.blog-image img{
    width: 100%;
    height: 100%;
}

.blog-image img{
    object-fit: cover;
    transition: .6s ease;
}

.blog-card:hover img{
    transform: scale(1.08);
}

.blog-overlay{
    position: absolute;
    inset: 0;

    background:
    linear-gradient(
        to top,
        rgba(0,0,0,.92),
        rgba(0,0,0,.2)
    );
}

.blog-content{
    position: absolute;
    left: 35px;
    right: 35px;
    bottom: 35px;
}

.blog-category{
    display: inline-flex;

    background: rgba(201,157,74,.12);

    border: 1px solid rgba(201,157,74,.22);

    color: #d4ad61;

    padding: 10px 16px;
    border-radius: 50px;

    font-size: 13px;
    margin-bottom: 18px;
}

.blog-content h3{
    color: #fff;

    font-size: 28px;
    line-height: 1.3;
    font-weight: 400;
}

/* botão */
.blog-btn-wrap{
    text-align: center;
    margin-top: 55px;
}

.view-posts-btn{
    display: inline-flex;
    align-items: center;
    gap: 16px;

    background:
    linear-gradient(
        135deg,
        #d7b069,
        #c99d4a
    );

    color: #111;
    text-decoration: none;

    padding: 18px 34px;

    border-radius: 70px;

    font-weight: 700;
    letter-spacing: .5px;

    transition: .35s ease;
}

.view-posts-btn:hover{
    transform: translateY(-5px);
}

.view-posts-btn span{
    width: 38px;
    height: 38px;

    border-radius: 50%;
    background: rgba(0,0,0,.08);

    display: flex;
    align-items: center;
    justify-content: center;
}

/* =========================================
   CONTATO
========================================= */

.contact-section{
    margin-top: 140px;

    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 70px;
    align-items: center;
}

/* mapa */
.contact-map{
    position: relative;
    border-radius: 35px;
    overflow: hidden;

    border: 1px solid rgba(201,157,74,.12);

    height: 600px;
}

.contact-map iframe{
    width: 100%;
    height: 100%;
    border: none;

    filter: grayscale(.2);
}

/* infos */
.contact-tag{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #c99d4a;

    letter-spacing: 3px;
    font-size: 13px;
    font-weight: 600;

    margin-bottom: 25px;
}

.contact-info h2{
    color: #f5f5f5;

    font-size: 52px;
    line-height: 1.1;

    margin-bottom: 28px;

    font-weight: 300;
}

.contact-info h2 strong{
    color: #c99d4a;
}

.contact-info p{
    color: rgba(255,255,255,.68);

    font-size: 18px;
    line-height: 1.9;

    margin-bottom: 45px;
}

/* itens */
.contact-items{
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.contact-item{
    display: flex;
    align-items: flex-start;
    gap: 18px;
}

.contact-item i{
    width: 58px;
    height: 58px;

    border-radius: 18px;

    display: flex;
    align-items: center;
    justify-content: center;

    background:
    linear-gradient(
        135deg,
        rgba(201,157,74,.18),
        rgba(201,157,74,.08)
    );

    color: #d4ad61;
    font-size: 20px;
}

.contact-item strong{
    display: block;

    color: #fff;
    margin-bottom: 6px;

    font-size: 18px;
}

.contact-item span{
    color: rgba(255,255,255,.68);
    line-height: 1.7;
}

/* redes */
.contact-socials{
    display: flex;
    gap: 15px;

    margin-top: 45px;
}

.contact-socials a{
    width: 56px;
    height: 56px;

    border-radius: 18px;

    display: flex;
    align-items: center;
    justify-content: center;

    text-decoration: none;

    color: #d4ad61;
    font-size: 20px;

    border: 1px solid rgba(201,157,74,.18);

    background:
    linear-gradient(
        145deg,
        rgba(255,255,255,.03),
        rgba(255,255,255,.01)
    );

    transition: .35s ease;
}

.contact-socials a:hover{
    transform: translateY(-5px);

    background:
    linear-gradient(
        135deg,
        #d7b069,
        #c99d4a
    );

    color: #111;
}

/* =========================================
   FOOTER
========================================= */

.main-footer{
    position: relative;
    background: #101216;
    overflow: hidden;
    padding-top: 0;
}

/* divisor superior */
.footer-divider{
    width: 100%;
    height: 1px;

    background:
    linear-gradient(
        90deg,
        transparent,
        rgba(212,180,106,.4),
        transparent
    );

    margin-bottom: 90px;
}

/* linhas douradas */
.footer-lines{
    position: absolute;
    inset: 0;
    opacity: .45;
    pointer-events: none;
}

.footer-lines::before{
    content: "";

    position: absolute;
    inset: -200px;

    background-image:
    repeating-linear-gradient(
        130deg,
        transparent 0px,
        transparent 85px,
        rgba(212,180,106,.05) 86px,
        transparent 87px
    );
}

/* grid */
.footer-grid{
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr .9fr;
    gap: 70px;

    padding-bottom: 90px;

    position: relative;
    z-index: 2;
}

/* colunas */
.footer-column h3{
    color: #fff;

    font-size: 22px;
    font-weight: 500;

    margin-bottom: 30px;

    position: relative;
}

.footer-column h3::after{
    content: "";

    width: 45px;
    height: 2px;

    background: #D4B46A;

    position: absolute;
    left: 0;
    bottom: -12px;
}

/* coluna logo */
.footer-about img{
    width: 270px;
    margin-bottom: 28px;
}

.footer-about p{
    color: rgba(255,255,255,.68);

    line-height: 1.9;
    font-size: 16px;
}

/* listas */
.footer-column ul{
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-column ul li{
    display: flex;
    align-items: flex-start;
    gap: 14px;

    color: rgba(255,255,255,.72);

    margin-bottom: 18px;

    line-height: 1.7;
}

.footer-column ul li i{
    color: #D4B46A;
    margin-top: 3px;
}

/* institucional */
.footer-links{
    margin-top: 35px;
}

.footer-links h4{
    color: #fff;

    font-size: 17px;
    font-weight: 500;

    margin-bottom: 18px;
}

.footer-links a{
    display: block;

    text-decoration: none;

    color: rgba(255,255,255,.68);

    margin-bottom: 14px;

    transition: .3s;
}

.footer-links a:hover{
    color: #D4B46A;
    transform: translateX(4px);
}

/* categorias */
.footer-categories{
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.footer-categories a{
    text-decoration: none;

    padding: 12px 18px;

    border-radius: 50px;

    color: rgba(255,255,255,.78);

    border: 1px solid rgba(212,180,106,.15);

    background:
    linear-gradient(
        145deg,
        rgba(255,255,255,.03),
        rgba(255,255,255,.01)
    );

    transition: .35s ease;
}

.footer-categories a:hover{
    background: #D4B46A;
    color: #101216;

    transform: translateY(-4px);
}

/* redes */
.footer-social-text{
    color: rgba(255,255,255,.68);

    line-height: 1.8;

    margin-bottom: 28px;
}

.footer-socials{
    display: flex;
    gap: 14px;
}

.footer-socials a{
    width: 48px;
    height: 48px;

    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    text-decoration: none;

    border: 1.5px solid #D4B46A;

    color: #D4B46A;

    transition: all .35s ease;
}

.footer-socials a:hover{
    transform: scale(1.12);

    background: #D4B46A;
    color: #101216;

    box-shadow: 0 0 18px rgba(212,180,106,.35);
}

/* bottom */
.footer-bottom{
    border-top: 1px solid rgba(255,255,255,.06);

    padding: 26px 0;

    position: relative;
    z-index: 2;
}

.footer-bottom p{
    color: rgba(255,255,255,.55);

    text-align: center;

    font-size: 15px;
    letter-spacing: .3px;
}

/* =========================================
   RESPONSIVO
========================================= */

@media(max-width: 1100px){

    .footer-grid{
        grid-template-columns: 1fr 1fr;
        gap: 60px;
    }

}

@media(max-width: 768px){

    .main-footer{
        padding-top: 0;
    }

    .footer-divider{
        margin-bottom: 70px;
    }

    .footer-grid{
        grid-template-columns: 1fr;
        gap: 55px;

        padding-bottom: 70px;
    }

    .footer-about img{
        width: 230px;
    }

    .footer-column h3{
        font-size: 20px;
    }

    .footer-categories{
        gap: 12px;
    }

    .footer-categories a{
        font-size: 14px;
        padding: 10px 15px;
    }

    .footer-bottom p{
        font-size: 14px;
        line-height: 1.7;
    }

}

/* =========================================
   RESPONSIVO
========================================= */

@media(max-width: 992px){

    .blog-grid{
        grid-template-columns: 1fr;
    }

    .contact-section{
        grid-template-columns: 1fr;
    }

    .section-top h2,
    .contact-info h2{
        font-size: 40px;
    }

}

@media(max-width: 768px){

    .psychology-blog-contact{
        padding: 90px 20px;
    }

    .blog-card{
        height: 420px;
    }

    .blog-content{
        left: 24px;
        right: 24px;
        bottom: 24px;
    }

    .blog-content h3{
        font-size: 23px;
    }

    .section-top h2,
    .contact-info h2{
        font-size: 32px;
    }

    .contact-map{
        height: 420px;
    }

        .contact-info{
        width: 100%;
    }

    .contact-info p{
        font-size: 15px;
        line-height: 1.8;
    }

    .contact-items{
        gap: 18px;
    }

    .contact-item{
        align-items: flex-start;
        gap: 14px;
    }

    .contact-item i{
        min-width: 18px;
        margin-top: 4px;
    }

    .contact-item div{
        width: 100%;
    }

    .contact-item span{
        display: block;
        line-height: 1.7;
        word-break: break-word;
    }

    .contact-socials{
        flex-wrap: wrap;
        gap: 14px;
        justify-content: flex-start;
    }

    .contact-socials a{
        width: 48px;
        height: 48px;
        flex-shrink: 0;
    }

    .contact-map iframe{
        width: 100%;
        height: 100%;
        border: 0;
    }

}



/* responsivo */
@media(max-width: 992px) {

    .mental-cta {
        padding: 2px;
    }

    .mental-cta-card {
        padding: 70px 35px;
    }

    .mental-cta-card h2 {
        font-size: 38px;
    }

    .mental-cta-card p {
        font-size: 18px;
    }

}

@media(max-width: 768px) {

    .mental-cta-card {
        padding: 55px 24px;
        border-radius: 28px;
    }

    .mental-mini-title {
        gap: 12px;
    }

    .mental-mini-title span {
        width: 35px;
    }

    .mental-mini-title div {
        font-size: 11px;
        letter-spacing: 2px;
        text-align: center;
    }

    .mental-cta-card h2 {
        font-size: 28px;
    }

    .mental-cta-card h2::after {
        width: 220px;
    }

    .mental-cta-card p {
        font-size: 16px;
        line-height: 1.7;
    }

    .mental-cta-btn {
        width: 100%;
        padding: 12px 12px;
        font-size: 12px;
    }

}

/* responsivo */

@media (max-width:991px) {

    .about-wrapper {
        grid-template-columns: 1fr;
    }

    .about-left h2 {
        font-size: 3rem;
    }

    .about-features {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width:768px) {

    .about-psychologist {
        padding: 80px 0;
    }

    .about-left h2 {
        font-size: 2.4rem;
    }

    .about-features {
        grid-template-columns: 1fr;
    }

    .feature-item {
        border-right: none;
        border-bottom: 1px solid rgba(177, 138, 74, .15);
    }

    .feature-item:last-child {
        border-bottom: none;
    }

    .about-btn {
        width: 100%;
        padding: 18px;
    }
}



/* ================= RESPONSIVO ================= */

@media (max-width: 991px) {

    .videos-grid {
        grid-template-columns: 1fr;
        gap: 28px;
        max-width: 700px;
        margin: auto;
    }

    .videos-header h2 {
        font-size: 32px;
    }

    .videos-header p {
        font-size: 17px;
    }

    .video-title {
        font-size: 17px;
    }

    .mode-layout {
        grid-template-columns: 1fr;
        padding: 40px 20px 40px 20px;
    }

    .mode-image {
        height: 400px;
    }

    .mode-card {
        flex: none;
    }

    .therapy-benefits-box {
        grid-template-columns: 1fr;
        gap: 35px;
        padding: 35px;
    }

    .benefits-left h3 {
        font-size: 30px;
    }
}

@media (max-width: 600px) {

    .psychology-videos {
        padding: 60px 0;
    }

    .videos-header {
        margin-bottom: 40px;
    }

    .videos-header h2 {
        font-size: 28px;
        line-height: 1.1;
    }

    .videos-header p {
        font-size: 15px;
        line-height: 1.7;
    }

    .video-card {
        border-radius: 20px;
    }

    .video-thumb {
        border-radius: 18px 18px 0 0;
    }

    .play-button {
        width: 68px;
        height: 68px;
        font-size: 22px;
    }

    .video-title {
        padding: 18px;
        font-size: 16px;
        line-height: 1.5;
    }

    .videos-channel-btn {
        width: 100%;
        font-size: 15px;
        padding: 16px;
    }

    .mode-image {
        height: 260px;
    }

    .therapy-benefits-box {
        padding: 28px 22px;
        border-radius: 24px;
    }

    .benefits-left h3 {
        font-size: 26px;
    }

    .benefits-left p {
        font-size: 16px;
    }

    .benefit-item {
        padding: 18px;
        gap: 14px;
    }

    .benefit-item span {
        font-size: 15px;
    }

    .benefit-item i {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }
}

/* animação */

@keyframes fade {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

/* RESPONSIVO */

@media(max-width:991px) {

    .therapy-process {
        padding: 80px 0;
    }

    .process-top {
        flex-direction: column;
        text-align: center;
        gap: 40px;
    }

    .process-heading h2 {
        font-size: 44px;
    }

    .process-description {
        border-left: none;
        padding-left: 0;
        max-width: 100%;
    }

    .process-description p {
        font-size: 18px;
    }

    .process-cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 60px 20px;
    }

    .process-line {
        display: none;
    }

    .audience-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .audience-header h2 {
        font-size: 36px;
    }

    .audience-header p {
        font-size: 18px;
    }
}

@media(max-width:600px) {

    .process-heading h2 {
        font-size: 34px;
    }

    .process-cards {
        grid-template-columns: 1fr;
    }

    .process-btn {
        width: 100%;
    }
}

/* ================= RESPONSIVO ================= */

@media (max-width: 1260px) {
    .process-cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 60px 26px;
    }

    .process-line {
        display: none;
    }

    .process-heading h2 {
        font-size: 52px;
    }
}

/* NOTEBOOK */
@media (max-width: 1200px) {

    .logo {
        flex-basis: 260px;
    }

    .custom-logo {
        width: 250px;
    }

    .main-nav ul {
        gap: 22px;
    }

    .main-nav a {
        font-size: 15px;
    }

    .social-icons {
        flex-basis: 150px;
        gap: 10px;
    }

    .social-icons a {
        width: 38px;
        height: 38px;
        font-size: 16px;
    }

    .hero-content h1 {
        font-size: 44px;
    }

    .hero-content p {
        font-size: 21px;
    }
}


/* TABLET + MOBILE */
@media (max-width: 1400px) {

    /* HEADER */

    .logo {
        flex: 1;
        flex-basis: auto;
    }

    .custom-logo {
        width: 320px;
    }

    .social-icons {
        display: none;
    }

    .menu-toggle {
        display: block;
        background: none;
        border: none;
        font-size: 28px;
        cursor: pointer;
        z-index: 10001;
    }

    /* MENU MOBILE */

    .main-nav {
        display: flex;
        flex-direction: column;
        align-items: center;

        position: fixed;
        top: 95px;
        left: 0;
        width: 100%;

        background: #101216;
        padding: 30px 0;

        opacity: 0;
        visibility: hidden;
        transform: translateY(-20px);

        transition: all .3s ease;
    }

    .main-nav.active {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .main-nav ul {
        flex-direction: column;
        gap: 24px;
        text-align: center;
    }

    .main-nav a {
        font-size: 20px;
        color: #F5F3EF;
    }

    /* extras mobile */

    .mobile-extra {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 28px;
        margin-top: 35px;
    }

    .mobile-social {
        display: flex;
        gap: 14px;
    }

    .mobile-social a {
        width: 42px;
        height: 42px;
        border-radius: 50%;

        display: flex;
        align-items: center;
        justify-content: center;

        text-decoration: none;
        color: #D4B46A;
        border: 1.5px solid #D4B46A;

        transition: all .3s ease;
    }

    .mobile-social a:hover {
        background: #D4B46A;
        color: #101216;
        transform: scale(1.08);
    }

    .mobile-contact-btn {
        width: 240px;
        padding: 16px;

        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;

        text-decoration: none;
        font-weight: 700;
        font-size: 16px;

        color: #101216;
        background: #D4B46A;
        border-radius: 40px;

        transition: all .3s ease;
    }

    .mobile-contact-btn:hover {
        background: #E3C784;
        transform: scale(1.03);
    }

    /* HERO */

    .hero {
        margin-top: 50px;
        min-height: 100vh;
        height: auto;
        align-items: flex-start;
        /* em vez de center */
        background-position: 70% center;
        background-size: cover;
    }

    .hero-container {
        flex-direction: column;
        text-align: center;
        padding-top: 0;
    }

    .hero-content {
        padding-left: 0;
        margin-top: 0;
        transform: translateY(-220px);
    }

    .hero-content h1 {
        font-size: 42px;
    }

    .hero-content p {
        font-size: 18px;
    }
}

@media(max-width:767px) {

    .process-cards {
        grid-template-columns: 1fr;
        gap: 50px;
    }

    .process-heading h2 {
        font-size: 36px;
    }

    .process-btn {
        width: 100%;
    }

    .audience-grid {
        grid-template-columns: 1fr;
    }

    .audience-header h2 {
        font-size: 34px;
    }
}


/* CELULAR PEQUENO */
@media (max-width: 600px) {

    .container {
        padding: 0 20px;
    }

    .custom-logo {
        width: 320px;
    }

    .hero {
        min-height: 100vh;
        height: 100vh;
        padding-bottom: 0;
        background-position: center top;

    }

    .hero-content {
        transform: translateY(-180px);
    }

    .hero-content h1 {
        margin-top: 150px;
        font-size: 34px;
        line-height: 1;
        letter-spacing: -2px;
    }

    .hero-content p {
        font-size: 17px;
    }

    .hero-btn {
        width: 100%;
        padding: 8px;
    }
}

/* =========================================
   RESPONSIVO — FORMAS DE ATENDIMENTO
========================================= */

/* TABLET */
@media (max-width: 991px) {

    /* container interno */
    .modes-box {
        padding: 45px 30px;
        border-radius: 28px;
    }

    /* título */
    .modes-header h2 {
        font-size: 32px;
        line-height: 1.1;
    }

    .modes-header p {
        font-size: 17px;
    }

    /* BOTÕES */
    .mode-tabs {
        gap: 10px;
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: 6px;

        scrollbar-width: none;
    }

    .mode-tabs::-webkit-scrollbar {
        display: none;
    }

    .mode-btn {
        flex: 1;
        min-width: 0;
        white-space: nowrap;

        padding: 14px 16px;
        font-size: 15px;
    }

    /* CARD + IMAGEM */
    .mode-content {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .mode-image img {
        width: 100%;
        height: 380px;
        object-fit: cover;
    }
}


/* MOBILE */
@media (max-width: 600px) {

    .service-modes {
        padding: 60px 0;
    }

    .modes-box {
        padding: 25px 18px;
        border-radius: 22px;
    }

    /* subtítulo */
    .modes-header span {
        font-size: 12px;
        letter-spacing: 1.5px;
    }

    /* título principal */
    .modes-header h2 {
        font-size: 28px;
        line-height: 1.1;
        margin-bottom: 15px;
    }

    .modes-header p {
        font-size: 15px;
        line-height: 1.6;
    }

    /* BOTÕES MENORES */
    .mode-tabs {
        gap: 8px;
        margin-top: 30px;
        margin-bottom: 30px;
    }

    .mode-btn {
        padding: 12px 14px;
        font-size: 13px;
        border-radius: 14px;
        gap: 8px;
    }

    /* CARD */
    .mode-card {
        padding: 24px 18px;
        border-radius: 20px;
    }

    .tab-panel h3 {
        font-size: 22px;
    }

    .tab-panel p {
        font-size: 15px;
        line-height: 1.7;
    }

    .mode-divider {
        width: 60px;
        margin: 20px 0;
    }

    .tab-panel li {
        font-size: 15px;
        padding-left: 24px;
        margin-bottom: 14px;
    }

    /* imagem menor abaixo */
    .mode-image img {
        height: 250px;
        border-radius: 18px;
    }
}


/* CELULARES MUITO PEQUENOS */
@media (max-width: 380px) {

    .videos-header h2 {
        font-size: 24px;
    }

    .play-button {
        width: 60px;
        height: 60px;
        font-size: 20px;
    }

    .video-title {
        font-size: 15px;
    }

    .videos-channel-btn {
        font-size: 14px;
    }

    .mode-btn {
        font-size: 12px;
        padding: 10px 12px;
    }

    .modes-header h2 {
        font-size: 24px;
    }

    .tab-panel h3 {
        font-size: 20px;
    }
}

/* ================= RESPONSIVO - FORMAS DE ATENDIMENTO ================= */

@media (max-width: 992px) {

    /* coluna em vez de lado a lado */
    .mode-layout {
        flex-direction: column;
        gap: 35px;
    }

    /* conteúdo ocupa tudo */
    .mode-left {
        width: 100%;
    }

    /* imagem também */
    .mode-image {
        width: 100%;
        max-width: 450px;
        margin: 0 auto;
    }

    .mode-image img {
        width: 100%;
        height: auto;
        display: block;
    }

    /* reduz padding do card */
    .mode-card {
        padding: 30px 25px;
    }

    /* botões um embaixo do outro */
    .mode-tabs {
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: 100%;
    }

    .mode-btn {
        width: 100%;
        justify-content: center;
    }

    /* texto centralizado fica melhor */
    .modes-header {
        text-align: center;
    }
}


/* celulares pequenos */
@media (max-width: 576px) {

    .mode-card {
        padding: 22px 18px;
    }

    .modes-header h2 {
        font-size: 1.9rem;
        line-height: 1.3;
    }

    .modes-header p {
        font-size: .95rem;
    }

    .tab-panel h3 {
        font-size: 1.2rem;
    }

    .tab-panel ul li {
        font-size: .95rem;
    }

}

/* animações */

.process-heading,
.process-description {
    animation: fadeUp .8s ease forwards;
}

.process-card {
    opacity: 0;
    transform: translateY(35px);

    animation:
        fadeOpacity .8s ease forwards,
        fadeMove .8s ease forwards;
}

.process-card:nth-child(2) {
    animation-delay: .15s;
}

.process-card:nth-child(3) {
    animation-delay: .30s;
}

.process-card:nth-child(4) {
    animation-delay: .45s;
}

.process-card:nth-child(5) {
    animation-delay: .60s;
}

.process-btn-wrap {
    animation: fadeUp .8s ease .7s forwards;
    opacity: 0;
}

@keyframes fadeOpacity {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeMove {
    from {
        transform: translateY(35px);
    }

    to {
        transform: translateY(0);
    }
}

/* =====================================
   SCROLL REVEAL REUTILIZÁVEL
===================================== */

.reveal {
    opacity: 0;
    transform: translateY(50px);
    transition:
        opacity .9s ease,
        transform .9s cubic-bezier(.22, 1, .36, 1);
    will-change: transform, opacity;
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

/* variantes opcionais */

.reveal-left {
    transform: translateX(-70px);
}

.reveal-left.active {
    transform: translateX(0);
}

.reveal-right {
    transform: translateX(70px);
}

.reveal-right.active {
    transform: translateX(0);
}

.reveal-scale {
    transform: scale(.94);
}

.reveal-scale.active {
    transform: scale(1);
}



/* =========================================
SINGLE POST
========================================= */

.single-post-page{
    padding: 180px 0 120px;
    background: #0B0D11;
}

.single-post-wrapper{
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 50px;
}

.single-post-content{
    min-width: 0;
}

.single-category{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 10px 18px;

    border-radius: 999px;

    background: rgba(212,180,106,.08);

    border: 1px solid rgba(212,180,106,.18);

    color: #D4B46A;

    font-size: 13px;
    font-weight: 700;
}

.single-title{
    margin-top: 30px;

    color: #FFFFFF;

    font-size: 58px;
    line-height: 1.15;
    font-weight: 800;
}

.single-meta{
    margin-top: 24px;

    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}

.single-meta span{
    display: flex;
    align-items: center;
    gap: 10px;

    color: rgba(255,255,255,.65);

    font-size: 14px;
}

.single-thumb{
    margin-top: 40px;

    overflow: hidden;

    border-radius: 28px;
}

.single-thumb img{
    width: 100%;
    height: auto;

    display: block;
}

.single-content{
    margin-top: 50px;

    color: rgba(255,255,255,.78);

    font-size: 18px;
    line-height: 2;
}

.single-content h2,
.single-content h3,
.single-content h4{
    margin-top: 50px;
    margin-bottom: 20px;

    color: #FFFFFF;

    line-height: 1.3;
}

.single-content h2{
    font-size: 40px;
}

.single-content h3{
    font-size: 32px;
}

.single-content p{
    margin-bottom: 26px;
}

.single-content strong{
    color: #FFFFFF;
}

.single-content a{
    color: #D4B46A;
}

.single-content img{
    max-width: 100%;
    height: auto;

    border-radius: 24px;

    margin: 30px 0;
}

.single-content ul,
.single-content ol{
    padding-left: 24px;

    margin-bottom: 30px;
}

.single-content li{
    margin-bottom: 12px;
}

.single-content blockquote{
    margin: 40px 0;
    padding: 30px;

    border-left: 4px solid #D4B46A;

    background: rgba(255,255,255,.03);

    border-radius: 20px;

    color: #FFFFFF;

    font-size: 22px;
    line-height: 1.7;
}

.single-sidebar{
    position: sticky;
    top: 120px;

    height: fit-content;
}

.single-sidebar-card{
    margin-bottom: 30px;
    padding: 30px;

    border-radius: 28px;

    background: rgba(255,255,255,.03);

    border: 2px solid rgba(0, 0, 0, 0.09)!important;
}

.sidebar-mini-title{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #D4B46A;

    font-size: 12px;
    font-weight: 700;
}

.single-sidebar-card img{
    width: 100%;
    height: 340px;

    object-fit: cover;

    border-radius: 22px;
}

.single-sidebar-card h3{
    margin-top: 22px;

    color: #FFFFFF;

    font-size: 28px;
}

.single-sidebar-card p{
    margin-top: 18px;

    color: rgba(255,255,255,.72);

    line-height: 1.8;
}

.sidebar-btn{
    margin-top: 24px;

    width: 100%;
    height: 56px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 999px;

    text-decoration: none;

    background: #D4B46A;

    color: #101216;

    font-weight: 700;

    transition: .3s;
}

.sidebar-btn:hover{
    transform: scale(1.03);
}

.recent-posts{
    margin-top: 24px;

    display: flex;
    flex-direction: column;
    gap: 18px;
}

.recent-post-item{
    display: flex;
    gap: 16px;
    align-items: flex-start;

    text-decoration: none;
}

.recent-thumb{
    width: 130px;
    height: 100px;

    flex-shrink: 0;
    align-self: flex-start;

    overflow: hidden;
    border-radius: 18px;
}

.recent-thumb img{
    
    width: 100%;
    height: 100%;
    object-fit: cover;

    display: block;
}

.recent-info h4{
    margin: 0;

    color: #FFFFFF;
    font-size: 16px;
    line-height: 1.5;

    transition: .3s;
}

.recent-post-item:hover h4{
    color: #D4B46A;
}

.recent-info span{
    margin-top: 8px;

    display: block;

    color: rgba(255,255,255,.55);

    font-size: 13px;
}

/* RESPONSIVO */

@media(max-width: 1200px){

    .single-post-wrapper{
        grid-template-columns: 1fr;
    }

    .single-sidebar{
        position: relative;
        top: auto;
    }

}

@media(max-width: 768px){

    .single-post-page{
        padding: 140px 0 90px;
    }

    .single-title{
        font-size: 40px;
    }

    .single-content{
        font-size: 16px;
    }

    .single-content h2{
        font-size: 32px;
    }

    .single-content h3{
        font-size: 28px;
    }

    .single-sidebar-card{
        padding: 24px;
    }

        .gv-psico-hero{

        background-size:cover !important;
        background-position:center !important;

    }

}

/* =========================================
PÁGINAS PADRÃO
========================================= */

.default-page{
    padding: 180px 20px 120px;

    background:
    linear-gradient(
        180deg,
        #0B0D11 0%,
        #11151B 100%
    );
}

.default-page-content{
    max-width: 900px;
    margin: 0 auto;

    color: rgba(255,255,255,.78);

    font-size: 18px;
    line-height: 2;
}

.default-page-content h1{
    margin-bottom: 40px;

    color: #FFFFFF;

    font-size: 58px;
    line-height: 1.1;
}

.default-page-content h2,
.default-page-content h3{
    margin-top: 50px;
    margin-bottom: 20px;

    color: #FFFFFF;
}

.default-page-content strong{
    color: #FFFFFF;
}

.default-page-content a{
    color: #D4B46A;
}

.default-page-content ul{
    padding-left: 24px;

    margin: 20px 0;
}

.default-page-content li{
    margin-bottom: 12px;
}

@media(max-width: 768px){

    .default-page{
        padding: 140px 20px 90px;
    }

    .default-page-content h1{
        font-size: 40px;
    }

    .default-page-content{
        font-size: 16px;
    }

}

/* =========================================
LEGAL PAGES
========================================= */

.legal-page{
    position: relative;
    overflow: hidden;

    padding: 180px 20px 120px;

    background:
    linear-gradient(
        180deg,
        #0B0D11 0%,
        #11151B 100%
    );
}

.legal-glow{
    position: absolute;
    top: 120px;
    left: 50%;

    transform: translateX(-50%);

    width: 700px;
    height: 700px;

    border-radius: 50%;

    background: rgba(212,180,106,.08);

    filter: blur(120px);

    pointer-events: none;
}

.legal-lines{
    position: absolute;
    inset: 0;

    background-image:
        linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);

    background-size: 80px 80px;

    mask-image: radial-gradient(circle at center, black 30%, transparent 80%);

    pointer-events: none;
}

.legal-wrapper{
    position: relative;
    z-index: 2;

    max-width: 950px;
    margin: 0 auto;
}

.legal-top{
    text-align: center;
}

.legal-top span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 12px 20px;

    border-radius: 999px;

    background: rgba(212,180,106,.08);

    border: 1px solid rgba(212,180,106,.16);

    color: #D4B46A;

    font-size: 13px;
    font-weight: 700;
    letter-spacing: .5px;
}

.legal-top h1{
    margin-top: 34px;

    color: #FFFFFF;

    font-size: 68px;
    line-height: 1.1;
    font-weight: 800;
}

.legal-top h1 strong{
    color: #D4B46A;
}

.legal-top p{
    margin-top: 24px;

    color: rgba(255,255,255,.72);

    font-size: 19px;
    line-height: 1.9;
}

.legal-block{
    padding: 38px;

    border-radius: 30px;

    background: rgba(255,255,255,.03);

    border: 1px solid rgba(255,255,255,.06);

    backdrop-filter: blur(14px);
}

.legal-block h2{
    margin-bottom: 20px;

    color: #FFFFFF;

    font-size: 30px;
}

.legal-block p{
    color: rgba(255,255,255,.72);

    line-height: 2;

    font-size: 17px;
}

.legal-block ul{
    padding-left: 24px;

    margin-top: 20px;
}

.legal-block li{
    margin-bottom: 14px;

    color: rgba(255,255,255,.72);

    line-height: 1.8;
}

@media(max-width: 768px){

    .legal-page{
        padding: 150px 20px 90px;
    }

    .legal-top h1{
        font-size: 44px;
    }

    .legal-top p{
        font-size: 16px;
    }

    .legal-block{
        padding: 28px;
    }

    .legal-block h2{
        font-size: 24px;
    }

}

/* =========================================
LEGAL CONTENT
========================================= */

.legal-content{
    margin-top: 70px;

    padding: 50px;

    border-radius: 32px;

    background: rgba(255,255,255,.03);

    border: 1px solid rgba(255,255,255,.06);

    backdrop-filter: blur(12px);

    color: rgba(255,255,255,.74);
}

/* remove fundos brancos do WP */

.legal-content *{
    background: transparent !important;
    color: inherit;
}

/* títulos */

.legal-content h1,
.legal-content h2,
.legal-content h3,
.legal-content h4,
.legal-content h5,
.legal-content h6{
    color: #FFFFFF !important;
    line-height: 1.3;
    font-weight: 700;
}

.legal-content h2{
    margin-top: 40px;
    margin-bottom: 18px;
    font-size: 32px;
}

.legal-content h3{
    margin-top: 30px;
    margin-bottom: 14px;
    font-size: 24px;
}

/* parágrafos */

.legal-content p{
    margin-bottom: 22px;

    color: rgba(255,255,255,.74) !important;

    font-size: 17px;
    line-height: 2;
}

/* listas */

.legal-content ul,
.legal-content ol{
    padding-left: 25px;
    margin-bottom: 24px;
}

.legal-content li{
    margin-bottom: 14px;

    color: rgba(255,255,255,.74) !important;

    line-height: 1.8;
}

/* negrito */

.legal-content strong{
    color: #FFFFFF !important;
}

/* links */

.legal-content a{
    color: #D4B46A !important;
}

/* separadores */

.legal-content hr{
    border: none;
    height: 1px;

    background: rgba(255,255,255,.08);

    margin: 40px 0;
}

/* blocos gutenberg */

.legal-content .wp-block-group,
.legal-content .wp-block-columns,
.legal-content .wp-block-column{
    background: transparent !important;
}

/* mobile */

@media(max-width:768px){

    .legal-content{
        padding: 32px 24px;
    }

    .legal-content h2{
        font-size: 26px;
    }

}

/* =========================================
CONTACT PAGE
========================================= */

.contact-page{
    position: relative;

    overflow: hidden;

    padding: 180px 20px 120px;

    min-height: 100vh;

    background:
    linear-gradient(
        180deg,
        #0B0D11 0%,
        #11151B 100%
    );
}

.contact-page-glow{
    position: absolute;

    top: 120px;
    left: 50%;

    transform: translateX(-50%);

    width: 700px;
    height: 700px;

    border-radius: 50%;

    background: rgba(212,180,106,.08);

    filter: blur(120px);

    pointer-events: none;
}

.contact-page-lines{
    position: absolute;
    inset: 0;

    background-image:
        linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);

    background-size: 80px 80px;

    mask-image: radial-gradient(circle at center, black 30%, transparent 80%);
}

.contact-page-hero{
    position: relative;
    z-index: 2;

    max-width: 850px;

    margin: 0 auto 80px;

    text-align: center;
}

.contact-page-hero span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 12px 22px;

    border-radius: 999px;

    background: rgba(212,180,106,.08);

    border: 1px solid rgba(212,180,106,.16);

    color: #D4B46A;

    font-size: 13px;
    font-weight: 700;
}

.contact-page-hero h1{
    margin-top: 34px;

    color: #FFFFFF;

    font-size: 68px;
    line-height: 1.1;
}

.contact-page-hero h1 strong{
    color: #D4B46A;
}

.contact-page-hero p{
    margin-top: 24px;

    color: rgba(255,255,255,.72);

    font-size: 19px;
    line-height: 1.9;
}

.contact-page-grid{
    position: relative;
    z-index: 2;

    display: grid;
    grid-template-columns: 420px 1fr;

    gap: 40px;
}

.contact-card,
.contact-schedule-card,
.contact-editor-content{
    padding: 40px;

    border-radius: 30px;

    background: rgba(255,255,255,.03);

    border: 1px solid rgba(255,255,255,.06);

    backdrop-filter: blur(12px);
}

.contact-schedule-card{
    margin-top: 30px;
}

.contact-card h2,
.contact-schedule-card h3{
    color: #FFFFFF;
}

.contact-list{
    margin-top: 30px;

    display: flex;
    flex-direction: column;
    gap: 24px;
}

.contact-schedule-card p{
    margin-top: 18px;

    color: rgba(255,255,255,.72);

    line-height: 1.9;
}

.contact-schedule-btn{
    margin-top: 30px;

    height: 62px;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;

    border-radius: 18px;

    background: #D4B46A;

    color: #101216;

    text-decoration: none;

    font-weight: 700;

    transition: .3s;
}

.contact-schedule-btn:hover{
    transform: translateY(-3px);
}

.contact-map{
    overflow: hidden;

    height: 420px;

    border-radius: 30px;

    border: 1px solid rgba(255,255,255,.06);
}

.contact-map iframe{
    width: 100%;
    height: 100%;

    border: none;
}

.contact-editor-content{
    margin-top: 30px;

    color: rgba(255,255,255,.74);
}

.contact-editor-content *{
    background: transparent !important;
}

.contact-editor-content h2,
.contact-editor-content h3{
    color: #FFFFFF;
}

.contact-editor-content p,
.contact-editor-content li{
    color: rgba(255,255,255,.74);

    line-height: 2;
}

@media(max-width: 991px){

    .contact-page-grid{
        grid-template-columns: 1fr;
    }

}

@media(max-width: 768px){

    .contact-page{
        padding: 150px 20px 90px;
    }

    .contact-page-hero h1{
        font-size: 44px;
    }

    .contact-page-hero p{
        font-size: 16px;
    }

    .contact-card,
    .contact-schedule-card,
    .contact-editor-content{
        padding: 28px;
    }

}

/* =========================================
GV SERVICES PAGE
========================================= */

.gv-services-page{
    background: #070B14;
    overflow: hidden;
}

/* container */

.gv-services-container{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px;
}

/* =========================================
HERO
========================================= */

.gv-services-hero{
    padding: 180px 0 120px;
}

.gv-services-badge{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 12px 22px;

    border-radius: 999px;

    background: rgba(212,180,106,.08);
    border: 1px solid rgba(212,180,106,.25);

    color: #D4B46A;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 1px;

    margin-bottom: 30px;
}

.gv-services-hero h1{
    max-width: 920px;

    font-size: 74px;
    line-height: 1.08;
    font-weight: 800;

    color: #fff;

    margin-bottom: 28px;
}

.gv-services-hero h1 strong{
    color: #D4B46A;
}

.gv-services-hero p{
    max-width: 720px;

    font-size: 20px;
    line-height: 1.9;

    color: rgba(255,255,255,.72);

    margin-bottom: 45px;
}

.gv-services-buttons{
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
}

.gv-services-btn-primary,
.gv-services-btn-secondary{
    height: 62px;
    padding: 0 34px;

    border-radius: 60px;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;

    text-decoration: none;
    font-weight: 700;

    transition: .3s;
}

.gv-services-btn-primary{
    background: #D4B46A;
    color: #070B14;
}

.gv-services-btn-primary:hover{
    transform: translateY(-4px);
}

.gv-services-btn-secondary{
    border: 1px solid rgba(255,255,255,.12);
    color: #fff;
}

.gv-services-btn-secondary:hover{
    border-color: #D4B46A;
    color: #D4B46A;
}

/* =========================================
SERVICES GRID
========================================= */

.gv-services-list{
    padding-bottom: 120px;
}

.gv-services-grid{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 28px;
}

.gv-service-card{
    padding: 38px;

    border-radius: 28px;

    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.05);

    transition: .35s;
}

.gv-service-card:hover{
    transform: translateY(-8px);
    border-color: rgba(212,180,106,.25);
}

.gv-service-icon{
    width: 72px;
    height: 72px;

    border-radius: 22px;

    display: flex;
    align-items: center;
    justify-content: center;

    background: rgba(212,180,106,.1);

    margin-bottom: 24px;
}

.gv-service-icon i{
    color: #D4B46A;
    font-size: 28px;
}

.gv-service-card h3{
    color: #fff;
    font-size: 30px;
    line-height: 1.3;

    margin-bottom: 16px;
}

.gv-service-card p{
    color: rgba(255,255,255,.72);

    line-height: 1.9;
    font-size: 16px;

    margin-bottom: 24px;
}

.gv-service-card ul{
    padding-left: 18px;
    margin-bottom: 28px;
}

.gv-service-card ul li{
    color: rgba(255,255,255,.65);
    margin-bottom: 8px;
    line-height: 1.8;
}

.gv-service-link{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #D4B46A;
    text-decoration: none;
    font-weight: 700;
}

.gv-service-link:hover{
    gap: 16px;
}

/* =========================================
BENEFITS
========================================= */

.gv-services-benefits{
    padding: 120px 0;
}

.gv-benefits-wrapper{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 70px;
    align-items: center;
}

.gv-benefits-left span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #D4B46A;
    font-weight: 700;
    letter-spacing: 1px;

    margin-bottom: 24px;
}

.gv-benefits-left h2{
    font-size: 58px;
    line-height: 1.15;

    color: #fff;

    margin-bottom: 28px;
}

.gv-benefits-left h2 strong{
    color: #D4B46A;
}

.gv-benefits-left p{
    color: rgba(255,255,255,.72);

    font-size: 19px;
    line-height: 1.9;
}

.gv-benefits-right{
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.gv-benefit-box{
    display: flex;
    gap: 18px;

    padding: 24px;

    border-radius: 24px;

    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.05);
}

.gv-benefit-box i{
    color: #D4B46A;
    font-size: 24px;
    margin-top: 3px;
}

.gv-benefit-box h3{
    color: #fff;
    margin-bottom: 8px;
}

.gv-benefit-box p{
    color: rgba(255,255,255,.7);
    line-height: 1.7;
}

/* =========================================
CTA
========================================= */

.gv-services-cta{
    padding: 80px 0 140px;
}

.gv-services-cta-box{
    padding: 80px;

    border-radius: 40px;

    text-align: center;

    background:
        linear-gradient(
            135deg,
            rgba(212,180,106,.12),
            rgba(255,255,255,.02)
        );

    border: 1px solid rgba(212,180,106,.16);
}

.gv-services-cta-box span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #D4B46A;
    font-weight: 700;
    letter-spacing: 1px;

    margin-bottom: 24px;
}

.gv-services-cta-box h2{
    font-size: 58px;
    line-height: 1.15;

    color: #fff;

    margin-bottom: 24px;
}

.gv-services-cta-box h2 strong{
    color: #D4B46A;
}

.gv-services-cta-box p{
    max-width: 760px;

    margin: 0 auto 40px;

    color: rgba(255,255,255,.72);

    font-size: 19px;
    line-height: 1.9;
}

/* =========================================
RESPONSIVO
========================================= */

@media(max-width:1100px){

    .gv-services-grid{
        grid-template-columns: repeat(2,1fr);
    }

    .gv-benefits-wrapper{
        grid-template-columns: 1fr;
    }

}

@media(max-width:768px){

    .gv-services-hero{
        padding: 150px 0 90px;
    }

    .gv-services-grid{
        grid-template-columns: 1fr;
    }

    .gv-services-hero h1{
        font-size: 42px;
    }

    .gv-benefits-left h2,
    .gv-services-cta-box h2{
        font-size: 36px;
    }

    .gv-services-cta-box{
        padding: 50px 26px;
    }

}

/* =========================================
BACKGROUND PREMIUM
========================================= */

.gv-services-page{
    position: relative;
    background:
        radial-gradient(circle at top left,
            rgba(212,180,106,.08),
            transparent 30%),


        radial-gradient(circle at bottom right,
            rgba(212,180,106,.06),
            transparent 35%),


        linear-gradient(
            180deg,
            #070B14 0%,
            #09111E 100%
        );

    overflow: hidden;
}

/* glow topo */

.gv-services-page::before{
    content: "";

    position: absolute;

    top: -200px;
    left: -200px;

    width: 600px;
    height: 600px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(212,180,106,.18),
            transparent 70%
        );

    filter: blur(80px);

    pointer-events: none;
}

/* glow inferior */

.gv-services-page::after{
    content: "";

    position: absolute;

    right: -250px;
    bottom: -250px;

    width: 700px;
    height: 700px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(212,180,106,.10),
            transparent 70%
        );

    filter: blur(100px);

    pointer-events: none;
}

/* =========================================
ONDAS DECORATIVAS
========================================= */

.gv-services-hero{
    position: relative;
}

.gv-services-hero::before{
    content: "";

    position: absolute;

    top: 0;
    right: -200px;

    width: 700px;
    height: 700px;

    border-radius: 50%;

    border:
        1px solid rgba(212,180,106,.06);

    transform: rotate(12deg);

    pointer-events: none;
}

.gv-services-hero::after{
    content: "";

    position: absolute;

    top: 120px;
    right: -120px;

    width: 500px;
    height: 500px;

    border-radius: 50%;

    border:
        1px solid rgba(212,180,106,.05);

    pointer-events: none;
}

/* =========================================
EFEITO GRID PSICOLÓGICO
========================================= */

.gv-services-list{
    position: relative;
}

.gv-services-list::before{
    content: "";

    position: absolute;
    inset: 0;

    background-image:
        linear-gradient(
            rgba(255,255,255,.015) 1px,
            transparent 1px
        ),

        linear-gradient(
            90deg,
            rgba(255,255,255,.015) 1px,
            transparent 1px
        );

    background-size: 80px 80px;

    mask-image:
        radial-gradient(circle at center,
            black 20%,
            transparent 90%);

    pointer-events: none;
}

/* =========================================
CARD PREMIUM
========================================= */

.gv-service-card{
    position: relative;
    overflow: hidden;

    backdrop-filter: blur(10px);
}

.gv-service-card::before{
    content: "";

    position: absolute;

    inset: 0;

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,.04),
            transparent 40%
        );

    pointer-events: none;
}

.gv-service-card::after{
    content: "";

    position: absolute;

    top: -100px;
    right: -100px;

    width: 220px;
    height: 220px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(212,180,106,.08),
            transparent 70%
        );

    opacity: 0;

    transition: .4s;
}

.gv-service-card:hover::after{
    opacity: 1;
}

/* =========================================
ÍCONE MAIS PREMIUM
========================================= */

.gv-service-icon{
    position: relative;
}

.gv-service-icon::before{
    content: "";

    position: absolute;
    inset: -1px;

    border-radius: inherit;

    background:
        linear-gradient(
            135deg,
            rgba(212,180,106,.4),
            transparent
        );

    opacity: .5;
}

/* =========================================
CTA MAIS IMPACTANTE
========================================= */

.gv-services-cta{
    position: relative;
}

.gv-services-cta::before{
    content: "";

    position: absolute;

    left: 50%;
    top: 50%;

    transform: translate(-50%, -50%);

    width: 900px;
    height: 900px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(212,180,106,.08),
            transparent 70%
        );

    filter: blur(120px);

    pointer-events: none;
}

.gv-services-cta-box{
    position: relative;
    overflow: hidden;
}

.gv-services-cta-box::before{
    content: "";

    position: absolute;

    inset: 0;

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,.06),
            transparent 40%
        );

    pointer-events: none;
}

/* =========================================
PARTÍCULAS LEVES
========================================= */

.gv-services-page .particle{
    position: absolute;

    width: 6px;
    height: 6px;

    border-radius: 50%;

    background: rgba(212,180,106,.35);

    filter: blur(1px);
}

/* =========================================
FEEDBACKS PAGE
========================================= */

.gv-feedbacks-page{
    position: relative;
    padding: 180px 0 120px;
    background: #070B14;
    overflow: hidden;
}

.gv-feedbacks-glow{
    position: absolute;

    top: -200px;
    right: -200px;

    width: 700px;
    height: 700px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(212,180,106,.14),
            transparent 70%
        );

    filter: blur(100px);
}

.gv-feedbacks-header{
    text-align: center;
    margin-bottom: 70px;
}

.gv-feedbacks-header span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    color: #D4B46A;

    font-weight: 700;
    letter-spacing: 1px;

    margin-bottom: 22px;
}

.gv-feedbacks-header h1{
    max-width: 900px;

    margin: 0 auto 24px;

    font-size: 62px;
    line-height: 1.1;

    color: #fff;
}

.gv-feedbacks-header p{
    max-width: 760px;

    margin: 0 auto;

    color: rgba(255,255,255,.72);

    line-height: 1.9;
    font-size: 18px;
}

.gv-feedbacks-grid{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 28px;
}

.gv-feedback-card{
    padding: 34px;

    border-radius: 30px;

    background:
        linear-gradient(
            145deg,
            rgba(255,255,255,.05),
            rgba(255,255,255,.02)
        );

    border: 1px solid rgba(255,255,255,.06);

    backdrop-filter: blur(10px);

    transition: .35s;
}

.gv-feedback-card:hover{
    transform: translateY(-8px);
    border-color: rgba(212,180,106,.22);
}

.gv-feedback-top{
    display: flex;
    align-items: center;
    gap: 18px;

    margin-bottom: 24px;
}

.gv-feedback-top img{
    width: 70px;
    height: 70px;

    border-radius: 50%;
    object-fit: cover;
}

.gv-feedback-top h3{
    color: #fff;
    margin-bottom: 8px;
}

.gv-feedback-stars{
    display: flex;
    gap: 5px;
}

.gv-feedback-stars i{
    color: #D4B46A;
}

.gv-feedback-card p{
    color: rgba(255,255,255,.72);

    line-height: 1.9;
    font-size: 16px;
}

@media(max-width:992px){

    .gv-feedbacks-grid{
        grid-template-columns: 1fr 1fr;
    }

}

@media(max-width:768px){

    .gv-feedbacks-page{
        padding: 150px 0 90px;
    }

    .gv-feedbacks-grid{
        grid-template-columns: 1fr;
    }

    .gv-feedbacks-header h1{
        font-size: 40px;
    }

}

/* =========================================
CTA FINAL
========================================= */

.gv-feedbacks-cta{
    margin-top: 120px;
    position: relative;
    z-index: 2;
}

.gv-feedbacks-cta-box{
    position: relative;
    overflow: hidden;

    padding: 70px 50px;

    border-radius: 35px;

    background:
    linear-gradient(
        145deg,
        rgba(255,255,255,0.04),
        rgba(255,255,255,0.02)
    );

    border: 1px solid rgba(255,255,255,0.08);

    backdrop-filter: blur(10px);

    text-align: center;
}

.gv-feedbacks-cta-box::before{
    content: '';

    position: absolute;

    top: -120px;
    right: -120px;

    width: 260px;
    height: 260px;

    background: rgba(255, 196, 87, 0.08);

    border-radius: 50%;

    filter: blur(30px);
}

.gv-feedbacks-cta-box span{
    display: inline-flex;
    align-items: center;
    gap: 10px;

    padding: 12px 22px;

    border-radius: 999px;

    background: rgba(255,255,255,0.05);

    border: 1px solid rgba(255,255,255,0.08);

    color: #f7d28b;

    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1px;

    margin-bottom: 28px;
}

.gv-feedbacks-cta-box span i{
    font-size: 14px;
}

.gv-feedbacks-cta-box h2{
    font-size: 52px;
    line-height: 1.15;

    color: #fff;

    max-width: 900px;

    margin:
    0 auto
    28px auto;

    font-weight: 300;
}

.gv-feedbacks-cta-box h2 strong{
    display: block;

    font-weight: 700;

    background: linear-gradient(
        90deg,
        #fff,
        #f7d28b
    );

    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.gv-feedbacks-cta-box p{
    max-width: 760px;

    margin: 0 auto;

    color: rgba(255,255,255,0.75);

    font-size: 18px;
    line-height: 1.8;
}

/* botão */

.gv-feedbacks-cta-btn{
    margin-top: 45px;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 16px;

    height: 72px;

    padding: 0 34px;

    border-radius: 999px;

    background:
    linear-gradient(
        135deg,
        #f7d28b,
        #e5b85f
    );

    color: #111;

    font-size: 15px;
    font-weight: 700;
    letter-spacing: 1px;

    text-decoration: none;

    transition:
    transform .25s ease,
    box-shadow .25s ease;
}

.gv-feedbacks-cta-btn:hover{
    transform: scale(0.96);

    box-shadow:
    0 15px 40px rgba(247, 210, 139, 0.25);
}

.gv-feedbacks-cta-btn i{
    font-size: 18px;
}

.gv-feedbacks-cta-arrow {
    width: 34px;
    height: 34px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;

    background: rgba(0,0,0,0.12);

    margin: 0;
    padding: 0;
    border: none;

    color: #111;
}

/* avatar clicável */

.gv-feedback-avatar-link{
    display: flex;

    width: fit-content;

    border-radius: 50%;

    overflow: hidden;

    transition:
    transform .25s ease,
    box-shadow .25s ease;
}

.gv-feedback-avatar-link:hover{
    transform: scale(0.94);

    box-shadow:
    0 10px 25px rgba(247, 210, 139, 0.25);
}

/* responsivo */

@media(max-width: 768px){

    .gv-feedbacks-cta{
        margin-top: 80px;
    }

    .gv-feedbacks-cta-box{
        padding: 45px 25px;
        border-radius: 25px;
    }

    .gv-feedbacks-cta-box h2{
        font-size: 34px;
    }

    .gv-feedbacks-cta-box p{
        font-size: 16px;
    }

    .gv-feedbacks-cta-btn{
        width: 100%;
        height: 64px;

        font-size: 14px;
    }
}

/* =========================================
BLOG PAGE
========================================= */

.gv-blog-page{

    background:#070B14;

    color:#fff;

    position:relative;

    overflow:hidden;
}

/* =========================================
HERO
========================================= */

.gv-blog-hero{

    min-height:700px;

    display:flex;
    align-items:center;

    position:relative;

    background:
    linear-gradient(
        90deg,
        rgba(7,11,20,.95) 0%,
        rgba(7,11,20,.85) 40%,
        rgba(7,11,20,.40) 100%
    );

    background-size:cover;
    background-position:center right;
}

/*.gv-blog-hero::before{

    content:'';

    position:absolute;

    inset:0;

    background:
    radial-gradient(
        circle at right center,
        rgba(212,180,106,.18),
        transparent 50%
    );

    pointer-events:none;
}*/

/*.gv-blog-hero::after{

    content:'';

    position:absolute;

    right:-200px;
    top:50%;

    width:700px;
    height:700px;

    transform:translateY(-50%);

    background:
    radial-gradient(
        circle,
        rgba(212,180,106,.18),
        transparent 70%
    );

    pointer-events:none;
}*/

.gv-blog-hero-grid{

    width:100%;

    display:grid;

    grid-template-columns:1fr 420px;

    gap:60px;

    align-items:end;
}

.gv-blog-badge{

    display:inline-flex;

    align-items:center;

    padding:12px 20px;

    border-radius:999px;

    border:1px solid rgba(212,180,106,.25);

    background:rgba(212,180,106,.08);

    color:#D4B46A;

    margin-bottom:25px;

    font-size:14px;

    letter-spacing:2px;
}

.gv-blog-hero h1{

    font-size:72px;

    line-height:1.05;

    margin-bottom:30px;
}

.gv-blog-hero h1 strong{
    color: #D4B46A;
}

.gv-blog-hero p{

    font-size:22px;

    color:#C9CED7;

    max-width:700px;

    line-height:1.8;
}

/* =========================================
SEARCH
========================================= */

.gv-blog-search form{

    position:relative;
}

.gv-blog-search i{

    position:absolute;

    left:24px;
    top:50%;

    transform:translateY(-50%);

    color: #d4b46a !important;
    z-index: 20;
}

.gv-blog-search input{

    width:100%;

    height:78px;

    background:rgba(8,13,24,.85);

    backdrop-filter:blur(12px);

    border:1px solid rgba(255,255,255,.12);

    border-radius:24px;

    color:#fff;

    padding-left:65px;

    font-size:18px;
}

.gv-blog-search input::placeholder{
    color: #D4B46A;
}

.gv-blog-search input:focus{

    outline:none;

    border-color:#D4B46A;
}

/* =========================================
CATEGORIAS
========================================= */

.gv-blog-categories{

    padding-bottom:70px;
}

.gv-blog-categories-wrap{

    display:flex;

    gap:15px;

    flex-wrap:wrap;
}

.gv-blog-categories-wrap a{

    padding:14px 24px;

    border-radius:999px;

    border:1px solid rgba(212,180,106,.20);

    color:#fff;

    text-decoration:none;

    transition:.3s;
}

.gv-blog-categories-wrap a:hover,
.gv-blog-categories-wrap a.active{

    background:#D4B46A;

    color:#070B14;
}

/* =========================================
GRID
========================================= */

.gv-blog-content{

    padding-bottom:120px;
}

.gv-blog-grid{

    display:grid;

    grid-template-columns:2fr 380px;

    gap:35px;
}

.gv-blog-posts{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:35px;
}

.gv-blog-card{

    background:linear-gradient(
        180deg,
        #10192B,
        #0B1220
    );

    border-radius:30px;

    overflow:hidden;

    border:1px solid rgba(212,180,106,.12);

    transition:.4s;
}

.gv-blog-card:hover{

    transform:translateY(-10px);

    border-color:rgba(212,180,106,.35);

    box-shadow:
    0 25px 60px rgba(0,0,0,.45);
}

.gv-load-more-wrap{

    text-align:center;

    margin-top:60px;
}

.gv-load-more-btn{

    background:#D4B46A;

    color:#070B14;

    border:none;

    padding:18px 40px;

    border-radius:999px;

    font-weight:700;

    cursor:pointer;

    transition:.3s;
}

.gv-load-more-btn:hover{

    transform:translateY(-3px);

    box-shadow:
    0 15px 30px rgba(212,180,106,.25);
}

.gv-blog-card a{

    color:inherit;

    text-decoration:none;
}

.gv-blog-thumb{

    aspect-ratio:16/8;

    overflow:hidden;

    position:relative;
}

.gv-blog-thumb img{

    width:100%;
    height:100%;

    object-fit:cover;

    transition:.6s;
}

.gv-blog-card:hover .gv-blog-thumb img{

    transform:scale(1.08);
}

.gv-blog-card-content{

    padding:24px;
}

.gv-blog-category{

    position:absolute;

    left:20px;
    bottom:20px;

    z-index:2;

    background:rgba(212,180,106,.95);

    color:#070B14;

    padding:10px 16px;

    border-radius:999px;

    font-size:12px;

    font-weight:700;

    text-transform:uppercase;

    backdrop-filter:blur(10px);
}

.gv-blog-meta{

    display:flex;

    gap:20px;

    align-items:center;

    margin-bottom:18px;

    color:#AAB2C0;

    font-size:14px;
}

.gv-blog-meta span{

    display:flex;

    align-items:center;

    gap:8px;
}

.gv-blog-card-content h3{

    font-size:30px;

    line-height:1.3;

    margin-bottom:18px;
}

.gv-blog-card-content p{

    color:#C9CED7;

    line-height:1.8;

    margin-bottom:25px;
}

.gv-blog-read{

    color:#D4B46A;

    font-weight:600;
}

.gv-blog-sidebar-card{

    background:#0D1422;

    border-radius:28px;

    padding:30px;

    border:1px solid rgba(212,180,106,.12);

    position:sticky;

    top:120px;
}

.gv-blog-sidebar-card h3{

    color:#D4B46A;

    margin-bottom:30px;

    font-size:30px;
}

.gv-sidebar-post{

    display:flex;

    gap:15px;

    margin-bottom:25px;

    text-decoration:none;

    color:#fff;
}

.gv-sidebar-thumb{

    width:90px;
    height:90px;

    border-radius:14px;

    overflow:hidden;

    flex-shrink:0;
}

.gv-sidebar-thumb img{

    width:100%;
    height:100%;

    object-fit:cover;
}

.gv-sidebar-post strong{

    display:block;

    line-height:1.5;

    margin-bottom:8px;
}

.gv-sidebar-post span{

    color:#C9CED7;

    font-size:14px;
}

@media(max-width:1024px){

    .gv-blog-grid{

        grid-template-columns:1fr;
    }

    .gv-blog-sidebar{

        order:-1;
    }

    .gv-sidebar-thumb {
        width: 150px;
        height: 100px;
    }

    .gv-sidebar-thumb img{
        width: 150px;
        height: 100px;
    }

}

@media(max-width:768px){

    .gv-blog-hero{

        padding:120px 0 80px;
    }

    .gv-blog-hero-grid{

        grid-template-columns:1fr;
    }

    .gv-blog-hero h1{

        font-size:42px;
    }

    .gv-blog-hero p{

        font-size:18px;
    }

        .gv-blog-card{

        width:100%;
    }

    .gv-blog-posts{

        display:grid !important;

        grid-template-columns:1fr !important;

        gap:20px;
    }

    .gv-blog-card-featured{

        grid-column:auto !important;

        width:100%;

        max-width:100%;
    }

        .gv-blog-thumb{

        aspect-ratio:16/10;
    }

    .gv-blog-card-content h3{

        font-size:24px;

        line-height:1.3;

        margin-bottom:12px;
    }

        .gv-blog-card-content, .gv-blog-card-featured{

        padding:18px;
    }

        .gv-blog-card-content p {

        margin-bottom:12px;
    }

    .gv-blog-read{

        display:inline-block;

        margin-bottom:0;
    }

    .gv-blog-page .gv-services-container{

        padding-left:8px;

        padding-right:8px;
    }

        .gv-blog-posts, .gv-blog-card-f{

        gap:18px;
    }

        .gv-blog-category{

        left:12px;

        bottom:12px;

        padding:8px 12px;

        font-size:11px;
    }

        .gv-blog-card-featured h3{

        font-size:30px!important;
    }

        .gv-blog-card-featured .gv-blog-thumb{

        aspect-ratio:16/10!important;
    }

    .gv-blog-card-featured .gv-blog-card-content{

        padding:18px!important;
    }
        

}

.gv-blog-card-featured{

    grid-column:span 2;
}

.gv-blog-card-featured .gv-blog-thumb{

    aspect-ratio:21/8;
}

.gv-blog-card-featured h3{

    font-size:42px;

    max-width:800px;
}

.gv-blog-card-featured .gv-blog-card-content{

    padding:35px;
}

.gv-blog-search-hero{

    padding:220px 0 120px;

    text-align:center;
}

.articles-grid{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:24px;
}

.article-card{
    background:#0f141d;
    border:1px solid rgba(255,255,255,.05);
    border-radius:22px;
    overflow:hidden;
    transition:.4s;
}

.article-card:hover{
    transform:translateY(-8px);
    border-color:var(--gold);
}

.single-sidebar-card h3 strong{
     color: #D4B46A;
}

.gv-feedbacks-more{
    margin-top: 50px;
    text-align: center;
}

.gv-feedbacks-more-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;

    padding: 16px 32px;

    border-radius: 999px;

    background: #D4B46A;
    color: #070B14;

    font-weight: 600;
    text-decoration: none;

    transition: .3s;
}

.gv-feedbacks-more-btn:hover{
    transform: translateY(-3px);
}