/**
 * Centralcomm — Componentes do Brand Manual v2.1
 */

/* ── TIPOGRAFIA ── */
.ts-h1 {
    font-family: var(--display);
    font-size: clamp(34px, 5vw, 52px);
    font-weight: 800;
    letter-spacing: -0.025em;
    line-height: 1;
    color: var(--branco);
}

.ts-h2 {
    font-family: var(--display);
    font-size: clamp(28px, 4vw, 38px);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.ts-h3 {
    font-family: var(--display);
    font-size: clamp(22px, 3vw, 26px);
    font-weight: 700;
    letter-spacing: -0.015em;
    line-height: 1.2;
}

.ts-h4 {
    font-family: var(--display);
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

.ts-body {
    font-family: var(--body);
    font-size: 15px;
    font-weight: 400;
    line-height: 1.7;
}

.ts-sm {
    font-family: var(--body);
    font-size: 13px;
    font-weight: 400;
    line-height: 1.6;
    color: var(--cinza-300);
}

.ts-lbl,
.brand-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--s8);
    font-family: var(--body);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--verde);
}

.brand-eyebrow::before {
    content: '';
    width: 16px;
    height: 1px;
    background: var(--verde);
}

.text-accent-neon {
    color: var(--verde-neon);
}

.text-accent-verde {
    color: var(--verde);
}

/* ── BOTÕES ── */
.btn-brand,
.hero-btn-primary,
.home-hero__cta-primary,
.nav-btn-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s8);
    font-family: var(--body);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: var(--t-base);
}

.btn-brand-p,
.hero-btn-primary,
.home-hero__cta-primary {
    padding: 13px 28px;
    border-radius: var(--rfull);
    background: var(--verde);
    color: var(--preto);
}

.btn-brand-p:hover,
.hero-btn-primary:hover,
.home-hero__cta-primary:hover {
    background: var(--color-primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-verde);
}

.btn-brand-o,
.hero-btn-secondary,
.home-hero__cta-secondary {
    padding: 12px 26px;
    border-radius: var(--rfull);
    background: transparent;
    color: var(--branco);
    border: 1.5px solid rgba(255, 255, 255, 0.22);
}

.btn-brand-o:hover,
.hero-btn-secondary:hover,
.home-hero__cta-secondary:hover {
    border-color: rgba(255, 255, 255, 0.55);
    background: rgba(255, 255, 255, 0.04);
}

.btn-brand-g {
    padding: 9px 18px;
    border-radius: var(--r12);
    background: transparent;
    color: var(--verde);
    border: 1px solid rgba(79, 255, 130, 0.3);
}

.btn-brand-g:hover {
    background: rgba(79, 255, 130, 0.08);
    border-color: var(--verde);
}

.btn-brand-gold {
    padding: 13px 28px;
    border-radius: var(--rfull);
    background: var(--dourado);
    color: var(--preto);
}

.btn-brand-sm {
    padding: 7px 14px;
    border-radius: var(--rfull);
    font-size: 12px;
    background: var(--verde);
    color: var(--preto);
}

/* ── BADGES ── */
.badge-brand,
.badge-brand-g {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 12px;
    border-radius: var(--rfull);
    font-family: var(--body);
    font-size: 11px;
    font-weight: 600;
    background: rgba(79, 255, 130, 0.12);
    color: var(--verde);
    border: 1px solid rgba(79, 255, 130, 0.25);
}

.badge-brand-d {
    background: rgba(251, 186, 7, 0.12);
    color: var(--dourado);
    border-color: rgba(251, 186, 7, 0.25);
}

.badge-brand-w {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.badge-brand-out {
    background: transparent;
    color: var(--cinza-300);
    border: 1px solid var(--cinza-700);
}

/* ── CARDS ESCUROS ── */
.brand-card,
.journey-section--picker .journey-card,
.journey-section--picker .journey-mobile-toggle-btn {
    background: var(--dark-3);
    border: 1px solid var(--cinza-700);
    border-radius: var(--r20);
    transition: var(--t-base);
}

.brand-card:hover {
    border-color: rgba(79, 255, 130, 0.3);
    transform: translateY(-2px);
}

.brand-stat-card {
    background: var(--dark-3);
    border: 1px solid var(--cinza-700);
    border-radius: var(--r20);
    padding: var(--s24) var(--s16);
    text-align: center;
}

.brand-stat-card strong,
.brand-stat-num {
    display: block;
    font-family: var(--display);
    font-size: 34px;
    font-weight: 800;
    color: var(--verde);
    line-height: 1;
}

/* ── INPUTS (tema escuro) ── */
.brand-input,
.contact-form-section--dark .contact-form-v2 input:not([type='hidden']):not([type='checkbox']),
.contact-form-section--dark .contact-form-v2 textarea,
.contact-form-section--dark .contact-form-v2 select {
    width: 100%;
    box-sizing: border-box;
    background: var(--dark-3);
    border: 1.5px solid var(--cinza-700);
    border-radius: var(--r12);
    padding: 11px 14px;
    color: var(--branco);
    font-family: var(--body);
    font-size: 14px;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.brand-input::placeholder {
    color: var(--cinza-500);
}

.brand-input:focus {
    border-color: var(--verde);
    box-shadow: 0 0 0 3px rgba(79, 255, 130, 0.1);
}

.brand-input-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--cinza-300);
}

/* ── UTILITÁRIOS DE FUNDO ── */
.bg-brand-hero-glow {
    background:
        radial-gradient(ellipse 70% 60% at 72% 45%, rgba(79, 255, 130, 0.09) 0%, transparent 55%),
        radial-gradient(ellipse 35% 35% at 12% 78%, rgba(251, 186, 7, 0.06) 0%, transparent 50%);
}

.bg-brand-grid {
    background-image:
        linear-gradient(rgba(79, 255, 130, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(79, 255, 130, 0.04) 1px, transparent 1px);
    background-size: 56px 56px;
}

/* Tailwind utility overrides — ver também global.css */
.bg-surface-dark {
    background-color: var(--preto) !important;
}

.text-primary {
    color: var(--verde) !important;
}

.bg-primary {
    background-color: var(--verde) !important;
}

.bg-primary-dark,
.hover\:bg-primary-dark:hover {
    background-color: var(--color-primary-dark) !important;
}

.border-primary {
    border-color: var(--verde) !important;
}
