/*
Theme Name:   CIMADERA — Astra Child
Theme URI:    https://cimadera.net
Description:  Child theme de Astra para CIMADERA S.A — Fabrica de aberturas de madera y aluminio. Brand v1.1.
Author:       CIMADERA S.A
Author URI:   https://cimadera.net
Template:     astra
Version:      1.6.5
License:      GPL-2.0-or-later
License URI:  https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  astra-child
*/

/* ===== LOGO + HERO — override v1.6.5 ===== */

/* Logo del header: 220px de ancho, max-height 80px (mismo ancho aprox que boton CTA) */
.custom-logo-link img,
.custom-logo {
    height: auto !important;
    max-height: 80px !important;
    width: 220px !important;
    max-width: 220px !important;
    object-fit: contain !important;
}

.custom-logo-link {
    display: inline-flex !important;
    align-items: center !important;
}

/* Ocultar texto del nombre del sitio y descripcion (junto al logo) */
.site-title { display: none !important; }
.site-description { display: none !important; }

/* Hero text: sin fondo en el contenedor; text-shadow base en titulares */
.wp-block-cover__inner-container {
    background: none !important;
}
.wp-block-cover__inner-container h1,
.wp-block-cover__inner-container h2,
.wp-block-cover__inner-container p {
    text-shadow: 2px 2px 8px rgba(0,0,0,0.9),
                 0 0 20px rgba(0,0,0,0.8) !important;
}

/* Subtitulo del hero (p): legible sobre cualquier foto, mas peso visual */
.wp-block-cover__inner-container p {
    color: #ffffff !important;
    text-shadow: 2px 2px 10px rgba(0,0,0,1),
                 0 0 30px rgba(0,0,0,1) !important;
    font-weight: 600 !important;
    font-size: 1.1rem !important;
}

/* ===== BRAND TOKENS ===== */
:root {
    --cm-blue:       #00ADEF;
    --cm-blue-deep:  #008FC4;
    --cm-blue-dark:  #006A93;
    --cm-dark:       #1A1A1A;
    --cm-gray:       #4A4A4A;
    --cm-bg:         #FFFFFF;
    --cm-soft:       #F2F2F2;
    --cm-wood:       #8B6C3E;
    --cm-line:       #E5E5E5;

    --cm-wa:         #25D366;
    --cm-wa-deep:    #1FAA52;

    --cm-font-display: "Barlow Condensed", "Inter", system-ui, -apple-system, sans-serif;
    --cm-font-body:    "Inter", system-ui, -apple-system, sans-serif;
}

