/* =============================================
   MAIN.CSS - Etiquetas Termoadhesivas
   Design System v4.0 — Clean Geometric
   ============================================= */

/* =============================================
   CSS CUSTOM PROPERTIES
   ============================================= */
:root {
    /* ---- BRAND COLORS (same palette) ---- */
    --primary: #0CBABA;
    --primary-light: #A8E6E6;
    --primary-lighter: #E0F7F7;
    --primary-dark: #099E9E;
    --primary-darker: #078282;

    --secondary: #FF6B6B;
    --secondary-light: #FFA8A8;
    --secondary-dark: #E85555;

    --accent: #F5A623;
    --accent-light: #FFD080;
    --accent-dark: #D4900F;

    --mint: #7FD8BE;
    --mint-light: #C4EDDF;

    /* ---- FONDOS ---- */
    --bg-white: #FFFFFF;
    --bg-warm: #FAFBFC;
    --bg-cream: #F3F4F6;
    --bg-soft-teal: #F0FAFA;
    --bg-soft-coral: #FFF5F5;
    --bg-gradient-hero: linear-gradient(160deg, #F0FAFA 0%, #FFFFFF 60%, #FFF5F5 100%);
    --bg-gradient-section: linear-gradient(180deg, #FAFBFC 0%, #F0FAFA 100%);

    /* ---- TEXTO ---- */
    --text-dark: #1A1D1F;
    --text-medium: #6F767E;
    --text-light: #9A9FA5;
    --text-on-primary: #FFFFFF;
    --text-on-dark: #E8ECEF;

    /* ---- ESTADO ---- */
    --success: #22C55E;
    --success-light: #ECFDF5;
    --warning: #F5A623;
    --warning-light: #FFFBEB;
    --error: #EF4444;
    --error-light: #FEF2F2;

    /* ---- GRADIENTES ---- */
    --gradient-primary: linear-gradient(135deg, #0CBABA 0%, #099E9E 100%);
    --gradient-warm: linear-gradient(135deg, #FF6B6B 0%, #F5A623 100%);
    --gradient-hero: linear-gradient(160deg, #0CBABA 0%, #7FD8BE 50%, #F5A623 100%);
    --gradient-cta: linear-gradient(135deg, #FF6B6B 0%, #E85555 100%);
    --gradient-topbar: linear-gradient(90deg, #1A1D1F 0%, #2D3436 100%);
    --gradient-footer: #1A1D1F;

    /* ---- TIPOGRAFÍA (nueva — geométrica + legible) ---- */
    --font-display: 'Outfit', sans-serif;
    --font-body: 'Source Sans 3', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* ---- SOMBRAS (neutras, no coloreadas) ---- */
    --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.12);
    --shadow-hover: 0 12px 32px rgba(0, 0, 0, 0.14);
    --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-card-hover: 0 4px 16px rgba(0, 0, 0, 0.1);
    --shadow-cta: 0 2px 8px rgba(255, 107, 107, 0.25);
    --shadow-cta-hover: 0 6px 20px rgba(255, 107, 107, 0.35);

    /* ---- BORDES (semi-angular) ---- */
    --radius-xs: 4px;
    --radius-sm: 6px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 9999px;

    --border-light: 1px solid #E8ECEF;
    --border-medium: 1px solid #D1D5DB;

    /* ---- TRANSICIONES ---- */
    --ease: cubic-bezier(0.25, 0.1, 0.25, 1);
    --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
    --transition-fast: 150ms var(--ease);
    --transition-base: 250ms var(--ease);
    --transition-slow: 400ms var(--ease);

    /* ---- LAYOUT ---- */
    --container-max: 1200px;
    --container-narrow: 800px;
    --header-height: 64px;
    --section-padding: 5rem 2rem;
}

/* =============================================
   RESET & BASE
   ============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-dark);
    background: var(--bg-white);
    overflow-x: hidden;
}

a { color: inherit; text-decoration: none; transition: var(--transition-fast); }
img { max-width: 100%; display: block; }
button { cursor: pointer; font-family: var(--font-body); }
.no-scroll { overflow: hidden !important; }

/* =============================================
   UTILITY: SECTION TITLES
   ============================================= */
.section-label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--primary);
    margin-bottom: 0.75rem;
}
.section-label::before {
    content: '';
    width: 24px;
    height: 2px;
    background: var(--primary);
}

.section-title {
    font-family: var(--font-display);
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--text-dark);
    letter-spacing: -0.5px;
    line-height: 1.2;
    text-align: center;
    margin-bottom: 0.75rem;
}
.section-title .highlight { color: var(--primary); }

.section-subtitle {
    text-align: center;
    font-size: 1.05rem;
    color: var(--text-medium);
    margin-bottom: 3rem;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* =============================================
   TOP INFO BAR (replaces old email-capture + announcement)
   ============================================= */
.top-info-bar {
    background: var(--text-dark);
    color: var(--text-on-dark);
    font-size: 0.78rem;
    padding: 0.45rem 1rem;
    letter-spacing: 0.3px;
}

.top-info-bar-inner {
    max-width: var(--container-max);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.top-info-left { display: flex; align-items: center; gap: 1.5rem; }
.top-info-left span { display: flex; align-items: center; gap: 0.35rem; opacity: 0.85; }

.top-info-right form { display: flex; gap: 0.35rem; }
.top-info-right input {
    padding: 0.3rem 0.7rem;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radius-xs);
    background: rgba(255,255,255,0.06);
    color: white;
    font-size: 0.78rem;
    font-family: var(--font-body);
    width: 180px;
    outline: none;
    transition: var(--transition-fast);
}
.top-info-right input::placeholder { color: rgba(255,255,255,0.35); }
.top-info-right input:focus { border-color: var(--primary); background: rgba(255,255,255,0.1); }

.top-info-right button {
    padding: 0.3rem 0.85rem;
    background: var(--primary);
    color: white;
    border: none;
    border-radius: var(--radius-xs);
    font-size: 0.75rem;
    font-weight: 600;
    transition: var(--transition-fast);
}
.top-info-right button:hover { background: var(--primary-dark); }

/* =============================================
   HEADER — Compact single-line
   ============================================= */
.main-header {
    background: var(--bg-white);
    border-bottom: var(--border-light);
    position: sticky;
    top: 0;
    z-index: 1000;
    height: var(--header-height);
    transition: box-shadow var(--transition-base);
}
.main-header.scrolled { box-shadow: var(--shadow-md); }

.nav-container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    height: 100%;
    gap: 2rem;
}

.logo-link { display: flex; align-items: center; flex-shrink: 0; }
.logo-link.logo-text {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-dark);
    letter-spacing: -0.3px;
}
.logo-image { height: 36px; width: auto; }

.nav-menu {
    display: flex;
    list-style: none;
    gap: 0.25rem;
    align-items: center;
}
.nav-menu a {
    display: block;
    padding: 0.45rem 0.85rem;
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-medium);
    border-radius: var(--radius-sm);
    transition: var(--transition-fast);
    letter-spacing: -0.1px;
}
.nav-menu a:hover { color: var(--text-dark); background: var(--bg-cream); }

.nav-spacer { flex: 1; }

.nav-actions { display: flex; align-items: center; gap: 0.5rem; }

.search-container { position: relative; }
.search-input {
    width: 180px;
    padding: 0.45rem 0.75rem 0.45rem 2.1rem;
    border: var(--border-light);
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 0.85rem;
    background: var(--bg-warm);
    color: var(--text-dark);
    outline: none;
    transition: var(--transition-fast);
}
.search-input:focus { border-color: var(--primary); background: white; width: 220px; }
.search-input::placeholder { color: var(--text-light); }
.search-icon {
    position: absolute;
    left: 0.65rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.82rem;
    color: var(--text-light);
    pointer-events: none;
}

.nav-action-btn {
    width: 36px; height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    font-size: 1rem;
    color: var(--text-medium);
    transition: var(--transition-fast);
    position: relative;
    background: none;
    border: none;
}
.nav-action-btn:hover { color: var(--primary); background: var(--bg-soft-teal); }

.cart-count {
    position: absolute;
    top: 2px; right: 2px;
    min-width: 16px; height: 16px;
    background: var(--secondary);
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 1.1rem;
    background: var(--secondary);
    color: white !important;
    font-size: 0.82rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-cta);
    transition: var(--transition-fast);
    white-space: nowrap;
}
.nav-cta:hover { transform: translateY(-1px); box-shadow: var(--shadow-cta-hover); }

.hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 0.5rem;
    background: none;
    border: none;
}
.hamburger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--text-dark);
    border-radius: 1px;
    transition: var(--transition-fast);
}

/* =============================================
   MOBILE MENU
   ============================================= */
.mobile-menu-overlay {
    display: none;
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(26, 29, 31, 0.4);
    z-index: 1100;
    opacity: 0;
    transition: opacity var(--transition-base);
    backdrop-filter: blur(2px);
}
.mobile-menu-overlay.active { opacity: 1; }

.mobile-menu-panel {
    position: fixed;
    top: 0; right: -100%;
    width: 320px;
    max-width: 85%;
    height: 100%;
    background: var(--bg-white);
    z-index: 1101;
    padding: 1.5rem;
    overflow-y: auto;
    transition: right 0.3s var(--ease);
    border-left: var(--border-light);
}
.mobile-menu-panel.active { right: 0; }

.mobile-menu-close {
    position: absolute;
    top: 1rem; right: 1rem;
    width: 32px; height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-cream);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 1.1rem;
    color: var(--text-medium);
    cursor: pointer;
}

.mobile-nav-list { list-style: none; margin-top: 3rem; }
.mobile-nav-list a {
    display: block;
    padding: 0.85rem 0;
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--text-dark);
    border-bottom: var(--border-light);
    transition: var(--transition-fast);
}
.mobile-nav-list a:hover { color: var(--primary); padding-left: 0.5rem; }

