/**
 * KAZOFI HOME v2 — Mejoras visuales
 * Tipografía · Contraste · Espaciado · Cards · Botones
 */

/* ══ HERO — imagen real + overlay CSS ══ */
.elementor-section:has(.kzn-hero-content) {
    background-image:
        linear-gradient(rgba(8,18,40,0.62), rgba(8,18,40,0.62)),
        url('https://new.kazofi.online/wp-content/uploads/2026/03/kazofi-hero-bg.jpg') !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    position: relative;
}

.elementor-section .kzn-hero-content {
    position: relative;
}
.elementor-section:has(.kzn-hero-content) .elementor-container {
    position: relative;
    z-index: 2;
}

/* Hero content upgrade */
.kzn-hero-content {
    max-width: 860px;
    margin: 0 auto;
    text-align: center;
    padding: 0 24px;
}
.kzn-hero-eyebrow {
    display: inline-block;
    background: rgba(0,200,83,.2);
    border: 1px solid rgba(0,200,83,.4);
    color: #7bffb2;
    padding: 7px 22px;
    border-radius: 50px;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: 28px;
}
.kzn-hero-title {
    font-family: 'Manrope', sans-serif !important;
    font-size: clamp(2.2rem, 6vw, 4.5rem) !important;
    font-weight: 900 !important;
    color: #ffffff !important;
    line-height: 1.05 !important;
    letter-spacing: -.03em;
    margin: 0 0 22px !important;
    text-transform: uppercase;
    text-shadow: 0 4px 24px rgba(0,0,0,.4);
}
.kzn-hero-sub {
    font-size: clamp(1rem, 2.5vw, 1.25rem);
    color: rgba(255,255,255,.88);
    line-height: 1.65;
    margin: 0 0 40px;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.kzn-hero-sub strong {
    color: #5dff9b;
    font-weight: 800;
}
.kzn-hero-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: linear-gradient(135deg, #00e676, #00C853);
    color: #003318 !important;
    text-decoration: none !important;
    padding: 20px 56px;
    border-radius: 50px;
    font-size: 1.08rem;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
    box-shadow: 0 8px 32px rgba(0,200,83,.55), 0 2px 8px rgba(0,0,0,.2);
    transition: all .25s ease;
    margin-bottom: 32px;
}
.kzn-hero-cta:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 14px 44px rgba(0,200,83,.7);
    background: linear-gradient(135deg, #69ff9e, #00e676);
}
.kzn-hero-badges {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
    font-size: .8rem;
    color: rgba(255,255,255,.65);
    font-weight: 600;
    letter-spacing: .04em;
}
.kzn-hero-badges span::before { content: '✓ '; color: #00C853; }

@media (max-width: 480px) {
    .kzn-hero-cta { padding: 18px 32px; width: 100%; font-size: .95rem; }
    .kzn-hero-badges { gap: 12px; font-size: .72rem; }
}

/* ══ WC PRODUCT CARDS — Mejora visual completa ══════════════ */

/* Reset WC default margins */
.woocommerce ul.products,
.elementor-widget-shortcode .woocommerce ul.products,
.elementor-widget-woocommerce-products ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.woocommerce ul.products li.product,
.elementor-widget-shortcode .woocommerce ul.products li.product {
    background: #fff !important;
    border-radius: 16px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04) !important;
    overflow: hidden !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    position: relative !important;
}
.woocommerce ul.products li.product:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 12px 40px rgba(0,0,0,.13) !important;
}

/* Product image */
.woocommerce ul.products li.product a:first-child {
    display: block !important;
    overflow: hidden !important;
    position: relative !important;
}
.woocommerce ul.products li.product a:first-child img,
.woocommerce ul.products li.product .woocommerce-loop-product__link img {
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
    transition: transform .4s ease !important;
}
.woocommerce ul.products li.product:hover img {
    transform: scale(1.07) !important;
}

/* No image placeholder */
.woocommerce ul.products li.product a:first-child img[src*="woocommerce-placeholder"] {
    object-fit: contain !important;
    background: #f4f6f8 !important;
    padding: 20px !important;
}

/* Card info area */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
    padding: 14px 16px 6px !important;
    font-family: 'Manrope', sans-serif !important;
    font-size: .92rem !important;
    font-weight: 700 !important;
    color: #1a1a2e !important;
    line-height: 1.35 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* Price */
