/* ============================================================
   Ariseweb Commerce — main.css
   Hoja principal del tema. Tokens del diseño (vallas parajardin.es),
   estilos base y componentes compartidos.
   Las fuentes son locales (Sora + Mulish) con font-display: swap.
   ============================================================ */

/* ---------- FONT FACES (locales, ver docs/05) ---------- */
@font-face {
    font-family: "Sora";
    src: url("../fonts/sora-400.woff2") format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Sora";
    src: url("../fonts/sora-600.woff2") format("woff2");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Sora";
    src: url("../fonts/sora-700.woff2") format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Sora";
    src: url("../fonts/sora-800.woff2") format("woff2");
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Mulish";
    src: url("../fonts/mulish-400.woff2") format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Mulish";
    src: url("../fonts/mulish-500.woff2") format("woff2");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Mulish";
    src: url("../fonts/mulish-600.woff2") format("woff2");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Mulish";
    src: url("../fonts/mulish-700.woff2") format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    /* ---------- COLOR — MARCA (override desde el Personalizador) ---------- */
    --arsc-color-primary: #1f7e45;
    --arsc-color-secondary: #10301d;
    --arsc-color-accent: #fbb03b;
    --arsc-color-offer: #fbb03b;

    /* ---------- COLOR — PRIMITIVAS ---------- */
    --green-900: var(--arsc-color-secondary);
    --green-700: #1c4d30;
    --green-600: var(--arsc-color-primary);
    --green-100: #cfe7d8;
    --green-50: #eef6f0;
    --brown-500: #8b6233;
    --brown-100: #ece0cf;
    --brown-50: #f6f0e8;
    --ink: #1a1a1a;
    --gray-500: #6b6b66;
    --border-c: #e3e3de;
    --white: #ffffff;

    /* ---------- COLOR — SEMÁNTICO ---------- */
    --bg: var(--white);
    --bg-alt-green: var(--green-50);
    --bg-alt-brown: var(--brown-50);
    --heading: var(--green-900);
    --text: var(--ink);
    --text-muted: var(--gray-500);
    --action: var(--green-600);
    --action-hover: var(--brown-500);
    --action-text: var(--white);
    --border: var(--border-c);

    /* ---------- TIPOGRAFÍA ---------- */
    --font-display: "Sora", system-ui, sans-serif;
    --font-text: "Mulish", system-ui, sans-serif;
    --font-rounded: "Sora", system-ui, sans-serif;
    --font-neutral: "Mulish", system-ui, sans-serif;

    --h1-size: 44px; --h1-lh: 1.2; --h1-weight: 800;
    --h2-size: 32px; --h2-lh: 1.25; --h2-weight: 700;
    --h3-size: 24px; --h3-lh: 1.3; --h3-weight: 700;
    --h4-size: 20px; --h4-lh: 1.35; --h4-weight: 700;
    --body-lg-size: 18px; --body-lg-lh: 1.6; --body-lg-weight: 400;
    --body-size: 16px; --body-lh: 1.6; --body-weight: 400;
    --small-size: 14px; --small-lh: 1.5; --small-weight: 400;
    --caption-size: 12px; --caption-lh: 1.4; --caption-weight: 500;

    /* ---------- ESPACIADO (4 / 8 / 12 / 16 / 24 / 32 / 48 / 64 / 96) ---------- */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-6: 24px;
    --space-8: 32px;
    --space-10: 40px;
    --space-12: 48px;
    --space-16: 64px;
    --space-24: 96px;

    /* ---------- RADIOS ---------- */
    --radius-control: 4px;
    --radius-card: 8px;
    --radius-container: 12px;
    --radius-pill: 9999px;

    /* ---------- SOMBRAS (solo flotantes) ---------- */
    --shadow-float: 0 6px 24px rgba(34, 45, 8, 0.12);
    --shadow-float-strong: 0 12px 40px rgba(34, 45, 8, 0.18);

    /* ---------- FOCUS RING ---------- */
    --focus-ring: 0 0 0 3px rgba(31, 126, 69, 0.35);
}