.mobile-menu-cta {
    display: block;
    margin-top: 1.5rem;
    padding: 0.85rem;
    text-align: center;
    background: var(--secondary);
    color: white;
    font-weight: 600;
    border-radius: var(--radius-sm);
}

/* =============================================
   HERO
   ============================================= */
.hero {
    background: var(--bg-gradient-hero);
    padding: 5rem 2rem 4rem;
    position: relative;
    overflow: hidden;
}
.hero::before {
    content: '';
    position: absolute;
    top: -30%; right: -5%;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(12, 186, 186, 0.06) 0%, transparent 70%);
    border-radius: 50%;
}

.hero-container {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.hero h1 {
    font-family: var(--font-display);
    font-size: 3rem;
    font-weight: 700;
    color: var(--text-dark);
    letter-spacing: -1px;
    line-height: 1.15;
    margin-bottom: 1.25rem;
}
.hero h1 .highlight {
    display: block;
    color: var(--primary);
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: 0;
    margin-top: 0.5rem;
}

.hero-subtitle {
    font-size: 1.1rem;
    color: var(--text-medium);
    margin-bottom: 2rem;
    line-height: 1.6;
}

.cta-group { display: flex; gap: 1rem; margin-bottom: 2.5rem; flex-wrap: wrap; }

.cta-primary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    background: var(--secondary);
    color: white;
    font-weight: 600;
    font-size: 1rem;
    border-radius: var(--radius-md);
    border: none;
    box-shadow: var(--shadow-cta);
    transition: var(--transition-base);
}
.cta-primary:hover { transform: translateY(-2px); box-shadow: var(--shadow-cta-hover); }

.cta-secondary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    background: transparent;
    color: var(--text-dark);
    font-weight: 600;
    font-size: 1rem;
    border: 2px solid #D1D5DB;
    border-radius: var(--radius-md);
    transition: var(--transition-base);
}
.cta-secondary:hover { border-color: var(--primary); color: var(--primary); }

.hero-trust-signals { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.trust-signal { display: flex; align-items: center; gap: 0.4rem; font-size: 0.88rem; color: var(--text-medium); font-weight: 500; }
.trust-signal-icon { font-size: 1.1rem; }

.hero-image-container { position: relative; }
.hero-image { width: 100%; max-width: 550px; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); object-fit: cover; }

.floating-badge {
    position: absolute;
    top: 1.5rem; right: 1.5rem;
    background: white;
    padding: 0.75rem 1rem;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    text-align: center;
    border-left: 3px solid var(--primary);
}
.floating-badge-number { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--primary); display: block; }
.floating-badge-text { font-size: 0.75rem; color: var(--text-light); font-weight: 600; }

/* =============================================
   SOCIAL PROOF BAR
   ============================================= */