.woocommerce ul.products li.product .price {
    padding: 4px 16px 8px !important;
    font-size: 1.05rem !important;
    font-weight: 900 !important;
    color: #1a1a2e !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    margin: 0 !important;
}
.woocommerce ul.products li.product .price ins {
    text-decoration: none !important;
    color: #00962E !important;
    font-size: 1.1rem !important;
}
.woocommerce ul.products li.product .price del {
    color: #9ca3af !important;
    font-size: .82rem !important;
    font-weight: 400 !important;
}

/* Rating stars */
.woocommerce ul.products li.product .star-rating {
    padding: 0 16px 6px !important;
    font-size: .8rem !important;
}

/* ADD TO CART — full width */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.woocommerce ul.products li.product a.button {
    display: block !important;
    width: calc(100% - 32px) !important;
    margin: auto 16px 16px !important;
    margin-top: auto !important;
    text-align: center !important;
    padding: 13px 16px !important;
    background: linear-gradient(135deg, #00C853, #00962E) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    font-weight: 800 !important;
    font-size: .88rem !important;
    text-transform: uppercase !important;
    letter-spacing: .04em !important;
    transition: all .2s ease !important;
    cursor: pointer !important;
    font-family: 'Inter', sans-serif !important;
}
.woocommerce ul.products li.product .button:hover {
    background: linear-gradient(135deg, #00e665, #00C853) !important;
    transform: none !important;
    box-shadow: 0 4px 16px rgba(0,200,83,.45) !important;
    color: #fff !important;
}

/* Sale badge */
.woocommerce span.onsale {
    background: #ef4444 !important;
    color: #fff !important;
    border-radius: 8px !important;
    font-size: .7rem !important;
    font-weight: 800 !important;
    padding: 4px 10px !important;
    min-width: auto !important;
    min-height: auto !important;
    line-height: 1.4 !important;
    top: 10px !important;
    left: 10px !important;
    right: auto !important;
    text-transform: uppercase !important;
    letter-spacing: .04em !important;
}

/* ── Responsive product grid ── */
@media (max-width: 1100px) {
    .woocommerce ul.products,
    .elementor-widget-shortcode .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 768px) {
    .woocommerce ul.products,
    .elementor-widget-shortcode .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
}
@media (max-width: 400px) {
    .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .82rem !important; }
    .woocommerce ul.products li.product .price { font-size: .9rem !important; }
}

/* ══ CATEGORY GRID — upgrade ════════════════════════════════ */
.kzn-catgrid {
    display: grid !important;
    grid-template-columns: repeat(6, 1fr) !important;
    gap: 14px !important;
}
@media (max-width: 1024px) { .kzn-catgrid { grid-template-columns: repeat(3, 1fr) !important; } }
@media (max-width: 600px)  { .kzn-catgrid { grid-template-columns: repeat(2, 1fr) !important; } }

.kzn-catcard {
    aspect-ratio: 3 / 4 !important;
    border-radius: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-end !important;
    padding: 20px 14px !important;
    text-decoration: none !important;
    overflow: hidden !important;
    transition: transform .3s ease, box-shadow .3s ease !important;
    box-shadow: 0 6px 24px rgba(0,0,0,.2) !important;
    position: relative !important;
}
.kzn-catcard:hover {
    transform: translateY(-5px) scale(1.02) !important;
    box-shadow: 0 14px 40px rgba(0,0,0,.3) !important;
}
.kzn-catcard-name {
    font-family: 'Manrope', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 800 !important;
    color: #fff !important;
    text-align: center !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.6) !important;
    line-height: 1.25 !important;
    position: relative !important;
    z-index: 2 !important;
}
.kzn-catcard-count {
    font-size: .72rem !important;
    color: rgba(255,255,255,.85) !important;
    font-weight: 600 !important;
    margin-top: 4px !important;
    text-shadow: 0 1px 6px rgba(0,0,0,.6) !important;
    position: relative !important;
    z-index: 2 !important;
}