/* ============================================================
   BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--font-text);
    color: var(--text);
    background: var(--bg);
    font-size: var(--body-size);
    line-height: var(--body-lh);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

h1, h2, h3, h4 {
    font-family: var(--font-display);
    color: var(--heading);
    margin: 0;
}
h1 { font-size: var(--h1-size); line-height: var(--h1-lh); font-weight: var(--h1-weight); letter-spacing: -0.01em; }
h2 { font-size: var(--h2-size); line-height: var(--h2-lh); font-weight: var(--h2-weight); }
h3 { font-size: var(--h3-size); line-height: var(--h3-lh); font-weight: var(--h3-weight); }
h4 { font-size: var(--h4-size); line-height: var(--h4-lh); font-weight: var(--h4-weight); }
p { margin: 0 0 1em; text-wrap: pretty; }
p:last-child { margin-bottom: 0; }

:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: var(--radius-control); }

/* Accesibilidad: skip-link y texto solo para lectores. */
.screen-reader-text {
    border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
    height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0;
    position: absolute !important; word-wrap: normal !important;
}
.skip-link {
    position: absolute; left: -9999px; top: 0; z-index: 100000;
    background: var(--green-900); color: #fff; padding: 12px 18px;
    border-radius: 0 0 var(--radius-card) 0;
}
.skip-link:focus {
    left: 0; clip: auto; clip-path: none; width: auto; height: auto;
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ---------- LAYOUT ---------- */
.container { max-width: 1200px; margin: 0 auto; padding-inline: var(--space-6); }
.container.narrow { max-width: 760px; }
.section { padding-block: var(--space-24); }
.section--tight { padding-block: var(--space-16); }
.bg-green { background: var(--bg-alt-green); border-block: 1px solid var(--border); }
.bg-brown { background: var(--bg-alt-brown); border-block: 1px solid var(--border); }
.bg-dark { background: var(--green-900); color: rgba(255,255,255,.85); }
.bg-green-soft { background: var(--green-50); }

/* ---------- TIPOGRAFÍA UTIL ---------- */
.lede { font-size: var(--body-lg-size); line-height: var(--body-lg-lh); }
.muted { color: var(--text-muted); }
.kicker {
    display: inline-flex; align-items: center; gap: 12px;
    font-family: var(--font-text); font-weight: 700; font-size: 13px;
    letter-spacing: .15em; text-transform: uppercase; color: var(--brown-500);
}
.kicker::before { content: ""; width: 30px; height: 2px; background: currentColor; border-radius: 2px; }
.kicker--neutral { color: var(--gray-500); }
.kicker--green { color: var(--green-700); }
.section-head { max-width: 720px; margin-bottom: var(--space-16); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head h2 { margin-top: 14px; }
.section-head p { margin-top: 14px; font-size: var(--body-lg-size); line-height: var(--body-lg-lh); color: var(--text); }

/* ---------- BOTONES ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    font-family: var(--font-text); font-weight: 700; font-size: 15px; line-height: 1;
    padding: 13px 22px; border-radius: var(--radius-control);
    border: 1px solid transparent; cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease, transform .1s ease;
}
.btn:active { transform: scale(.98); }
.btn .ic { width: 18px; height: 18px; }
.btn--lg { padding: 16px 28px; font-size: 17px; }
.btn--primary { background: var(--arsc-color-accent); color: var(--green-900); }
.btn--primary:hover { background: var(--action-hover); color: #fff; }
.btn--secondary { background: transparent; border-color: var(--action); color: var(--action); }
.btn--secondary:hover { background: var(--green-50); }
.btn--ghost-dark { background: transparent; border-color: rgba(255,255,255,.35); color: #fff; }
.btn--ghost-dark:hover { background: rgba(255,255,255,.12); }
.btn--text { background: transparent; color: var(--action); padding: 10px 6px; }
.btn--text:hover { color: var(--action-hover); }
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- TOPBAR + HEADER ---------- */
.topbar {
    background: var(--green-900); color: rgba(255,255,255,.85);
    font-size: 13px; font-weight: 500;
    padding: 8px 16px;
}
.topbar .container { display: flex; align-items: center; justify-content: center; gap: 16px; }
.topbar .ic { width: 15px; height: 15px; }
.topbar-menu { list-style: none; display: flex; gap: 16px; margin: 0; padding: 0; }
.topbar-menu a { color: inherit; }

.site-header { background: #fff; border-bottom: 1px solid var(--border); }
.has-sticky-header .site-header { position: sticky; top: 0; z-index: 40; }
.site-header .container {
    display: grid; grid-template-columns: auto 1fr auto;
    align-items: center; gap: 24px; min-height: 76px;
}
.brand { display: flex; align-items: center; justify-self: start; }
.brand img, .footer-logo { height: 56px; width: auto; }
.brand-name { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--green-900); display: block; }
.brand-tagline { font-size: 12px; color: var(--text-muted); }
.main-nav { justify-self: center; }
.main-nav-list { list-style: none; display: flex; gap: 22px; margin: 0; padding: 0; }
.main-nav-list a { font-size: 15px; font-weight: 500; color: var(--ink); white-space: nowrap; }
.main-nav-list a:hover { color: var(--action); }
.main-nav-list .current-menu-item > a { font-weight: 700; color: var(--action); }
.header-actions { display: flex; align-items: center; gap: 14px; justify-self: end; }
.header-phone { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: var(--green-900); font-size: 15px; white-space: nowrap; }
.header-phone .ic { width: 18px; height: 18px; color: var(--action); }
.icon-btn { background: transparent; border: none; cursor: pointer; color: var(--green-900); padding: 8px; display: inline-flex; position: relative; }
.icon-btn .ic { width: 24px; height: 24px; }
.cart-count {
    position: absolute; top: 0; right: 0; background: var(--action); color: #fff;
    font-size: 11px; font-weight: 700; min-width: 18px; height: 18px; border-radius: 9px;
    display: flex; align-items: center; justify-content: center; padding: 0 4px;
}
.nav-toggle { display: none; background: transparent; border: none; cursor: pointer; color: var(--green-900); padding: 6px; }
.nav-toggle .ic { width: 26px; height: 26px; }

/* Panel de búsqueda desplegable */
.header-search-panel { border-bottom: 1px solid var(--border); background: #fff; padding-block: var(--space-4); }
.header-search-panel[hidden] { display: none; }
.search-form { display: flex; gap: 10px; }
.search-form .search-field {
    flex: 1; height: 48px; padding: 0 16px; border: 1px solid var(--border);
    border-radius: var(--radius-control); font: inherit; background: #fff;
}
.search-form .search-field:focus-visible { outline: none; border-color: var(--action); box-shadow: var(--focus-ring); }

/* Menú móvil */
.mobile-nav { position: fixed; inset: 0; z-index: 60; background: rgba(26,26,26,.5); }
.mobile-nav[hidden] { display: none; }
.mobile-nav-inner {
    position: absolute; top: 0; right: 0; height: 100%; width: min(86vw, 360px);
    background: #fff; box-shadow: var(--shadow-float-strong); padding: var(--space-6);
    display: flex; flex-direction: column; gap: var(--space-6); overflow-y: auto;
}
.mobile-nav-head { display: flex; align-items: center; justify-content: space-between; }
.mobile-nav-title { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--green-900); }
.nav-close { background: transparent; border: none; cursor: pointer; color: var(--green-900); padding: 4px; }
.mobile-nav-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.mobile-nav-list a { display: block; padding: 14px 0; font-size: 17px; font-weight: 600; color: var(--green-900); border-bottom: 1px solid var(--border); }
.mobile-nav-list a:hover { color: var(--action); }

/* ---------- TRUST BAR ---------- */
.trustbar { background: #fff; border-block: 1px solid var(--border); }
.trustbar .grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding-block: var(--space-6); }
.trust-item { display: flex; align-items: center; gap: 12px; }
.trust-item .ic { width: 30px; height: 30px; color: var(--action); flex: 0 0 auto; }
.trust-item .t { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--heading); }
.trust-item .d { font-size: 12px; color: var(--text-muted); }

/* ---------- HERO ---------- */
.hero { position: relative; background: var(--bg-alt-green); border-bottom: 1px solid var(--border); overflow: hidden; }
.hero .container { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; padding-block: var(--space-24); }
.hero h1 { margin: 16px 0; }
.hero .lede { color: var(--ink); margin-bottom: 28px; max-width: 520px; }
.hero-media {
    position: relative; border-radius: var(--radius-container); overflow: hidden;
    border: 1px solid var(--border); aspect-ratio: 4 / 3.4; background: var(--green-100);
}
.hero-media img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- BREADCRUMB ---------- */
.breadcrumb { background: var(--green-50); border-bottom: 1px solid var(--border); }
.breadcrumb .container { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; padding-block: 12px; font-size: 13px; }
.breadcrumb a { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--action); }
.breadcrumb .sep, .breadcrumb .separator { color: var(--border); }
.breadcrumb .current, .breadcrumb .last { color: var(--green-900); font-weight: 700; }