.social-proof-bar {
    background: var(--primary);
    padding: 0.85rem 2rem;
    text-align: center;
    color: white;
    font-size: 0.95rem;
    font-weight: 500;
}
.social-proof-bar strong { font-size: 1.1rem; font-family: var(--font-display); }

/* =============================================
   PRODUCT CARDS
   ============================================= */
.product-card {
    background: var(--bg-white);
    border: var(--border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: var(--transition-base);
    position: relative;
}
.product-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); border-color: var(--primary-light); }

.product-badge {
    position: absolute;
    top: 12px; right: 12px;
    padding: 0.3rem 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: var(--radius-xs);
    z-index: 2;
}
.product-badge.bestseller { background: var(--accent); color: white; }
.product-badge.pack { background: var(--primary); color: white; }
.product-badge.business { background: var(--text-dark); color: white; }

.product-image-wrapper { height: 240px; overflow: hidden; background: var(--bg-cream); }
.product-image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s var(--ease); }
.product-card:hover .product-image { transform: scale(1.04); }

.product-content { padding: 1.25rem; }
.product-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; margin-bottom: 0.5rem; color: var(--text-dark); }
.product-rating { display: flex; align-items: center; gap: 0.4rem; margin-bottom: 0.75rem; }
.stars { color: var(--accent); font-size: 0.9rem; }
.reviews-count { color: var(--text-light); font-size: 0.8rem; }

.btn-product {
    display: block;
    width: 100%;
    text-align: center;
    padding: 0.7rem;
    background: var(--primary);
    color: white;
    font-weight: 600;
    font-size: 0.88rem;
    border-radius: var(--radius-sm);
    border: none;
    transition: var(--transition-fast);
}
.btn-product:hover { background: var(--primary-dark); }

/* =============================================
   BENEFITS
   ============================================= */
.benefits-section { padding: var(--section-padding); background: var(--bg-white); }

.benefits-grid {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.benefit-card {
    padding: 1.75rem 1.5rem;
    border: var(--border-light);
    border-radius: var(--radius-md);
    transition: var(--transition-base);
    border-top: 3px solid transparent;
}
.benefit-card:hover { border-top-color: var(--primary); box-shadow: var(--shadow-card); }

.benefit-icon { font-size: 2rem; margin-bottom: 0.75rem; display: block; }
.benefit-title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 600; margin-bottom: 0.4rem; }
.benefit-description { font-size: 0.88rem; color: var(--text-medium); line-height: 1.5; }

/* =============================================
   USE CASES
   ============================================= */
.use-cases-section { padding: var(--section-padding); background: var(--bg-gradient-section); }

.cases-grid {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
.case-card { background: var(--bg-white); border: var(--border-light); border-radius: var(--radius-lg); overflow: hidden; transition: var(--transition-base); }
.case-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }

.case-image-wrapper { height: 200px; overflow: hidden; position: relative; }
.case-image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s var(--ease); }
.case-card:hover .case-image { transform: scale(1.04); }
.case-icon { font-size: 3rem; }

.case-content { padding: 1.25rem; }
.case-content h3 { font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; margin-bottom: 0.5rem; }
.case-content p { font-size: 0.88rem; color: var(--text-medium); margin-bottom: 0.75rem; }
.case-benefits { list-style: none; margin-bottom: 1rem; }
.case-benefits li { font-size: 0.85rem; font-weight: 500; margin-bottom: 0.3rem; }
.case-cta { font-size: 0.85rem; font-weight: 600; color: var(--primary); }
.case-cta:hover { color: var(--primary-dark); }

/* =============================================
   HOW IT WORKS / STEPS
   ============================================= */
.steps-grid {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}
.step-card {
    text-align: center;
    padding: 2rem 1.5rem;
    position: relative;
    counter-increment: step;
}
.step-card::before {
    content: counter(step);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px; height: 48px;
    margin: 0 auto 1rem;
    background: var(--primary-lighter);
    color: var(--primary-dark);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.25rem;
    border-radius: var(--radius-md);
}
.step-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; margin-bottom: 0.5rem; }
.step-description { font-size: 0.88rem; color: var(--text-medium); line-height: 1.5; }

/* =============================================
   REVIEWS
   ============================================= */