/* ===== TIPOGRAFIA ===== */
body {
    background-color: var(--cm-bg);
    color: var(--cm-dark);
    font-family: var(--cm-font-body);
    font-feature-settings: "kern", "liga", "calt";
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6,
.entry-title, .ast-archive-title {
    font-family: var(--cm-font-display);
    color: var(--cm-dark);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.01em;
    line-height: 1.05;
}

h1 { font-size: clamp(2.4rem, 5vw, 4rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.55rem); }
h4 { font-size: 1.05rem; letter-spacing: 0.06em; }

p, li { font-family: var(--cm-font-body); color: var(--cm-gray); line-height: 1.65; }

a { color: var(--cm-blue); transition: color .15s ease; }
a:hover, a:focus { color: var(--cm-blue-deep); }

/* ===== BOTONES ===== */
.wp-block-button__link,
.ast-button,
button.wp-block-search__button {
    background-color: var(--cm-blue);
    color: #fff;
    font-family: var(--cm-font-display);
    font-weight: 700;
    border-radius: 4px;
    border: 0;
    padding: 14px 28px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    transition: background-color .2s ease, transform .15s ease;
}
.wp-block-button__link:hover,
.ast-button:hover {
    background-color: var(--cm-blue-deep);
    transform: translateY(-1px);
    color: #fff;
}

.is-style-outline .wp-block-button__link {
    background: transparent;
    color: var(--cm-blue);
    border: 2px solid var(--cm-blue);
}
.is-style-outline .wp-block-button__link:hover {
    background: var(--cm-blue);
    color: #fff;
}

/* CTA WhatsApp */
.cm-cta-wa .wp-block-button__link,
a.wp-block-button__link.cm-wa {
    background-color: var(--cm-wa);
    padding: 18px 36px;
    font-size: 1.05rem;
}
.cm-cta-wa .wp-block-button__link:hover,
a.wp-block-button__link.cm-wa:hover { background-color: var(--cm-wa-deep); }

/* ===== HERO ===== */
.cm-hero .wp-block-cover__inner-container { max-width: 1100px; }
.cm-hero h1 {
    color: #fff !important;
    text-shadow: 0 2px 16px rgba(0,0,0,.5);
}
.cm-hero p.cm-subtitle {
    color: #fff;
    font-family: var(--cm-font-body);
    font-size: 1.15rem;
    letter-spacing: 0.01em;
    text-shadow: 0 1px 8px rgba(0,0,0,.5);
    margin-bottom: 1.5rem;
}

/* ===== TAGLINE STRIP ===== */
.cm-tagline-strip {
    background: var(--cm-blue);
    color: #fff;
    text-align: center;
    padding: 18px 16px;
}
.cm-tagline-strip p {
    font-family: var(--cm-font-display);
    font-size: clamp(1rem, 2vw, 1.4rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin: 0;
    color: #fff;
}

/* ===== PILARES DE CLIENTE ===== */
.cm-pilar {
    background: #fff;
    border: 1px solid var(--cm-line);
    border-top: 4px solid var(--cm-blue);
    border-radius: 4px;
    padding: 32px 28px;
    height: 100%;
    transition: transform .2s ease, box-shadow .2s ease;
}
.cm-pilar:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 32px rgba(0,0,0,.08);
}
.cm-pilar h3 {
    margin: 0 0 12px;
    color: var(--cm-dark);
    font-size: 1.35rem;
}
.cm-pilar .cm-pilar-meta {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: .72rem;
    color: var(--cm-blue);
    margin: 0 0 6px;
    font-weight: 600;
}
.cm-pilar p { color: var(--cm-gray); margin-bottom: 0; }

/* ===== LINEAS DE PRODUCTO ===== */
.cm-linea {
    background: var(--cm-soft);
    border-radius: 4px;
    padding: 30px 26px;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.cm-linea h3 {
    color: var(--cm-dark);
    margin: 0 0 18px;
    padding-bottom: 12px;
    border-bottom: 3px solid var(--cm-blue);
    display: inline-block;
    align-self: flex-start;
}
.cm-linea ul {
    list-style: none;
    padding: 0;
    margin: 0 0 22px 0;
    flex-grow: 1;
}
.cm-linea li {
    padding: 8px 0 8px 22px;
    border-bottom: 1px solid var(--cm-line);
    color: var(--cm-gray);
    font-size: .95rem;
    position: relative;
}
.cm-linea li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 14px;
    width: 10px; height: 2px;
    background: var(--cm-blue);
}
.cm-linea li:last-child { border-bottom: 0; }
.cm-linea .wp-block-button__link { align-self: flex-start; }

/* ===== VENTAJAS ===== */
.cm-feature {
    padding: 24px;
    border-left: 3px solid var(--cm-blue);
    background: #fff;
    border-radius: 0 4px 4px 0;
    height: 100%;
}
.cm-feature h4 {
    margin: 0 0 10px;
    color: var(--cm-dark);
    font-size: 1.05rem;
}
.cm-feature p { color: var(--cm-gray); margin-bottom: 0; font-size: .95rem; }

/* ===== ISO TRUST BAND ===== */
.cm-iso-band {
    background: var(--cm-dark);
    color: #fff;
    padding: 56px 16px;
    text-align: center;
}
.cm-iso-band h2 {
    font-family: var(--cm-font-display);
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    color: #fff;
    margin: 0 0 12px;
}
.cm-iso-band .cm-iso-cert { color: var(--cm-blue); }
.cm-iso-band p {
    color: rgba(255,255,255,.85);
    max-width: 760px;
    margin: 0 auto;
    font-size: 1.02rem;
}
.cm-iso-band strong { color: #fff; }

.cm-iso {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: var(--cm-blue);
    padding: 12px 22px;
    border-radius: 999px;
    font-family: var(--cm-font-display);
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #fff;
    text-transform: uppercase;
    font-size: .9rem;
}

/* ===== MAPA ===== */
.cm-mapa iframe {
    width: 100%;
    min-height: 380px;
    border: 0;
    border-radius: 4px;
    filter: grayscale(.15) saturate(.92);
}

/* ===== CONTACTO ===== */
.cm-contacto-bloque p { margin: 10px 0; color: var(--cm-dark); }
.cm-contacto-bloque .cm-label {
    display: block;
    font-family: var(--cm-font-display);
    font-size: .75rem;
    color: var(--cm-gray);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin-bottom: 4px;
    font-weight: 700;
}
.cm-contacto-bloque a {
    color: var(--cm-dark);
    text-decoration: none;
    border-bottom: 1px solid var(--cm-blue);
}
.cm-contacto-bloque a:hover { color: var(--cm-blue); }

/* ===== FOOTER PROPIO ===== */
.cm-footer {
    background: var(--cm-dark);
    color: #fff;
    padding: 56px 24px 24px;
    margin-top: 60px;
}
.cm-footer-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 40px;
}
.cm-footer h4 {
    color: #fff;
    margin: 0 0 14px;
    font-size: .85rem;
    letter-spacing: 0.16em;
    font-family: var(--cm-font-display);
}
.cm-footer p, .cm-footer a {
    color: rgba(255,255,255,.78);
    font-size: .92rem;
    line-height: 1.65;
    text-decoration: none;
}
.cm-footer a:hover { color: var(--cm-blue); }
.cm-footer-bottom {
    max-width: 1200px;
    margin: 36px auto 0;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.1);
    font-size: .82rem;
    color: rgba(255,255,255,.55);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}