/* ---------- BLOG ---------- */
.blog-head, .archive-head { max-width: 720px; margin-bottom: var(--space-8); }
.blog-head h1, .archive-head h1 { margin: 0 0 12px; }
.blog-head p, .archive-head p { color: var(--text-muted); font-size: var(--body-lg-size); line-height: var(--body-lg-lh); }
.post-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-bottom: 12px; }
.post-cat { font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: .03em; text-transform: uppercase; color: var(--green-600); }
.post-date, .post-read { font-size: 13px; color: var(--text-muted); }
.read-more { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: 14px; color: var(--action); margin-top: 4px; }
.read-more .ic { width: 16px; height: 16px; transition: transform .16s ease; }
.read-more:hover .ic { transform: translateX(3px); }
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.post-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-card); overflow: hidden; transition: border-color .16s ease, transform .16s ease; }
.post-card:hover { border-color: var(--action); transform: translateY(-2px); }
.post-thumb { display: block; aspect-ratio: 16/10; }
.post-thumb img { width: 100%; height: 100%; object-fit: cover; }
.post-card-body { padding: var(--space-4); display: flex; flex-direction: column; flex: 1; }
.post-card-body h3 { font-size: 19px; line-height: 1.28; margin: 0 0 8px; }
.post-card-body h3 a { color: var(--green-900); }
.post-card-body h3 a:hover { color: var(--action); }
.post-card-body p { font-size: 14px; line-height: 1.55; color: var(--text-muted); margin: 0 0 14px; }
.post-card-body .read-more { margin-top: auto; }