/* ══ SECTION TITLE UPGRADE ══════════════════════════════════ */
.kzn-section-title {
    font-size: 2.1rem !important;
    font-weight: 900 !important;
    letter-spacing: -.02em !important;
    color: #0f172a !important;
    margin: 0 !important;
    line-height: 1.15 !important;
}
.kzn-section-eyebrow {
    font-size: .72rem !important;
    font-weight: 800 !important;
    color: #00962E !important;
    text-transform: uppercase !important;
    letter-spacing: .14em !important;
    margin-bottom: 6px !important;
}
.kzn-section-link {
    font-size: .88rem !important;
    font-weight: 700 !important;
    color: #00962E !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    border-bottom: 1.5px solid #00C853 !important;
    padding-bottom: 2px !important;
    transition: all .2s !important;
}
.kzn-section-link:hover { color: #005c1c !important; }

.kzn-section-header {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    margin-bottom: 32px !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
}

/* ══ AUTHORITY — numbers bigger ═════════════════════════════ */
.kzn-stat-num {
    font-size: 2.2rem !important;
    font-weight: 900 !important;
    color: #00C853 !important;
    font-family: 'Manrope', sans-serif !important;
}
.kzn-authority-title {
    font-size: clamp(1.7rem, 4vw, 2.8rem) !important;
    font-weight: 900 !important;
    line-height: 1.15 !important;
    color: #fff !important;
    margin: 0 0 20px !important;
}
.kzn-authority-title span { color: #00e676 !important; }

/* ══ BENEFIT CARDS — espaciado mejorado ═════════════════════ */
.kzn-benefit-card {
    padding: 40px 32px !important;
    border-radius: 20px !important;
    box-shadow: 0 4px 24px rgba(0,0,0,.07) !important;
    height: 100% !important;
    transition: all .25s ease !important;
}
.kzn-benefit-icon-lg {
    font-size: 3.2rem !important;
    margin-bottom: 18px !important;
}
.kzn-benefit-title {
    font-size: 1.15rem !important;
    font-weight: 800 !important;
    margin-bottom: 10px !important;
    color: #0f172a !important;
}
.kzn-benefit-desc {
    font-size: .9rem !important;
    line-height: 1.7 !important;
    color: #64748b !important;
}

/* ══ SPACING — reducir espacios vacíos ══════════════════════ */
.elementor-section {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* Eliminar padding extra por defecto de Elementor */
.elementor-column > .elementor-widget-wrap {
    padding: 0 !important;
}
.elementor-widget:not(:last-child) {
    margin-bottom: 0 !important;
}

/* ══ SOCIAL STRIP upgrade ════════════════════════════════════ */
.kzn-social-strip {
    border-top: 1px solid #f0f0f0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
}
.kzn-social-num {
    font-size: 1.7rem !important;
    font-weight: 900 !important;
    color: #00962E !important;
}
.kzn-social-text { font-size: .9rem !important; color: #374151 !important; }

/* ══ TOP BAR — tighter ══════════════════════════════════════ */
.kzn-topbar-item { font-size: .8rem !important; }

/* ══ HEADER — mejorado ══════════════════════════════════════ */
.kzn-logo-text {
    font-size: 1.7rem !important;
    font-weight: 900 !important;
    letter-spacing: -.04em !important;
}

/* ══ GLOBAL TYPOGRAPHY ══════════════════════════════════════ */
body { font-family: 'Inter', system-ui, sans-serif !important; }
h1, h2, h3, h4 { font-family: 'Manrope', sans-serif !important; }

.elementor-heading-title {
    font-family: 'Manrope', sans-serif !important;
}
.elementor-widget-heading h1.elementor-heading-title { font-size: clamp(2rem, 5vw, 3.5rem) !important; font-weight: 900 !important; }
.elementor-widget-heading h2.elementor-heading-title { font-size: clamp(1.5rem, 3.5vw, 2.2rem) !important; font-weight: 800 !important; }
.elementor-widget-heading h3.elementor-heading-title { font-size: clamp(1.1rem, 2.5vw, 1.4rem) !important; font-weight: 700 !important; }

/* ══ CTA BUTTON final ═══════════════════════════════════════ */
.kzn-cta-big-btn {
    display: inline-flex !important;
    background: linear-gradient(135deg, #00C853, #00962E) !important;
    color: #fff !important;
    text-decoration: none !important;
    padding: 18px 52px !important;
    border-radius: 50px !important;
    font-size: 1rem !important;
    font-weight: 800 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    box-shadow: 0 6px 24px rgba(0,200,83,.4) !important;
    transition: all .25s ease !important;
}
.kzn-cta-big-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 32px rgba(0,200,83,.6) !important;
    color: #fff !important;
}

/* ══ MOBILE FULL EXPERIENCE ══════════════════════════════════ */
@media (max-width: 480px) {
    .kzn-catgrid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .kzn-catcard { aspect-ratio: 1 / 1 !important; }
    .kzn-authority-stats { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
    .kzn-stat-num { font-size: 1.6rem !important; }
    .kzn-benefit-card { padding: 28px 20px !important; }
    .kzn-cta-big-btn { width: 100% !important; padding: 18px !important; }
}