.cm-footer-bottom em {
    font-style: normal;
    font-family: var(--cm-font-display);
    color: var(--cm-blue);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

/* Esconder footer default de Astra */
.site-footer, .ast-small-footer { display: none !important; }

/* ===== FLOATING WHATSAPP ===== */
.cm-wa-float {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 60px; height: 60px;
    border-radius: 50%;
    background: var(--cm-wa);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 24px rgba(0,0,0,.28);
    z-index: 9999;
    transition: transform .2s ease, background .2s ease;
    color: #fff;
    text-decoration: none;
}
.cm-wa-float:hover { transform: scale(1.08); background: var(--cm-wa-deep); color: #fff; }
.cm-wa-float svg { width: 32px; height: 32px; fill: #fff; }

/* ===== NOSOTROS — helpers de seccion ===== */
.cm-text-center { text-align: center; }
.cm-section-h2 {
    position: relative;
    margin-bottom: 18px;
}
.cm-section-h2.cm-text-center::after,
.cm-section-h2.has-text-align-center::after {
    content: "";
    display: block;
    width: 64px;
    height: 4px;
    background: var(--cm-blue);
    margin: 14px auto 0;
}
.cm-section-sub {
    text-align: center;
    color: var(--cm-gray);
    max-width: 720px;
    margin: 0 auto 48px;
    font-size: 1.05rem;
}
.cm-lead {
    font-size: 1.15rem;
    color: var(--cm-dark);
    line-height: 1.7;
    margin-bottom: 1.4rem;
}

/* ===== NOSOTROS — FORTALEZA ===== */
.cm-fortaleza-section {
    background: var(--cm-soft);
    padding: 80px 24px;
}
.cm-fortaleza-inner {
    max-width: 1200px;
    margin: 0 auto;
}
.cm-fortaleza-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    margin-top: 8px;
}
.cm-fortaleza-card {
    background: #fff;
    border: 1px solid var(--cm-line);
    border-radius: 6px;
    padding: 32px 26px;
    text-align: left;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    display: flex;
    flex-direction: column;
}
.cm-fortaleza-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(0,0,0,.08);
    border-color: var(--cm-blue);
}
.cm-fortaleza-icon {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    background: rgba(0,173,239,.10);
    color: var(--cm-blue);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 18px;
}
.cm-fortaleza-icon svg { width: 28px; height: 28px; }
.cm-fortaleza-card h3 {
    color: var(--cm-dark);
    margin: 0 0 10px;
    font-size: 1.15rem;
    line-height: 1.2;
}
.cm-fortaleza-card p {
    color: var(--cm-gray);
    margin: 0;
    font-size: .98rem;
    line-height: 1.55;
}

/* ===== NOSOTROS — VALORES ===== */
.cm-valores-section {
    background: #fff;
    padding: 80px 24px;
}
.cm-valores-inner {
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}
.cm-valores-title { margin-bottom: 56px; }

.cm-valores-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-bottom: 56px;
}
.cm-valor {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}
.cm-valor-icon {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    border: 2px solid var(--cm-blue);
    color: var(--cm-blue);
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,173,239,.06);
    transition: transform .2s ease, background .2s ease;
}
.cm-valor:hover .cm-valor-icon {
    transform: translateY(-3px);
    background: var(--cm-blue);
    color: #fff;
}
.cm-valor-icon svg { width: 38px; height: 38px; }
.cm-valor span {
    font-family: var(--cm-font-display);
    font-size: .95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--cm-dark);
    text-align: center;
}