/* ---------- ENTRADA / PÁGINA · PROSE ---------- */
.prose { max-width: 760px; font-size: 17px; line-height: 1.7; color: var(--text); }
.prose > p { margin: 0 0 20px; }
.prose h2 { font-size: 26px; margin: 38px 0 14px; }
.prose h3 { font-size: 21px; margin: 28px 0 12px; }
.prose ul, .prose ol { margin: 0 0 20px; padding-left: 22px; display: flex; flex-direction: column; gap: 8px; }
.prose li { line-height: 1.6; }
.prose strong { color: var(--green-900); }
.prose a { color: var(--action); text-decoration: underline; }
.prose img { border-radius: var(--radius-card); margin: 24px 0; }
.prose blockquote { margin: 24px 0; padding: 16px 22px; border-left: 3px solid var(--green-600); background: var(--green-50); border-radius: 0 var(--radius-card) var(--radius-card) 0; }

.post-single-head { padding-bottom: var(--space-8); }
.post-single-head h1 { margin: 12px 0 18px; }
.post-lead { font-size: 20px; line-height: 1.5; color: var(--text-muted); margin: 0; }
.post-featured-img { border-radius: var(--radius-container); overflow: hidden; border: 1px solid var(--border); aspect-ratio: 21/9; margin-bottom: var(--space-12); }
.post-featured-img img { width: 100%; height: 100%; object-fit: cover; }
.page-featured-img { border-radius: var(--radius-container); overflow: hidden; margin-bottom: var(--space-8); }
.post-tags { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 28px 0 0; }
.post-tags li a { display: inline-block; font-size: 13px; color: var(--green-900); background: #fff; border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 6px 14px; }

/* ---------- CALCULADORA ---------- */
.calc-wrap { display: grid; grid-template-columns: .9fr 1.1fr; gap: 48px; align-items: center; }
.calc-card {
    border: 1px solid var(--border); border-radius: var(--radius-container);
    padding: var(--space-8); background: #fff; display: flex; flex-direction: column; gap: 22px;
}
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 13px; font-weight: 500; color: var(--text-muted); }
.input-row { display: flex; align-items: center; gap: 16px; }
.input-row input[type=range] { flex: 1; accent-color: var(--action); height: 4px; }
.num-box { display: flex; align-items: center; gap: 6px; border: 1px solid var(--border); border-radius: var(--radius-control); padding: 10px 14px; }
.num-box input { width: 52px; border: none; outline: none; font-family: var(--font-text); font-size: 17px; font-weight: 700; text-align: right; color: var(--ink); background: transparent; }
.num-box .unit { font-size: 14px; color: var(--text-muted); }
.calc-result { background: var(--green-50); border-radius: var(--radius-card); padding: 20px; display: flex; flex-direction: column; gap: 10px; }
.calc-line { display: flex; justify-content: space-between; align-items: baseline; font-size: 15px; color: var(--text-muted); }
.calc-divider { height: 1px; background: var(--border); margin: 2px 0; }
.calc-total { display: flex; justify-content: space-between; align-items: baseline; }
.calc-total .lbl { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--heading); }
.calc-total .amt { font-family: var(--font-display); font-weight: 800; font-size: 30px; color: var(--green-900); }
.packs-pill { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--action); }
.calc-note { font-size: 12px; color: var(--text-muted); }
.accent-head { color: var(--green-900); }