.reviews-section { padding: var(--section-padding); background: var(--bg-warm); }

.reviews-carousel-container { max-width: var(--container-max); margin: 0 auto; overflow: hidden; position: relative; }
.reviews-track { display: flex; gap: 1.5rem; transition: transform 0.5s var(--ease); }

.review-card {
    background: var(--bg-white);
    border: var(--border-light);
    padding: 1.5rem;
    border-radius: var(--radius-md);
    min-width: calc(33.333% - 1rem);
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
}
.review-stars { color: var(--accent); font-size: 0.95rem; margin-bottom: 0.75rem; }
.review-text { font-size: 0.9rem; font-style: italic; color: var(--text-dark); flex-grow: 1; line-height: 1.6; margin-bottom: 1rem; }
.review-author { font-weight: 600; font-size: 0.88rem; }
.review-date { font-size: 0.78rem; color: var(--text-light); margin-top: 0.25rem; }
.review-verified { font-size: 0.78rem; color: var(--success); font-weight: 600; margin-top: 0.35rem; }

.carousel-controls { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-top: 2rem; }
.carousel-btn {
    width: 40px; height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: var(--border-light);
    border-radius: var(--radius-sm);
    background: white;
    font-size: 1.1rem;
    color: var(--text-medium);
    transition: var(--transition-fast);
}
.carousel-btn:hover:not(:disabled) { background: var(--primary); color: white; border-color: var(--primary); }
.carousel-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.carousel-dots { display: flex; gap: 0.4rem; }
.carousel-dot {
    width: 8px; height: 8px;
    border-radius: var(--radius-full);
    border: none;
    background: var(--bg-cream);
    cursor: pointer;
    transition: var(--transition-fast);
    padding: 0;
}
.carousel-dot.active { background: var(--primary); width: 24px; }

/* =============================================
   FAQ
   ============================================= */
.faq-section { padding: var(--section-padding); background: var(--bg-white); }
.faq-container { max-width: var(--container-narrow); margin: 0 auto; }

.faq-item { border: var(--border-light); border-radius: var(--radius-md); margin-bottom: 0.5rem; overflow: hidden; transition: var(--transition-fast); }
.faq-item:hover { border-color: var(--primary-light); }

.faq-question {
    width: 100%;
    padding: 1rem 1.25rem;
    background: var(--bg-white);
    border: none;
    text-align: left;
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-dark);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: var(--transition-fast);
}
.faq-question:hover { color: var(--primary); }

.faq-icon {
    width: 24px; height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-xs);
    background: var(--bg-cream);
    font-size: 0.85rem;
    transition: var(--transition-fast);
    flex-shrink: 0;
}
.faq-item.active .faq-icon { transform: rotate(45deg); background: var(--primary); color: white; }

.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s var(--ease), padding 0.3s var(--ease); }
.faq-item.active .faq-answer { max-height: 500px; padding: 0 1.25rem 1.25rem; }
.faq-answer-content { font-size: 0.9rem; color: var(--text-medium); line-height: 1.7; }

/* =============================================
   FINAL CTA
   ============================================= */
.final-cta {
    padding: 4.5rem 2rem;
    background: var(--text-dark);
    text-align: center;
    color: white;
    position: relative;
    overflow: hidden;
}
.final-cta::before {
    content: '';
    position: absolute;
    bottom: -20%; right: -10%;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(12,186,186,0.15) 0%, transparent 70%);
    border-radius: 50%;
}
.final-cta h2 { font-family: var(--font-display); font-size: 2.5rem; font-weight: 700; margin-bottom: 1rem; position: relative; letter-spacing: -0.5px; }
.final-cta p { font-size: 1.1rem; margin-bottom: 2rem; opacity: 0.8; position: relative; max-width: 600px; margin-left: auto; margin-right: auto; }

.final-cta-buttons { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; position: relative; }
.cta-final-primary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 2rem;
    background: var(--secondary);
    color: white;
    font-weight: 600;
    font-size: 1rem;
    border-radius: var(--radius-md);
    transition: var(--transition-base);
    box-shadow: var(--shadow-cta);
}
.cta-final-primary:hover { transform: translateY(-2px); box-shadow: var(--shadow-cta-hover); }