.cm-valores-banner {
    background: var(--cm-dark);
    color: #fff;
    padding: 28px 24px;
    margin: 0 auto;
    border-radius: 4px;
    max-width: 900px;
}
.cm-valores-banner p {
    font-family: var(--cm-font-display);
    font-size: clamp(1rem, 2vw, 1.3rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin: 0;
    color: #fff;
    text-align: center;
}

.cm-iso-seal {
    margin-top: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
}
.cm-iso-seal-svg { width: 120px; height: 120px; flex: 0 0 auto; }
.cm-iso-seal-text {
    text-align: left;
    max-width: 380px;
}
.cm-iso-seal-text strong {
    display: block;
    font-family: var(--cm-font-display);
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--cm-dark);
    margin-bottom: 6px;
}
.cm-iso-seal-text span {
    color: var(--cm-gray);
    font-size: .92rem;
    line-height: 1.55;
}

/* ===== NOSOTROS — CTA FINAL ===== */
.cm-nos-cta {
    background: var(--cm-blue);
    color: #fff;
    padding: 72px 24px;
    text-align: center;
}
.cm-nos-cta-inner { max-width: 720px; margin: 0 auto; }
.cm-nos-cta h2 { color: #fff; margin: 0 0 12px; }
.cm-nos-cta p {
    color: rgba(255,255,255,.92);
    font-size: 1.05rem;
    margin: 0 0 28px;
}
.cm-nos-cta-buttons {
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
}
.cm-nos-cta-buttons a.wp-block-button__link {
    background: transparent;
    color: #fff;
    border: 2px solid #fff;
    padding: 14px 30px;
    text-decoration: none;
}
.cm-nos-cta-buttons a.wp-block-button__link:hover {
    background: #fff;
    color: var(--cm-blue);
}
.cm-nos-cta-buttons a.wp-block-button__link.is-primary {
    background: var(--cm-dark);
    border-color: var(--cm-dark);
    color: #fff;
}
.cm-nos-cta-buttons a.wp-block-button__link.is-primary:hover {
    background: #000;
    color: #fff;
}

/* ===== NOSOTROS — RESPONSIVE ===== */
@media (max-width: 960px) {
    .cm-fortaleza-grid { grid-template-columns: repeat(2, 1fr); }
    .cm-valores-row    { grid-template-columns: repeat(2, 1fr); gap: 36px; }
}
@media (max-width: 560px) {
    .cm-fortaleza-grid { grid-template-columns: 1fr; }
    .cm-valores-row    { grid-template-columns: repeat(2, 1fr); gap: 24px; }
    .cm-iso-seal { flex-direction: column; text-align: center; }
    .cm-iso-seal-text { text-align: center; }
}

/* ===== TABS DE PRODUCTOS ===== */
.cm-product-tabs-wrap { margin: 0 auto; max-width: 1200px; padding: 0 20px; }
.cm-product-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 28px;
    border-bottom: 2px solid var(--cm-line);
    padding-bottom: 0;
}
.cm-product-tab {
    appearance: none;
    -webkit-appearance: none;
    background: transparent;
    border: 0;
    border-bottom: 4px solid transparent;
    color: var(--cm-gray);
    font-family: var(--cm-font-display);
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 14px 22px;
    cursor: pointer;
    margin-bottom: -2px;
    transition: color .15s ease, border-color .15s ease, background-color .15s ease;
}
.cm-product-tab:hover { color: var(--cm-dark); background: rgba(0,0,0,.03); }
.cm-product-tab.is-active {
    color: var(--cm-blue);
    border-bottom-color: var(--cm-blue);
}
.cm-product-tab:focus-visible {
    outline: 2px solid var(--cm-blue);
    outline-offset: 2px;
}
.cm-product-panel { display: none; }
.cm-product-panel.is-active { display: block; animation: cmFade .25s ease-out; }
@keyframes cmFade {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ===== CARRITO: badge en menu ===== */
.cm-cart-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    border-radius: 999px;
    background: var(--cm-blue);
    color: #fff;
    font-family: var(--cm-font-body);
    font-size: .75rem;
    font-weight: 700;
    margin-left: 6px;
    line-height: 1;
}
.menu-item .cm-cart-count { vertical-align: middle; }

