/* === Componentes Base — Design System v2.0 === */

/* --- Container --- */
.tc-container {
    margin: 0 auto;
    max-width: var(--tc-container);
    padding: 0 var(--tc-gutter);
    width: 100%;
}

.tc-container--narrow {
    max-width: var(--tc-container-sm);
}

/* --- Botón Primario --- */
.tc-btn--primary {
    align-items: center;
    background: var(--tc-navy);
    border: 2px solid var(--tc-navy);
    border-radius: var(--tc-radius-full);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-family: var(--tc-font-body);
    font-size: var(--tc-text-sm);
    font-weight: 700;
    gap: 8px;
    letter-spacing: 0.02em;
    min-height: 52px;
    padding: 0 32px;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    justify-content: center;
}

.tc-btn--primary:hover {
    background: var(--tc-gold);
    border-color: var(--tc-gold);
    box-shadow: var(--tc-shadow-gold);
    color: var(--tc-navy);
    transform: translateY(-2px);
}

/* --- Botón Secundario --- */
.tc-btn--secondary {
    align-items: center;
    background: transparent;
    border: 2px solid var(--tc-border-strong);
    border-radius: var(--tc-radius-full);
    color: var(--tc-ink);
    cursor: pointer;
    display: inline-flex;
    font-family: var(--tc-font-body);
    font-size: var(--tc-text-sm);
    font-weight: 700;
    gap: 8px;
    min-height: 52px;
    padding: 0 32px;
    text-decoration: none;
    transition: all 0.3s ease;
    justify-content: center;
}

.tc-btn--secondary:hover {
    background: var(--tc-navy);
    border-color: var(--tc-navy);
    color: #fff;
}

/* --- Botón WhatsApp --- */
.tc-btn--whatsapp {
    align-items: center;
    background: var(--tc-whatsapp);
    border: 2px solid var(--tc-whatsapp);
    border-radius: var(--tc-radius-full);
    box-shadow: 0 4px 20px rgba(37, 211, 102, 0.25);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-family: var(--tc-font-body);
    font-size: var(--tc-text-sm);
    font-weight: 700;
    gap: 10px;
    min-height: 52px;
    padding: 0 28px;
    text-decoration: none;
    transition: all 0.3s ease;
    justify-content: center;
}

.tc-btn--whatsapp:hover {
    background: #20BD5A;
    box-shadow: 0 8px 30px rgba(37, 211, 102, 0.35);
    transform: translateY(-2px);
}

/* --- Botón Small --- */
.tc-btn--small {
    font-size: var(--tc-text-xs);
    min-height: 42px;
    padding: 0 22px;
}

/* --- Botón Invertido (para fondos oscuros) --- */
.tc-btn--inverted {
    background: var(--tc-gold);
    border-color: var(--tc-gold);
    color: var(--tc-navy);
}

.tc-btn--inverted:hover {
    background: #fff;
    border-color: #fff;
    color: var(--tc-navy);
}

/* --- Eyebrow --- */
.tc-eyebrow {
    color: var(--tc-gold);
    display: inline-block;
    font-family: var(--tc-font-body);
    font-size: var(--tc-text-xs);
    font-weight: 800;
    letter-spacing: 0.12em;
    margin-bottom: var(--tc-space-md);
    text-transform: uppercase;
}

/* --- Section Heading --- */
.tc-section-heading {
    margin-bottom: var(--tc-space-2xl);
}

.tc-section-heading h2 {
    color: var(--tc-ink);
    font-family: var(--tc-font-display);
    font-size: var(--tc-text-3xl);
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: var(--tc-space-md);
}

.tc-section-heading p {
    color: var(--tc-ink-soft);
    font-size: var(--tc-text-lg);
    max-width: 620px;
}

/* --- Card --- */
.tc-card {
    background: var(--tc-surface);
    border: 1px solid var(--tc-border);
    border-radius: var(--tc-radius-lg);
    box-shadow: var(--tc-shadow);
    overflow: hidden;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.4s ease,
                border-color 0.4s ease;
}

.tc-card:hover {
    border-color: var(--tc-border-gold);
    box-shadow: var(--tc-shadow-lg);
    transform: translateY(-6px);
}

/* --- Divider --- */
.tc-divider {
    background: linear-gradient(90deg, var(--tc-gold), var(--tc-gold-light), transparent);
    border: none;
    height: 2px;
    margin: var(--tc-space-xl) 0;
    max-width: 120px;
}

/* --- Gold Border Top --- */
.tc-gold-border-top {
    position: relative;
}

.tc-gold-border-top::before {
    background: linear-gradient(90deg, var(--tc-gold), var(--tc-gold-light));
    content: "";
    height: 3px;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}


/* --- Image Zoom --- */
.tc-img-zoom {
    overflow: hidden;
}

.tc-img-zoom img {
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.tc-img-zoom:hover img {
    transform: scale(1.05);
}

/* --- Reveal Animations --- */
.tc-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.tc-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.tc-reveal-delay-1 { transition-delay: 0.1s; }
.tc-reveal-delay-2 { transition-delay: 0.2s; }
.tc-reveal-delay-3 { transition-delay: 0.3s; }
.tc-reveal-delay-4 { transition-delay: 0.4s; }
.tc-reveal-delay-5 { transition-delay: 0.5s; }
.tc-reveal-delay-6 { transition-delay: 0.6s; }