/* ---------- FAQ (bloque details nativo) ---------- */
.wp-block-details { border-bottom: 1px solid var(--border); padding: 6px 0; }
.wp-block-details summary { cursor: pointer; font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--heading); padding: 16px 4px; list-style: none; }
.wp-block-details summary::-webkit-details-marker { display: none; }
.wp-block-details[open] summary { color: var(--action); }

/* ---------- FORMULARIOS (contacto, comentarios) ---------- */
input[type=text], input[type=email], input[type=tel], input[type=url],
input[type=search], input[type=number], input[type=password], textarea, select {
    width: 100%; font-family: var(--font-text); font-size: 15px; color: var(--ink);
    background: #fff; border: 1px solid var(--border); border-radius: var(--radius-control);
    padding: 12px 14px;
}
textarea { resize: vertical; min-height: 120px; line-height: 1.5; }
input:focus-visible, textarea:focus-visible, select:focus-visible {
    outline: none; border-color: var(--action); box-shadow: var(--focus-ring);
}

/* ---------- PAGINACIÓN ---------- */
.pagination { margin-top: var(--space-12); }
.pagination .nav-links { display: flex; align-items: center; justify-content: center; gap: 8px; flex-wrap: wrap; }
.pagination .page-numbers {
    display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px;
    padding: 0 10px; border-radius: var(--radius-control); font-weight: 700; font-family: var(--font-display);
    border: 1px solid var(--border); color: var(--green-900); background: #fff;
}
.pagination .page-numbers:hover { border-color: var(--action); color: var(--action); }
.pagination .page-numbers.current { background: var(--green-600); border-color: var(--green-600); color: #fff; }
.pagination .page-numbers.dots { border-color: transparent; background: transparent; }

/* ---------- FOOTER ---------- */
.site-footer { background: var(--green-600); color: rgba(255,255,255,.85); }
.footer-top { display: grid; grid-template-columns: 1.5fr repeat(4, 1fr); gap: 32px; padding-block: var(--space-12); }
.footer-logo { margin-bottom: 16px; }
.footer-brand-name { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: #fff; display: block; margin-bottom: 16px; }
.footer-brand .blurb { font-size: 14px; line-height: 1.6; max-width: 250px; margin-bottom: 18px; }
.footer-col-title, .footer-col h5 { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: #fff; margin: 0 0 14px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 9px; }
.footer-col a { font-size: 14px; color: rgba(255,255,255,.85); }
.footer-col a:hover { color: #fff; }
.social-row { display: flex; gap: 10px; flex-wrap: wrap; }
.social-row a {
    width: 40px; height: 40px; border-radius: var(--radius-control);
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.14); color: #fff;
    transition: background .16s ease, transform .16s ease;
}
.social-row a:hover { background: rgba(255,255,255,.26); transform: translateY(-2px); }
.social-row .ic { width: 20px; height: 20px; }
.social-row--dark a { background: #fff; color: var(--green-900); border: 1px solid var(--border); }
.social-row--dark a:hover { background: var(--green-600); border-color: var(--green-600); color: #fff; }

.footer-payments {
    display: flex; flex-direction: column; align-items: center; gap: 14px;
    padding-block: var(--space-8); border-top: 1px solid rgba(255,255,255,.2);
}
.footer-payments .fp-label {
    font-family: var(--font-display); font-weight: 700; font-size: 13px;
    letter-spacing: .04em; text-transform: uppercase; color: rgba(255,255,255,.78);
}
.pay-methods { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.pay-badge {
    display: inline-flex; align-items: center; justify-content: center; height: 30px; padding: 0 12px;
    background: #fff; color: var(--green-900); border-radius: 5px; font-size: 12px; font-weight: 700;
}
.footer-bottom { border-top: 1px solid rgba(255,255,255,.2); }
.footer-bottom .container { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; padding-block: var(--space-4); font-size: 13px; color: rgba(255,255,255,.72); }
.footer-copyright { margin: 0; }
.footer-legal-list { list-style: none; display: flex; gap: 16px; margin: 0; padding: 0; }
.footer-legal-list a { color: rgba(255,255,255,.72); }
.footer-legal-list a:hover { color: #fff; }

/* ---------- 404 ---------- */
.error-404 .error-code { font-family: var(--font-display); font-weight: 900; font-size: 96px; color: var(--green-100); line-height: 1; margin: 0; }
.error-404 h1 { margin: 0 0 12px; }
.error-404 .error-lead { color: var(--text-muted); max-width: 520px; margin: 0 auto var(--space-8); }
.error-404 .search-form { max-width: 440px; margin: 0 auto var(--space-8); }

/* ---------- WIDGETS ---------- */
.widget { margin-bottom: var(--space-8); }
.widget-title { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--green-900); margin: 0 0 14px; }
.sidebar .widget ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.sidebar .widget a { color: var(--text); }
.sidebar .widget a:hover { color: var(--action); }

/* ---------- COMENTARIOS ---------- */
.comments-area { margin-top: var(--space-12); }
.comments-title { margin-bottom: var(--space-6); }
.comment-list { list-style: none; margin: 0 0 var(--space-8); padding: 0; display: flex; flex-direction: column; gap: var(--space-6); }
.comment-list ol { list-style: none; padding-left: var(--space-8); }
.comment-body { border: 1px solid var(--border); border-radius: var(--radius-card); padding: var(--space-6); }
.comment-form { display: flex; flex-direction: column; gap: var(--space-4); max-width: 720px; }
.comment-form .submit { align-self: flex-start; background: var(--arsc-color-accent); color: var(--green-900); border: none; border-radius: var(--radius-control); padding: 14px 26px; font-weight: 700; cursor: pointer; }

/* ---------- PÁGINA DE CONTACTO (plantilla dos columnas) ---------- */
.contact-intro { background: var(--green-50); border-bottom: 1px solid var(--border); }
.contact-head { max-width: 720px; }
.contact-head h1 { margin: 0 0 12px; }
.contact-head p { color: var(--text-muted); font-size: var(--body-lg-size); line-height: var(--body-lg-lh); }
.contact-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: var(--space-12); align-items: start; }
.cinfo-list { list-style: none; margin: 0 0 var(--space-8); padding: 0; display: flex; flex-direction: column; gap: var(--space-6); }
.cinfo-item { display: grid; grid-template-columns: 48px 1fr; gap: 16px; align-items: start; }
.cinfo-ic { width: 48px; height: 48px; border-radius: var(--radius-card); background: var(--green-600); color: #fff; display: flex; align-items: center; justify-content: center; }
.cinfo-item h4 { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--green-900); margin: 0 0 3px; }
.cinfo-main { display: block; font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--ink); }
a.cinfo-main:hover { color: var(--action); }
.cinfo-note { margin: 3px 0 0; font-size: 14px; color: var(--text-muted); line-height: 1.5; }
.cinfo-social { padding-top: var(--space-6); border-top: 1px solid var(--border); }
.cinfo-social-label { display: block; font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--green-900); margin-bottom: 12px; }
.contact-form-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-container); padding: var(--space-8); }
.map-embed { margin-top: var(--space-6); border-radius: var(--radius-container); overflow: hidden; border: 1px solid var(--border); }
.map-embed iframe { display: block; }
.mockimg--map {
    position: relative; aspect-ratio: 16/10;
    background:
        linear-gradient(90deg, transparent 0 48%, rgba(255,255,255,.7) 48% 51%, transparent 51%),
        linear-gradient(0deg, transparent 0 62%, rgba(255,255,255,.7) 62% 64%, transparent 64%),
        repeating-linear-gradient(38deg, rgba(255,255,255,.35) 0 2px, transparent 2px 26px),
        var(--green-100);
}
.map-pin-badge {
    position: absolute; left: 50%; top: 52%; transform: translate(-50%,-50%);
    display: inline-flex; align-items: center; gap: 6px; background: #fff;
    border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 7px 14px;
    font-size: 13px; font-weight: 700; color: var(--green-900); box-shadow: var(--shadow-float); white-space: nowrap;
}
.map-pin-badge .ic { width: 16px; height: 16px; color: var(--action); }
@media (max-width: 860px) {
    .contact-grid { grid-template-columns: 1fr; gap: var(--space-8); }
    .contact-form-card { padding: var(--space-6); }
}

/* ---------- CONTACT FORM 7 (opcional, si el cliente lo usa) ---------- */
.wpcf7 { max-width: 720px; }
.wpcf7-form { display: flex; flex-direction: column; gap: var(--space-6); }
.wpcf7-form p { margin: 0; }
.wpcf7 label { display: flex; flex-direction: column; gap: 7px; font-family: var(--font-text); font-size: 14px; font-weight: 600; color: var(--green-900); }
.wpcf7-form-control-wrap { display: block; }
.wpcf7 .wpcf7-form-control:not(.wpcf7-submit):not([type=checkbox]):not([type=radio]) {
    width: 100%; font-family: var(--font-text); font-size: 15px; color: var(--ink);
    background: #fff; border: 1px solid var(--border); border-radius: var(--radius-control); padding: 12px 14px;
}
.wpcf7 textarea.wpcf7-form-control { min-height: 140px; resize: vertical; }
.wpcf7 .wpcf7-form-control:focus-visible { outline: none; border-color: var(--action); box-shadow: var(--focus-ring); }
.wpcf7 .wpcf7-submit {
    align-self: flex-start; background: var(--arsc-color-accent); color: var(--green-900);
    border: 1px solid transparent; border-radius: var(--radius-control);
    font-family: var(--font-text); font-weight: 700; font-size: 15px; padding: 14px 28px; cursor: pointer;
    transition: background .15s ease, color .15s ease;
}
.wpcf7 .wpcf7-submit:hover { background: var(--action-hover); color: #fff; }
.wpcf7 .wpcf7-acceptance .wpcf7-list-item { margin: 0; }
.wpcf7 .wpcf7-acceptance label { flex-direction: row; align-items: flex-start; gap: 10px; font-weight: 400; color: var(--text-muted); font-size: 14px; line-height: 1.5; }
.wpcf7-not-valid { border-color: #c0392b !important; }
.wpcf7-not-valid-tip { color: #c0392b; font-size: 13px; margin-top: 4px; }
.wpcf7 .wpcf7-response-output {
    margin: 0; padding: 14px 18px; border-radius: var(--radius-card); font-size: 14px;
    border: 1px solid var(--border);
}
.wpcf7 form.sent .wpcf7-response-output { border-left: 4px solid var(--green-600); background: var(--green-50); color: var(--green-900); }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output { border-left: 4px solid #c0392b; background: #fdecea; color: #7a241b; }
.wpcf7-spinner { background-color: var(--green-600); }

/* ---------- RTL ---------- */
.rtl .kicker::before { margin-left: 0; }
.rtl .skip-link { border-radius: 0 0 0 var(--radius-card); }
.rtl .mobile-nav-inner { right: auto; left: 0; box-shadow: -12px 0 40px rgba(34,45,8,.18); }
.rtl .onsale, .rtl .quick-view-btn { left: auto; right: 12px; }
.rtl .read-more:hover .ic { transform: translateX(-3px); }
.rtl .woocommerce-MyAccount-navigation ul { border-left: 0; border-right: 2px solid var(--border); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
    :root { --h1-size: 38px; --h2-size: 28px; }
    .post-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-top { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 860px) {
    .main-nav, .header-phone { display: none; }
    .nav-toggle { display: inline-flex; }
    .hero .container, .calc-wrap { grid-template-columns: 1fr; gap: 32px; }
    .hero-media { aspect-ratio: 16/10; }
    .trustbar .grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .footer-top { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    :root { --h1-size: 32px; --h2-size: 26px; }
    .section { padding-block: var(--space-16); }
    .post-grid, .trustbar .grid, .footer-top { grid-template-columns: 1fr; }
    .cta-row .btn { flex: 1; }
    .footer-bottom .container { flex-direction: column; align-items: flex-start; }
}