/* ===== FORMULARIO PRESUPUESTO ===== */
.cm-form {
    max-width: 720px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid var(--cm-line);
    border-radius: 6px;
    padding: 36px 32px;
    box-shadow: 0 14px 40px rgba(0,0,0,.04);
}
.cm-form .cm-hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.cm-form-row { margin-bottom: 20px; }
.cm-form-row label {
    display: block;
    font-family: var(--cm-font-display);
    font-size: .85rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cm-dark);
    margin-bottom: 8px;
    font-weight: 700;
}
.cm-form-row .req { color: var(--cm-blue); font-size: 1rem; }
.cm-form-row input[type=text],
.cm-form-row input[type=email],
.cm-form-row input[type=tel],
.cm-form-row input[type=file],
.cm-form-row select,
.cm-form-row textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--cm-line);
    border-radius: 4px;
    font-family: var(--cm-font-body);
    font-size: 1rem;
    color: var(--cm-dark);
    background: #fff;
    transition: border-color .15s ease, box-shadow .15s ease;
    box-sizing: border-box;
}
.cm-form-row input:focus,
.cm-form-row select:focus,
.cm-form-row textarea:focus {
    outline: 0;
    border-color: var(--cm-blue);
    box-shadow: 0 0 0 3px rgba(0,173,239,.18);
}
.cm-form-row textarea { resize: vertical; min-height: 140px; }
.cm-form-row input[type=file] { padding: 10px; background: var(--cm-soft); }
.cm-form-row small { display: block; margin-top: 6px; color: var(--cm-gray); font-size: .82rem; }

.cm-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
/* Importante: min-width:0 en grid/flex children evita que el contenido fuerce overflow */
.cm-form-grid > .cm-form-row { min-width: 0; }
.cm-form .cm-form-row { min-width: 0; }

@media (max-width: 560px) {
    .cm-form-grid { grid-template-columns: 1fr; gap: 0; }
}

/* ===== FIX: select no debe cortar texto ===== */
.cm-form select,
.cm-form-row select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
    overflow: visible !important;
    text-overflow: unset !important;
    white-space: normal !important;
    /* Reserve un poquito para el chevron nativo del <select> */
    padding-right: 36px;
    box-sizing: border-box;
    /* Mantener la chevron nativa */
    appearance: auto;
    -webkit-appearance: menulist;
    -moz-appearance: menulist;
}
.cm-form select option {
    white-space: normal;
    word-wrap: break-word;
    padding: 6px 10px;
    color: var(--cm-dark);
    background: #fff;
}

.cm-form-submit {
    appearance: none;
    -webkit-appearance: none;
    background: var(--cm-blue);
    color: #fff;
    border: 0;
    padding: 16px 36px;
    border-radius: 4px;
    font-family: var(--cm-font-display);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .2s ease, transform .15s ease;
}
.cm-form-submit:hover { background: var(--cm-blue-deep); transform: translateY(-1px); }