.cta-final-secondary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 2rem;
    color: white;
    font-weight: 500;
    font-size: 1rem;
    border: 1px solid rgba(255,255,255,0.3);
    border-radius: var(--radius-md);
    transition: var(--transition-base);
}
.cta-final-secondary:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.5); }

.final-trust { margin-top: 1.5rem; font-size: 0.85rem; opacity: 0.6; position: relative; }

/* =============================================
   FOOTER — 2 columns, compact
   ============================================= */
.site-footer {
    background: var(--text-dark);
    color: var(--text-on-dark);
    padding: 3rem 2rem 1.5rem;
    border-top: 3px solid var(--primary);
}

.footer-main {
    max-width: var(--container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
}

.footer-logo { height: 32px; width: auto; margin-bottom: 1rem; filter: brightness(0) invert(1); }
.footer-brand-name {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 700;
    color: white;
    margin-bottom: 1rem;
}
.footer-tagline { font-size: 0.88rem; color: rgba(255,255,255,0.6); line-height: 1.5; margin-bottom: 1.25rem; max-width: 360px; }

.footer-contact { display: flex; flex-direction: column; gap: 0.5rem; }
.footer-contact-row { display: flex; align-items: center; gap: 0.5rem; font-size: 0.85rem; color: rgba(255,255,255,0.65); }
.footer-contact-row a { color: rgba(255,255,255,0.65); }
.footer-contact-row a:hover { color: var(--primary-light); }

.footer-social { display: flex; gap: 0.6rem; margin-top: 1rem; }
.social-link {
    width: 32px; height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radius-xs);
    color: rgba(255,255,255,0.6);
    font-size: 0.9rem;
    transition: var(--transition-fast);
}
.social-link:hover { background: var(--primary); color: white; border-color: var(--primary); }

.footer-links-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2rem;
}
.footer-links-group h5 {
    font-family: var(--font-display);
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.4);
    margin-bottom: 0.75rem;
}
.footer-links-group ul { list-style: none; }
.footer-links-group li { margin-bottom: 0.4rem; }
.footer-links-group a { font-size: 0.85rem; color: rgba(255,255,255,0.6); transition: var(--transition-fast); }
.footer-links-group a:hover { color: var(--primary-light); }

.footer-bottom {
    max-width: var(--container-max);
    margin: 2rem auto 0;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
}
.footer-copyright { font-size: 0.78rem; color: rgba(255,255,255,0.35); }
.footer-legal-links { display: flex; gap: 1.25rem; }
.footer-legal-links a { font-size: 0.78rem; color: rgba(255,255,255,0.35); }
.footer-legal-links a:hover { color: var(--primary-light); }

.footer-payments { display: flex; gap: 0.4rem; }
.payment-badge {
    background: rgba(255,255,255,0.06);
    padding: 0.2rem 0.5rem;
    border-radius: var(--radius-xs);
    font-size: 0.7rem;
    color: rgba(255,255,255,0.45);
    border: 1px solid rgba(255,255,255,0.08);
}

/* =============================================
   WHATSAPP
   ============================================= */
.whatsapp-float {
    position: fixed;
    bottom: 1.5rem; right: 1.5rem;
    width: 52px; height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #25D366;
    border-radius: var(--radius-md);
    color: white;
    font-size: 1.5rem;
    z-index: 999;
    box-shadow: 0 4px 16px rgba(37, 211, 102, 0.35);
    transition: var(--transition-base);
}
.whatsapp-float:hover { transform: scale(1.08); box-shadow: 0 8px 24px rgba(37, 211, 102, 0.45); color: white; }

.whatsapp-tooltip {
    position: absolute;
    right: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    background: var(--text-dark);
    color: white;
    padding: 0.4rem 0.8rem;
    border-radius: var(--radius-xs);
    font-size: 0.78rem;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-fast);
}
.whatsapp-float:hover .whatsapp-tooltip { opacity: 1; }

/* =============================================
   LEGAL PAGES
   ============================================= */