.cm-form-success,
.cm-form-error {
    max-width: 720px;
    margin: 0 auto 20px;
    padding: 18px 22px;
    border-radius: 4px;
    font-family: var(--cm-font-body);
}
.cm-form-success { background: #E6F8E8; border-left: 4px solid #2BAB45; color: #144A1F; }
.cm-form-error   { background: #FDECEC; border-left: 4px solid #C0392B; color: #5C1212; }

/* ===== CONTACTO — layout 2 columnas ===== */
.cm-contacto-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 48px;
    align-items: start;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}
.cm-contacto-grid h2 {
    font-size: 1.6rem;
    margin: 0 0 18px;
    padding-bottom: 10px;
    border-bottom: 4px solid var(--cm-blue);
    display: inline-block;
}
.cm-contacto-grid .cm-form { padding: 28px 26px; }
.cm-contacto-side {
    background: var(--cm-soft);
    border-radius: 6px;
    padding: 28px 26px;
}
.cm-contacto-side .cm-contacto-bloque p { margin: 12px 0; }
.cm-contacto-side .wp-block-button { margin-top: 18px; }

@media (max-width: 880px) {
    .cm-contacto-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* ===== CONTACTO — mapa full-width ===== */
.cm-mapa-section {
    margin-top: 56px;
    padding: 0;
}
.cm-mapa-section .cm-mapa-caption {
    text-align: center;
    color: var(--cm-gray);
    margin: 0 0 18px;
    font-size: .95rem;
}
.cm-mapa-section iframe {
    width: 100%;
    min-height: 420px;
    border: 0;
    display: block;
    filter: grayscale(.15) saturate(.92);
}

/* Banda WhatsApp alterno en /presupuesto-a-medida/ */
.cm-wa-section {
    background: var(--cm-soft);
    padding: 60px 24px;
    text-align: center;
    margin-top: 60px;
}
.cm-wa-section h2 { margin: 0 0 10px; }
.cm-wa-section p  { color: var(--cm-gray); margin: 0 0 24px; font-size: 1.05rem; }
.cm-wa-section a.cm-wa-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #25D366;
    color: #fff;
    font-family: var(--cm-font-display);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 16px 32px;
    border-radius: 4px;
    text-decoration: none;
    transition: background .2s ease, transform .15s ease;
}
.cm-wa-section a.cm-wa-cta:hover { background: #1FAA52; transform: translateY(-1px); color: #fff; }
.cm-wa-section a.cm-wa-cta svg { width: 22px; height: 22px; fill: #fff; }

/* ===== PRODUCTS PAGE ===== */
.cm-cat-hero h1 {
    color: #fff !important;
    text-shadow: 0 2px 16px rgba(0,0,0,.5);
}
.cm-cat-hero p.cm-subtitle {
    color: #fff;
    font-family: var(--cm-font-body);
    font-size: 1.05rem;
    text-shadow: 0 1px 8px rgba(0,0,0,.5);
}

.cm-cat-section { padding-left: 20px; padding-right: 20px; }
.cm-cat-section h2 {
    border-bottom: 4px solid var(--cm-blue);
    padding-bottom: 10px;
    margin: 0 0 14px 0;
    display: inline-block;
}
.cm-cat-section > p,
.cm-cat-section .alignwide > p {
    color: var(--cm-gray);
    max-width: 760px;
    margin-bottom: 2rem;
    font-size: 1.02rem;
}

/* CTA band inferior */
.cm-cta-band {
    background: var(--cm-blue);
    color: #fff;
    padding: 64px 24px;
    text-align: center;
}
.cm-cta-band-inner {
    max-width: 760px;
    margin: 0 auto;
}
.cm-cta-band h2 {
    color: #fff;
    margin: 0 0 12px;
}
.cm-cta-band p {
    color: rgba(255,255,255,.92);
    margin: 0 0 26px;
    font-size: 1.05rem;
    line-height: 1.6;
}
.cm-cta-band a.wp-block-button__link {
    background: var(--cm-dark);
    color: #fff;
    display: inline-block;
    padding: 16px 36px;
    font-size: 1rem;
}
.cm-cta-band a.wp-block-button__link:hover {
    background: #000;
    color: #fff;
}

/* ===== WOOCOMMERCE — GRID DE PRODUCTOS ===== */
.woocommerce ul.products {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.woocommerce ul.products li.product {
    background: #fff;
    border: 1px solid var(--cm-line);
    border-radius: 4px;
    padding: 14px;
    margin: 0 !important;
    width: auto !important;
    float: none !important;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    display: flex;
    flex-direction: column;
}
.woocommerce ul.products li.product:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 28px rgba(0,0,0,.08);
    border-color: var(--cm-blue);
}
.woocommerce ul.products li.product a img {
    border-radius: 3px;
    margin-bottom: 14px;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}
.woocommerce ul.products li.product h2.woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--cm-font-display) !important;
    font-size: 1rem !important;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--cm-dark) !important;
    padding: 0 !important;
    margin: 0 0 8px !important;
    line-height: 1.2;
}
.woocommerce ul.products li.product .price {
    color: var(--cm-blue) !important;
    font-weight: 700 !important;
    font-family: var(--cm-font-body) !important;
    font-size: 1.05rem !important;
    margin-bottom: 12px;
}
.woocommerce ul.products li.product .price del { color: var(--cm-gray); font-weight: 400; }
.woocommerce ul.products li.product .button {
    background: var(--cm-blue) !important;
    color: #fff !important;
    margin-top: auto;
    font-family: var(--cm-font-display);
    text-transform: uppercase;
    font-size: .85rem;
    letter-spacing: 0.06em;
}
.woocommerce ul.products li.product .button:hover { background: var(--cm-blue-deep) !important; }

.woocommerce span.onsale {
    background: var(--cm-blue);
    color: #fff;
    border-radius: 4px;
    font-family: var(--cm-font-display);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button { background: var(--cm-blue); color: #fff; }

@media (max-width: 1024px) {
    .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
    .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px) {
    .woocommerce ul.products { grid-template-columns: 1fr; }
}

/* ===== BLOQUE COMPACTO DE CATEGORIAS (home) ===== */
.cm-quick-cats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    max-width: 720px;
    margin: 0 auto;
}
.cm-quick-cat {
    background: #fff;
    border: 1px solid var(--cm-line);
    border-radius: 6px;
    padding: 22px 16px;
    text-align: center;
    text-decoration: none;
    color: var(--cm-dark);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, color .2s ease;
}
.cm-quick-cat:hover,
.cm-quick-cat:focus-visible {
    transform: translateY(-3px);
    border-color: var(--cm-blue);
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
    color: var(--cm-blue);
}
.cm-quick-cat-icon {
    font-size: 2.1rem;
    line-height: 1;
    font-family: "Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;
}
.cm-quick-cat-label {
    font-family: var(--cm-font-display);
    font-weight: 700;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.cm-quick-features {
    text-align: center;
    color: var(--cm-gray);
    font-size: .95rem;
    margin: 22px auto 0;
    max-width: 720px;
    line-height: 1.5;
}
@media (max-width: 560px) {
    .cm-quick-cats     { gap: 8px; }
    .cm-quick-cat      { padding: 14px 6px; }
    .cm-quick-cat-icon { font-size: 1.7rem; }
    .cm-quick-cat-label{ font-size: .85rem; letter-spacing: 0.04em; }
    .cm-quick-features { font-size: .85rem; padding: 0 8px; }
}

/* ===== MOBILE OPTIMIZATIONS — HOME ===== */
@media (max-width: 768px) {
    body.home .cm-hero,
    body.page-id-10 .cm-hero {
        min-height: 60vh !important;
    }
    body.home .cm-hero h1,
    body.page-id-10 .cm-hero h1 {
        font-size: clamp(1.6rem, 5.5vw, 2.2rem);
    }
    body.home .wp-block-group[style*="padding-top"],
    body.page-id-10 .wp-block-group[style*="padding-top"] {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
    body.home .cm-tagline-strip,
    body.page-id-10 .cm-tagline-strip {
        padding: 12px 16px;
    }
    body.home .cm-tagline-strip p,
    body.page-id-10 .cm-tagline-strip p {
        letter-spacing: 0.08em;
        font-size: .95rem;
    }
    body.home .cm-iso-band,
    body.page-id-10 .cm-iso-band {
        padding: 36px 16px;
    }
    body.home .cm-mapa iframe,
    body.page-id-10 .cm-mapa iframe {
        min-height: 250px;
    }
    body.home .cm-pilar,
    body.page-id-10 .cm-pilar {
        padding: 22px 18px;
    }
    body.home .wp-block-embed-youtube,
    body.page-id-10 .wp-block-embed-youtube {
        width: 100%;
        max-width: 100%;
    }
    body.home .wp-block-embed-youtube iframe,
    body.page-id-10 .wp-block-embed-youtube iframe {
        width: 100% !important;
        height: auto;
        aspect-ratio: 16 / 9;
    }
}

/* ===== RESPONSIVE GENERAL ===== */
@media (max-width: 960px) {
    .cm-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
    .cm-hero h1 { font-size: 2rem; }
    .cm-iso-band { padding: 36px 16px; }
    .cm-footer-grid { grid-template-columns: 1fr; gap: 28px; }
    .cm-wa-float { bottom: 16px; right: 16px; width: 54px; height: 54px; }
}