.legal-page { padding: 3rem 2rem; background: var(--bg-warm); min-height: 60vh; }
.legal-container { max-width: var(--container-narrow); margin: 0 auto; background: white; padding: 3rem; border-radius: var(--radius-lg); border: var(--border-light); }
.legal-header { margin-bottom: 2.5rem; padding-bottom: 1.5rem; border-bottom: var(--border-light); }
.legal-header h1 { font-family: var(--font-display); font-size: 2rem; font-weight: 700; letter-spacing: -0.5px; }
.legal-header p { font-size: 0.85rem; color: var(--text-light); margin-top: 0.5rem; }
.legal-section { margin-bottom: 2rem; }
.legal-section h2 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 600; margin-bottom: 0.75rem; }
.legal-section p { font-size: 0.92rem; color: var(--text-medium); line-height: 1.7; margin-bottom: 0.75rem; }
.legal-section ul { margin-left: 1.5rem; margin-bottom: 1rem; }
.legal-section li { font-size: 0.92rem; color: var(--text-medium); line-height: 1.7; margin-bottom: 0.4rem; }
.legal-section a { color: var(--primary); font-weight: 500; }
.legal-section a:hover { text-decoration: underline; }
.legal-info-box { background: var(--bg-warm); border-left: 3px solid var(--primary); padding: 1.25rem; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; margin-bottom: 1rem; }
.legal-info-box p { margin-bottom: 0.4rem; }
.legal-back-link { display: inline-flex; align-items: center; gap: 0.3rem; margin-top: 2rem; font-size: 0.9rem; font-weight: 600; color: var(--primary); }
.legal-back-link:hover { gap: 0.5rem; }

.cookie-table { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: 0.85rem; }
.cookie-table th { background: var(--bg-cream); padding: 0.6rem 0.75rem; text-align: left; font-weight: 600; border-bottom: 2px solid var(--primary-light); }
.cookie-table td { padding: 0.6rem 0.75rem; border-bottom: var(--border-light); }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1024px) {
    :root { --section-padding: 3.5rem 1.5rem; }
    .nav-menu { display: none; }
    .hamburger { display: flex; }
    .search-container { display: none; }
    .nav-cta { display: none; }
    .hero-container { gap: 2rem; }
    .hero h1 { font-size: 2.4rem; }
    .benefits-grid { grid-template-columns: repeat(2, 1fr); }
    .cases-grid { grid-template-columns: repeat(2, 1fr); }
    .steps-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
    .review-card { min-width: calc(50% - 0.75rem); }
    .footer-links-col { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
}

@media (max-width: 768px) {
    :root { --section-padding: 3rem 1.25rem; }

    .top-info-bar-inner { flex-direction: column; gap: 0.4rem; text-align: center; }
    .top-info-left { flex-wrap: wrap; justify-content: center; gap: 0.75rem; }
    .top-info-right { width: 100%; }
    .top-info-right form { justify-content: center; }

    .nav-container { padding: 0 1rem; }
    .logo-image { height: 30px; }

    .hero { padding: 3rem 1.25rem; }
    .hero-container { grid-template-columns: 1fr; text-align: center; }
    .hero h1 { font-size: 2rem; }
    .hero h1 .highlight { font-size: 1.1rem; }
    .hero-trust-signals { justify-content: center; }
    .hero-image-container { order: -1; max-width: 400px; margin: 0 auto; }
    .cta-group { justify-content: center; }

    .section-title { font-size: 1.75rem; }
    .benefits-grid { grid-template-columns: 1fr; }
    .cases-grid { grid-template-columns: 1fr; }
    .steps-grid { grid-template-columns: 1fr; gap: 1rem; }
    .review-card { min-width: 100%; }

    .final-cta h2 { font-size: 1.8rem; }
    .final-cta-buttons { flex-direction: column; align-items: center; }

    .footer-main { grid-template-columns: 1fr; gap: 2rem; }
    .footer-links-col { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
    .footer-bottom { flex-direction: column; text-align: center; }
    .footer-legal-links { flex-wrap: wrap; justify-content: center; }

    .whatsapp-float { bottom: 1rem; right: 1rem; width: 46px; height: 46px; }
    .legal-container { padding: 1.5rem; }
}

@media (max-width: 480px) {
    .hero h1 { font-size: 1.65rem; }
    .footer-links-col { grid-template-columns: 1fr 1fr; }
    .top-info-left span:nth-child(3) { display: none; }
}

@media print {
    .top-info-bar, .main-header, .whatsapp-float, .site-footer, .final-cta { display: none !important; }
    body { font-size: 12pt; color: #000; }
}
