/** Shopify CDN: Minification failed

Line 15:0 All "@import" rules must come first

**/
/* Anchor scroll target for CTAs that link to #buy-box (the tier list inside the purchase panel) */
.mat #buy-box { scroll-margin-top: 96px; }
html { scroll-behavior: smooth; }
/* ============================================================
MAT PDP — Relievian Earth Mat
Scoped under .mat — does NOT inherit Impulse theme styles
100% fidelity to source HTML (Earth-Forest Clinical palette)
============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,400;8..60,500;8..60,600&display=swap');

.mat {
--bg: #FFFFFF;
--bg-card: #FFFFFF;
--bg-soft: #F4F0E8;
--ink: #1A2A1F;
--ink-soft: #5A6B5F;
--ink-mute: #8A9088;
--ink-line: #DDE3DC;
--primary: #2D5F3F;
--primary-dark: #1F4530;
--primary-soft: #EAF1EC;
--accent: #4A9D6E;
--accent-dark: #3A7E58;
--accent-soft: #EAF1EC;
--green: #4A9D6E;
--green-soft: #EAF1EC;
--gold: #C89B3C;
--maxw: 1200px;
--maxw-narrow: 760px;
--font-display: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
--font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
--font-accent: 'Source Serif 4', Georgia, serif;

font-family: var(--font-body);
background: var(--bg);
color: var(--ink);
line-height: 1.55;
font-size: 16px;
-webkit-font-smoothing: antialiased;
}
.mat, .mat *, .mat *::before, .mat *::after { box-sizing: border-box; }
.mat img { max-width: 100%; display: block; }
.mat a { color: inherit; }
.mat h1, .mat h2, .mat h3, .mat h4 { margin: 0; font-family: var(--font-display); color: var(--ink); }
.mat ul, .mat ol { margin: 0; padding: 0; }
.mat p { margin: 0; }
.mat button { font-family: inherit; }

/* ANNOUNCEMENT BAR */
.mat .announce {
background: var(--ink);
color: white;
text-align: center;
padding: 10px 16px;
font-size: 13px;
letter-spacing: 0.5px;
font-weight: 500;
}

/* NAV */
.mat .mat-nav {
background: var(--bg);
border-bottom: 1px solid var(--ink-line);
padding: 16px 24px;
display: flex;
justify-content: space-between;
align-items: center;
max-width: var(--maxw);
margin: 0 auto;
}
.mat .mat-logo {
font-family: var(--font-body);
font-weight: 800;
font-size: 18px;
letter-spacing: 3px;
color: var(--ink);
display: flex;
align-items: center;
gap: 4px;
text-decoration: none;
}
.mat .mat-logo .dot { color: var(--accent); font-size: 26px; line-height: 0; transform: translateY(-2px); }
.mat .mat-nav-right { font-size: 13px; color: var(--ink-soft); }

/* IMAGE PLACEHOLDERS */
.mat .img-placeholder {
background: linear-gradient(135deg, #F4F0E8 0%, #EAF1EC 100%);
border: 2px dashed var(--primary);
border-radius: 8px;
padding: 24px 20px;
position: relative;
width: 100%;
}
.mat .img-placeholder.aspect-square { aspect-ratio: 1/1; display: flex; flex-direction: column; justify-content: center; }
.mat .img-placeholder.aspect-wide { aspect-ratio: 16/9; display: flex; flex-direction: column; justify-content: center; }
.mat .img-placeholder.aspect-tall { aspect-ratio: 4/5; display: flex; flex-direction: column; justify-content: center; }
.mat .img-placeholder.small { padding: 16px 14px; }
.mat .img-placeholder::before {
content: "📷";
position: absolute;
top: -10px; left: 14px;
background: var(--accent);
color: white;
font-size: 11px;
font-weight: 700;
padding: 4px 10px;
letter-spacing: 1px;
border-radius: 3px;
}
.mat .img-placeholder .img-title {
font-weight: 700; font-size: 13px; color: var(--ink);
text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px;
}
.mat .img-placeholder .img-desc { font-size: 13px; color: var(--ink-soft); line-height: 1.5; margin-bottom: 6px; }
.mat .img-placeholder .img-dims { font-size: 11px; color: var(--ink-mute); font-style: italic; }
.mat .real-img { border-radius: 8px; overflow: hidden; }
.mat .real-img img { width: 100%; height: auto; display: block; }

/* HERO LAYOUT */
.mat .hero-section {
max-width: var(--maxw);
margin: 0 auto;
padding: 24px 24px 32px;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 48px;
align-items: start;
}
@media (max-width: 900px) { .mat .hero-section { grid-template-columns: 1fr; gap: 10px; } }
@media (min-width: 901px) {
.mat .product-gallery {
  min-width: 0; 
  width: 100%;
}
}
.mat .thumb-row {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 8px;
margin-top: 12px;
}
.mat .thumb-row .img-placeholder { padding: 12px 8px; }
.mat .thumb-row .img-placeholder .img-title { font-size: 10px; margin-bottom: 4px; }
.mat .thumb-row .img-placeholder .img-desc { font-size: 10px; line-height: 1.3; }
.mat .thumb-row .img-placeholder::before { font-size: 9px; padding: 2px 6px; }
.mat .thumb-row .real-img { aspect-ratio: 1/1; cursor: pointer; }
.mat .thumb-row .real-img img { height: 100%; object-fit: cover; }
.mat .thumb-row .real-img.active { outline: 2px solid var(--accent); outline-offset: 2px; }

/* PURCHASE PANEL */
.mat .stars { color: var(--gold); font-size: 18px; letter-spacing: 1px; }
.mat .review-count { color: var(--ink-mute); font-size: 13px; font-weight: 500; margin-left: 8px; }
.mat .product-eyebrow {
font-family: var(--font-display);
font-size: 13px; font-weight: 700; color: var(--primary);
text-transform: uppercase; letter-spacing: 2.8px;
margin: 18px 0 8px; line-height: 1.3;
}
.mat .product-name {
font-family: var(--font-display);
font-size: 44px; font-weight: 800;
line-height: 1.05; letter-spacing: -1.5px;
color: var(--ink); margin: 0 0 14px;
}
@media (max-width: 600px) { .mat .product-name { font-size: 34px; } }
.mat .product-tagline {
font-family: var(--font-accent);
font-size: 19px; color: var(--ink-soft);
line-height: 1.5; margin-bottom: 22px;
font-style: italic; font-weight: 400;
}
.mat .guarantee-link {
display: inline-flex; align-items: center; gap: 6px;
font-size: 13px; color: var(--accent);
border-bottom: 1px solid var(--accent);
padding-bottom: 2px; margin-bottom: 24px;
font-weight: 600; letter-spacing: 0.3px;
text-decoration: none;
}
.mat .feature-row {
display: grid; grid-template-columns: repeat(4, 1fr);
gap: 10px; margin-bottom: 24px;
padding: 14px 0;
border-top: 1px solid var(--ink-line);
border-bottom: 1px solid var(--ink-line);
}
.mat .feature-row .feat {
text-align: center; font-size: 11px;
color: var(--ink-soft); line-height: 1.3; font-weight: 500;
}
.mat .feature-row .feat-icon { font-size: 20px; display: block; margin-bottom: 4px; }

/* PRICING TIERS */
.mat .tier-list { margin-bottom: 22px; }
.mat .tier {
border: 2px solid var(--ink-line);
border-radius: 8px;
padding: 18px 18px;
margin-bottom: 12px;
cursor: pointer;
transition: border-color 0.2s, background 0.2s;
background: var(--bg-card);
position: relative;
}
.mat .tier.selected { border-color: var(--accent); background: var(--accent-soft); }
.mat .tier-tag {
position: absolute; top: -10px; right: 14px;
background: var(--accent); color: white;
font-size: 10px; font-weight: 700;
padding: 4px 10px; border-radius: 3px;
letter-spacing: 1px; text-transform: uppercase;
}
.mat .tier-tag.gold { background: var(--gold); }
.mat .tier-row {
display: flex; justify-content: space-between;
align-items: baseline; gap: 12px;
}
.mat .tier-name { font-family: var(--font-display); font-size: 19px; font-weight: 700; color: var(--ink); }
.mat .tier-per { font-size: 12px; color: var(--ink-mute); margin-top: 2px; }
.mat .tier-price { text-align: right; }
.mat .tier-price .now { font-family: var(--font-display); font-size: 22px; font-weight: 700; color: var(--ink); }
.mat .tier-price .was { font-size: 13px; color: var(--ink-mute); text-decoration: line-through; display: block; }

/* CTA */
.mat .cta {
width: 100%; background: var(--accent); color: white;
border: none; border-radius: 8px;
padding: 18px 24px;
font-family: var(--font-body);
font-weight: 700; font-size: 17px;
letter-spacing: 1.2px; text-transform: uppercase;
cursor: pointer; transition: background 0.2s;
box-shadow: 0 4px 14px rgba(74, 157, 110, 0.22);
text-decoration: none;
display: inline-block;
text-align: center;
}
.mat .cta:hover { background: var(--accent-dark); }
.mat .ship-row {
display: grid; grid-template-columns: 1fr 1fr;
gap: 16px; margin-top: 16px; padding: 14px 0;
}
.mat .ship-row .ship-item {
display: flex; gap: 10px; align-items: center;
font-size: 13px; color: var(--ink-soft);
}
.mat .ship-row .ship-icon { font-size: 22px; flex-shrink: 0; }
.mat .quick-trust {
text-align: center; margin-top: 14px;
font-size: 12px; color: var(--ink-mute); letter-spacing: 0.3px;
}

/* TRUST STRIP */
.mat .trust-strip {
background: var(--bg-soft);
border-top: 1px solid var(--ink-line);
border-bottom: 1px solid var(--ink-line);
padding: 24px 24px;
}
.mat .trust-strip-inner { max-width: var(--maxw); margin: 0 auto; text-align: center; }
.mat .trust-strip-label {
font-size: 11px; color: var(--ink-mute);
text-transform: uppercase; letter-spacing: 3px;
margin-bottom: 22px; font-weight: 600;
}
/* Contenedor principal: Cambiamos a Flexbox para centrado dinámico sin importar la cantidad de tarjetas */
/* Contenedor principal flexbox */
/* 1. Reducimos el espacio ENTRE las tarjetas (Gap) */
.mat .trust-logos {
display: flex;
flex-wrap: wrap;
justify-content: center;
align-items: stretch;
gap: 12px; /* Reducido de 24px a 12px para que estén más juntas */
}

@media (max-width: 700px) {
.mat .trust-logos { gap: 10px; } /* Aún más compacto en móvil */
}

/* Nuevo contenedor individual que agrupa la foto (fuera) y el texto (dentro del borde) */
.mat .trust-item {
display: flex;
flex-direction: column;
align-items: center;
flex: 0 1 200px; /* Ancho base máximo */
width: 100%;
}

@media (max-width: 700px) {
.mat .trust-item { flex: 0 1 calc(50% - 8px); }
}

/* La foto libre, más grande y por fuera del recuadro */
.mat .trust-logo-img {
width: 110px; /* Aumentamos el tamaño */
height: 110px;
object-fit: cover;
border-radius: 8px; /* O puedes usar 50% si prefieres círculos perfectos */
margin: 0 auto 16px auto; /* Separación con el recuadro verde */
display: block;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); /* Opcional: un toque de profundidad premium */
}

/* 2. Hacemos el recuadro verde mucho más compacto por dentro */
.mat .logo-text-box {
/* Eliminamos background, border y border-radius */
padding: 0 10px; /* Solo dejamos un poco de margen a los lados */
text-align: center;
font-size: 11px;
color: var(--ink); /* Oscurecemos un poco el texto para que resalte sin el fondo */
line-height: 1.2;
width: 100%;
display: flex;
flex-direction: column;
justify-content: flex-start; /* Alineamos el texto hacia arriba, pegado a la foto */
flex-grow: 1;
}

.mat .logo-text-box strong {
color: var(--ink);
display: block;
margin-bottom: 2px; /* Un pequeñísimo respiro entre el nombre y el subtítulo */
font-size: 12px;
}

/* SECTIONS SHARED */
.mat section.cs { max-width: var(--maxw); margin: 0 auto; padding: 48px 24px; }
.mat section.cs.narrow { max-width: var(--maxw-narrow); }
.mat section.bg-tinted { background: var(--bg-soft); }
.mat section.bg-tinted .cs-inner { max-width: var(--maxw); margin: 0 auto; padding: 48px 24px; }

.mat .eyebrow {
text-align: center; font-size: 11px;
color: var(--primary); text-transform: uppercase;
letter-spacing: 3px; font-weight: 700; margin-bottom: 14px;
}
.mat h2.section-title {
font-family: var(--font-display);
font-size: 42px; font-weight: 800;
line-height: 1.1; letter-spacing: -1.2px;
text-align: center; color: var(--ink);
margin-bottom: 16px;
}
@media (max-width: 600px) { .mat h2.section-title { font-size: 32px; } }
.mat .section-sub {
text-align: center; font-family: var(--font-body);
font-size: 18px; line-height: 1.6;
color: var(--ink-soft); max-width: 640px;
margin: 0 auto 48px; font-weight: 400;
}

/* REFRAME */
.mat .reframe-grid {
display: grid; grid-template-columns: 1fr 1fr;
gap: 56px; align-items: start; margin-top: 24px;
}
@media (max-width: 800px) { .mat .reframe-grid { grid-template-columns: 1fr; gap: 32px; } }
.mat .reframe-list {
background: var(--bg-card); border: 1px solid var(--ink-line);
border-radius: 8px; padding: 32px 28px;
}
.mat .reframe-list h3 {
font-family: var(--font-display); font-size: 22px;
color: var(--primary); font-weight: 700;
margin-bottom: 16px; letter-spacing: -0.3px;
}
.mat .reframe-list ul { list-style: none; }
.mat .reframe-list li {
padding: 12px 0 12px 28px;
border-bottom: 1px solid var(--ink-line);
position: relative; font-family: var(--font-body);
font-size: 16px; color: var(--ink-soft); line-height: 1.5;
}
.mat .reframe-list li:last-child { border-bottom: none; }
.mat .reframe-list li::before {
content: "✓"; position: absolute;
left: 0; top: 12px; color: var(--accent);
font-weight: 700; font-size: 16px;
}
.mat .reframe-copy h3 {
font-family: var(--font-display); font-size: 30px;
line-height: 1.2; font-weight: 800;
color: var(--ink); margin-bottom: 22px; letter-spacing: -0.7px;
}
.mat .reframe-copy p {
font-family: var(--font-body); font-size: 16px;
line-height: 1.7; color: var(--ink-soft); margin-bottom: 16px;
}
.mat .reframe-copy p strong { color: var(--ink); font-weight: 600; }

/* BENEFIT GRID */
.mat .benefit-row {
display: grid; grid-template-columns: 1fr 1fr;
gap: 32px; align-items: center; margin-bottom: 60px;
}
.mat .benefit-row.reverse { direction: rtl; }
.mat .benefit-row.reverse > * { direction: ltr; }
@media (max-width: 700px) {
.mat .benefit-row, .mat .benefit-row.reverse {
grid-template-columns: 1fr; direction: ltr; gap: 20px;
}
}
.mat .benefit-text h3 {
font-family: var(--font-display); font-size: 28px;
font-weight: 800; line-height: 1.15;
color: var(--ink); margin-bottom: 16px; letter-spacing: -0.7px;
}
.mat .benefit-text p {
font-family: var(--font-body); font-size: 16px;
line-height: 1.7; color: var(--ink-soft);
}

/* MID CTA */
.mat .mid-cta {
background: var(--primary);
color: white; text-align: center;
padding: 40px 24px; margin: 24px 0;
}
.mat .mid-cta h3 {
font-family: var(--font-accent);
font-size: 30px; font-weight: 500;
font-style: italic; line-height: 1.35;
margin: 0 auto 14px; letter-spacing: -0.3px;
max-width: 720px; color: white;
}
.mat .mid-cta p {
font-family: var(--font-body); font-size: 14px;
color: #C5D4C8; margin-bottom: 28px;
text-transform: uppercase; letter-spacing: 2px; font-weight: 500;
}
.mat .mid-cta .cta-inline {
display: inline-block; background: var(--accent);
color: white; text-decoration: none;
padding: 16px 36px; border-radius: 8px;
font-size: 14px; font-weight: 700;
letter-spacing: 1.5px; text-transform: uppercase;
transition: background 0.2s;
}
.mat .mid-cta .cta-inline:hover { background: var(--accent-dark); }
.mat .mid-cta .trust-line {
margin-top: 22px; font-size: 12px;
color: #C5D4C8; letter-spacing: 1.5px;
}

/* BOX */
.mat .box-grid {
display: grid; grid-template-columns: 1fr 1fr;
gap: 48px; align-items: center; margin-top: 40px;
}
@media (max-width: 800px) { .mat .box-grid { grid-template-columns: 1fr; } }
.mat .box-list { list-style: none; counter-reset: boxn; }
.mat .box-list li {
padding: 18px 0 18px 44px;
border-bottom: 1px solid var(--ink-line);
position: relative;
}
.mat .box-list li::before {
content: counter(boxn); counter-increment: boxn;
position: absolute; left: 0; top: 18px;
width: 30px; height: 30px;
background: var(--primary); color: white;
border-radius: 50%; display: flex;
align-items: center; justify-content: center;
font-size: 13px; font-weight: 700;
font-family: var(--font-display);
}
.mat .box-list li strong {
font-family: var(--font-display); font-size: 18px;
color: var(--ink); font-weight: 700;
display: block; margin-bottom: 6px; letter-spacing: -0.2px;
}
.mat .box-list li span {
font-family: var(--font-body); font-size: 15px;
color: var(--ink-soft); line-height: 1.6;
}

/* MECHANISM */
.mat .mech-card {
background: var(--bg-soft); border: 1px solid var(--ink-line);
border-radius: 10px; padding: 56px 44px;
max-width: 760px; margin: 60px auto; text-align: center;
}
.mat .mech-card .mech-label {
font-size: 11px; letter-spacing: 3px;
text-transform: uppercase; color: var(--primary);
font-weight: 700; margin-bottom: 16px;
}
.mat .mech-card h3 {
font-family: var(--font-display); font-size: 30px;
font-weight: 800; color: var(--ink);
margin-bottom: 22px; letter-spacing: -0.7px; line-height: 1.2;
}
.mat .mech-card p {
font-family: var(--font-body); font-size: 17px;
line-height: 1.7; color: var(--ink-soft); margin-bottom: 14px;
}

/* REVIEWS */
.mat .reviews-summary { text-align: center; margin-bottom: 36px; }
.mat .big-rating {
font-family: var(--font-display); font-size: 56px;
font-weight: 700; color: var(--ink); line-height: 1; margin-bottom: 6px;
}
.mat .reviews-grid {
display: grid; grid-template-columns: repeat(3, 1fr);
gap: 20px; margin-bottom: 28px;
}
@media (max-width: 900px) { .mat .reviews-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .mat .reviews-grid { grid-template-columns: 1fr; } }
.mat .review-card {
background: var(--bg-card); border: 1px solid var(--ink-line);
border-radius: 8px; padding: 24px 22px;
display: flex; flex-direction: column;
}
.mat .review-header {
display: flex; justify-content: space-between;
align-items: center; margin-bottom: 8px;
}
.mat .review-author {
font-weight: 600; font-size: 14px; color: var(--ink);
display: flex; align-items: center; gap: 6px;
}
.mat .verified {
background: var(--green); color: white; border-radius: 50%;
width: 14px; height: 14px;
display: inline-flex; align-items: center; justify-content: center;
font-size: 9px;
}
.mat .review-date { font-size: 12px; color: var(--ink-mute); }
.mat .review-stars { color: var(--gold); font-size: 14px; margin-bottom: 10px; }
.mat .review-img-placeholder {
background: linear-gradient(135deg, #F4F0E8 0%, #EAF1EC 100%);
border: 1px dashed var(--primary);
border-radius: 6px; padding: 14px 12px; margin-bottom: 12px;
font-size: 11px; color: var(--ink-soft); line-height: 1.3;
aspect-ratio: 4/3; display: flex; flex-direction: column;
justify-content: center; text-align: center;
}
.mat .review-img-placeholder strong { display: block; color: var(--ink); margin-bottom: 4px; font-size: 11px; }
.mat .review-real-img { aspect-ratio: 4/3; border-radius: 6px; overflow: hidden; margin-bottom: 12px; }
.mat .review-real-img img { width: 100%; height: 100%; object-fit: cover; }
.mat .review-text {
font-family: var(--font-body); font-size: 15px;
line-height: 1.55; color: var(--ink-soft);
margin-bottom: 12px; flex-grow: 1;
}
.mat .review-meta {
font-size: 11px; color: var(--ink-mute);
border-top: 1px solid var(--ink-line);
padding-top: 10px; margin-top: auto;
}
.mat .brand-reply {
background: var(--primary-soft);
border-left: 3px solid var(--primary);
padding: 14px 16px;
margin: 14px 0 4px;
font-size: 13px; color: var(--ink-soft);
border-radius: 0 6px 6px 0; line-height: 1.55;
}
.mat .brand-reply strong { color: var(--primary); display: block; margin-bottom: 4px; font-size: 13px; font-weight: 700; }
.mat .show-more {
display: block; text-align: center;
border: 1px solid var(--ink); background: white;
padding: 14px 24px; color: var(--ink);
text-decoration: none; font-weight: 600;
border-radius: 6px; width: fit-content;
margin: 0 auto; font-size: 14px; letter-spacing: 0.5px;
}

/* FOUNDER */
.mat .founder-card {
background: var(--bg-card); border: 1px solid var(--ink-line);
border-radius: 10px; padding: 48px 40px;
max-width: 780px; margin: 0 auto;
display: grid; grid-template-columns: 180px 1fr;
gap: 36px; align-items: start;
}
@media (max-width: 700px) { .mat .founder-card { grid-template-columns: 1fr; padding: 32px 24px; gap: 20px; } }
.mat .founder-photo-placeholder {
aspect-ratio: 4/5;
background: linear-gradient(135deg, #F4F0E8 0%, #EAF1EC 100%);
border: 2px dashed var(--primary);
border-radius: 8px; padding: 16px 12px;
display: flex; flex-direction: column; justify-content: center;
font-size: 11px; color: var(--ink-soft); line-height: 1.4;
}
.mat .founder-photo-placeholder strong { color: var(--ink); display: block; margin-bottom: 4px; font-size: 12px; }
.mat .founder-real-img { aspect-ratio: 4/5; border-radius: 8px; overflow: hidden; }
.mat .founder-real-img img { width: 100%; height: 100%; object-fit: cover; }
.mat .founder-text h3 {
font-family: var(--font-display); font-size: 28px;
font-weight: 800; color: var(--ink);
margin-bottom: 18px; letter-spacing: -0.6px; line-height: 1.2;
}
.mat .founder-text p {
font-family: var(--font-accent); font-size: 17px;
line-height: 1.7; color: var(--ink-soft); margin-bottom: 14px;
}
.mat .founder-text .signature {
font-family: var(--font-accent); font-style: italic;
font-size: 19px; color: var(--primary);
margin-top: 22px; font-weight: 500;
}

/* GUARANTEE */
.mat .guarantee-card {
background: var(--primary-soft); border: 2px solid var(--primary);
border-radius: 12px; padding: 52px 40px;
max-width: 760px; margin: 0 auto;
text-align: center; position: relative;
}
.mat .guarantee-badge {
width: 110px; height: 110px;
background: var(--primary); border-radius: 50%;
color: white; display: flex; flex-direction: column;
align-items: center; justify-content: center;
font-family: var(--font-display); font-weight: 800;
margin: -85px auto 28px;
box-shadow: 0 6px 20px rgba(45, 95, 63, 0.3);
border: 4px solid white;
}
.mat .guarantee-badge .num { font-size: 34px; line-height: 1; letter-spacing: -1px; }
.mat .guarantee-badge .lbl { font-size: 11px; letter-spacing: 1.5px; margin-top: 4px; text-transform: uppercase; font-family: var(--font-body); font-weight: 700; }
.mat .guarantee-card h3 {
font-family: var(--font-display); font-size: 30px;
font-weight: 800; color: var(--ink);
margin-bottom: 22px; letter-spacing: -0.7px; line-height: 1.2;
}
.mat .guarantee-card p {
font-family: var(--font-body); font-size: 16px;
line-height: 1.7; color: var(--ink-soft); margin-bottom: 14px;
}
.mat .guarantee-card p strong { color: var(--ink); font-weight: 600; }
.mat .guarantee-card .ital {
font-family: var(--font-accent); font-style: italic;
color: var(--primary); font-size: 19px;
margin-top: 22px; font-weight: 500;
}


/* GUARANTEE eyebrow needs extra clearance because badge has margin-top: -85px */
.mat #guarantee { padding-top: 24px; }
.mat #guarantee .eyebrow { margin-bottom: 56px; }

/* FAQ */
.mat .faq-list { max-width: 760px; margin: 0 auto; }
.mat details.faq { border-bottom: 1px solid var(--ink-line); padding: 0; }
.mat details.faq summary {
cursor: pointer; padding: 24px 0;
font-family: var(--font-display); font-size: 18px;
font-weight: 700; color: var(--ink);
list-style: none;
display: flex; justify-content: space-between; align-items: center;
line-height: 1.35; letter-spacing: -0.2px;
}
.mat details.faq summary:hover { color: var(--primary); }
.mat details.faq summary::-webkit-details-marker { display: none; }
.mat details.faq summary::after {
content: "+"; font-size: 28px; color: var(--primary);
font-weight: 300; transition: transform 0.2s; margin-left: 16px;
}
.mat details.faq[open] summary::after { content: "−"; }
.mat details.faq .faq-body {
padding: 0 0 24px;
font-family: var(--font-body); font-size: 16px;
line-height: 1.7; color: var(--ink-soft);
}
.mat details.faq .faq-body p { margin-bottom: 14px; }
.mat details.faq .faq-body p:last-child { margin-bottom: 0; }
.mat details.faq .faq-body strong { color: var(--ink); font-weight: 600; }

/* FINAL CTA */
.mat .final-cta {
background: var(--primary); color: white;
padding: 56px 24px; text-align: center;
}
.mat .final-cta h2 {
font-family: var(--font-display); font-size: 44px;
font-weight: 800; line-height: 1.1;
letter-spacing: -1.5px; max-width: 780px;
margin: 0 auto 22px; color: white;
}
@media (max-width: 600px) { .mat .final-cta h2 { font-size: 32px; } }
.mat .final-cta p {
font-family: var(--font-accent); font-size: 19px;
color: #C5D4C8; font-style: italic;
max-width: 580px; margin: 0 auto 32px; line-height: 1.55;
}
.mat .final-cta .cta {
width: auto; padding: 20px 48px;
font-size: 16px; background: var(--accent);
box-shadow: 0 6px 20px rgba(74, 157, 110, 0.4);
}
.mat .final-cta .cta:hover { background: var(--accent-dark); }

/* FOOTER */
.mat .mat-footer {
background: #1A2A1F; color: #A8B5AB;
padding: 50px 24px 30px; font-size: 13px;
}
.mat .mat-footer-inner {
max-width: var(--maxw); margin: 0 auto;
display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
gap: 36px; margin-bottom: 36px;
}
@media (max-width: 700px) { .mat .mat-footer-inner { grid-template-columns: 1fr 1fr; gap: 24px; } }
.mat .mat-footer h4 {
color: white; font-size: 13px; font-weight: 700;
letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 14px;
}
.mat .mat-footer .footer-logo {
font-family: var(--font-body); font-size: 16px;
color: white; font-weight: 800; letter-spacing: 3px;
margin-bottom: 12px; display: flex; align-items: center; gap: 4px;
}
.mat .mat-footer .footer-logo .dot {
color: var(--accent); font-size: 26px;
line-height: 0; margin-right: 2px;
font-weight: 900; transform: translateY(-2px);
}
.mat .mat-footer ul { list-style: none; }
.mat .mat-footer ul li { padding: 5px 0; }
.mat .mat-footer ul li a { color: #A8B5AB; text-decoration: none; }
.mat .mat-footer ul li a:hover { color: white; }
.mat .footer-bottom {
max-width: var(--maxw); margin: 0 auto;
border-top: 1px solid #2D4032; padding-top: 22px;
font-size: 11px; color: #7A8580; line-height: 1.7;
}

/* Mobile: keep announcement bar on a single line without shrinking too much */
@media (max-width: 700px) {
.mat .announce {
font-size: 12px; letter-spacing: 0.2px;
padding: 9px 12px;
white-space: nowrap; overflow: hidden;
text-overflow: ellipsis;
}
}
@media (max-width: 420px) {
.mat .announce {
font-size: 11px; letter-spacing: 0.1px;
padding: 8px 10px;
}
}

/* Mobile: compact CTA buttons to one line without going too small */
@media (max-width: 700px) {
.mat .mid-cta .cta-inline {
font-size: 14.5px; padding: 15px 24px;
letter-spacing: 0.7px; white-space: nowrap;
max-width: 100%; box-sizing: border-box;
}
.mat .final-cta .cta {
font-size: 14.5px; padding: 16px 26px;
letter-spacing: 0.7px; white-space: nowrap;
max-width: 100%; box-sizing: border-box;
}
.mat .cta {
font-size: 15px; padding: 16px 20px;
letter-spacing: 0.7px;
}
}
@media (max-width: 420px) {
.mat .mid-cta .cta-inline,
.mat .final-cta .cta {
font-size: 12.5px; padding: 13px 16px;
letter-spacing: 0.4px;
}
}

/* Mobile: even more compact spacing between sections */
@media (max-width: 700px) {
.mat section.cs { padding: 32px 20px; }
.mat section.bg-tinted .cs-inner { padding: 32px 20px; }
.mat .hero-section { padding: 16px 20px 24px; }
.mat .mid-cta { padding: 28px 20px; margin: 16px 0; }
.mat .trust-strip { padding: 18px 20px; }
.mat .final-cta { padding: 40px 20px; }
}

/* Logo image inside .mat-logo (and footer logo) */
.mat .mat-logo-img { display: block; height: 36px; width: auto; max-width: 220px; }
.mat .footer-logo-img { display: block; height: 32px; width: auto; max-width: 200px; filter: brightness(0) invert(1); }
@media (max-width: 700px) { .mat .mat-logo-img { height: 28px; max-width: 160px; } }


/* GALERÍA SLIDER NATIVO */
.mat .gallery-slider {
display: flex;
overflow-x: auto;
scroll-snap-type: x mandatory;
scroll-behavior: smooth;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
aspect-ratio: 1/1;
border-radius: 8px;
width: 100%;
cursor: grab; /* Muestra la manito en escritorio para indicar que es arrastrable */
}
.mat .gallery-slider::-webkit-scrollbar {
display: none; /* Oculta barra en Chrome/Safari/Edge */
}
.mat .gallery-slide {
flex: 0 0 100%;
min-width: 100%;
scroll-snap-align: start;
display: flex;
align-items: center;
justify-content: center;
background: var(--bg-soft);
position: relative;
}
.mat .gallery-slide img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
/* ESTA ES LA MAGIA: Evita que el navegador agarre la imagen como archivo */
-webkit-user-drag: none;
-khtml-user-drag: none;
-moz-user-drag: none;
-o-user-drag: none;
user-drag: none;
user-select: none;
-moz-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
pointer-events: none; /* Hace que el clic pase directamente a la caja del slider */
}


/* ============================================================
PATCH GALERÍA PRODUCTO
- Flechas dentro de la imagen principal
- Miniaturas en una sola fila con scroll horizontal
- Sin desplazar márgenes ni crear overflow del body
============================================================ */

.mat .hero-section > * {
  min-width: 0;
}

.mat .product-gallery {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.mat .gallery-slider-wrap {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  border-radius: 8px;
}

.mat .gallery-slider {
  width: 100%;
  max-width: 100%;
}

/* Flechas encima/dentro de la imagen principal */
.mat .gallery-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;

  width: 42px;
  height: 42px;
  border-radius: 999px;

  display: flex;
  align-items: center;
  justify-content: center;

  padding: 0;
  margin: 0;
  border: 1px solid rgba(26, 42, 31, 0.16);
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);

  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);

  appearance: none;
  -webkit-appearance: none;
}

.mat .gallery-arrow.prev {
  left: 12px;
}

.mat .gallery-arrow.next {
  right: 12px;
}

.mat .gallery-arrow svg {
  display: block;
  pointer-events: none;
}

/* Miniaturas: una sola fila con scroll horizontal */
.mat .thumb-row {
  display: flex;
  grid-template-columns: none;
  flex-wrap: nowrap;

  gap: 8px;
  width: 100%;
  max-width: 100%;
  min-width: 0;

  margin-top: 12px;
  padding: 3px 2px 8px;

  overflow-x: auto;
  overflow-y: hidden;

  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.mat .thumb-row .real-img {
  flex: 0 0 calc((100% - 24px) / 4);
  width: calc((100% - 24px) / 4);
  min-width: calc((100% - 24px) / 4);

  aspect-ratio: 1 / 1;
  cursor: pointer;
  scroll-snap-align: start;
}

.mat .thumb-row .real-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Scroll horizontal visible pero limpio */
.mat .thumb-row::-webkit-scrollbar {
  height: 6px;
}

.mat .thumb-row::-webkit-scrollbar-track {
  background: transparent;
}

.mat .thumb-row::-webkit-scrollbar-thumb {
  background: rgba(26, 42, 31, 0.22);
  border-radius: 999px;
}

.mat .thumb-row {
  scrollbar-width: thin;
}

/* Ajuste móvil para que no se comprima ni desplace la página */
@media (max-width: 700px) {
  .mat .gallery-arrow {
    width: 36px;
    height: 36px;
  }

  .mat .gallery-arrow.prev {
    left: 8px;
  }

  .mat .gallery-arrow.next {
    right: 8px;
  }

  .mat .thumb-row .real-img {
    flex-basis: 78px;
    width: 78px;
    min-width: 78px;
  }
}

/* Ocultar flechas del slider solo en móvil */
@media (max-width: 700px) {
  .mat .gallery-arrow {
    display: none !important;
  }
}

/* Miniaturas: permitir arrastre con mouse en escritorio */
.mat .thumb-row {
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}

.mat .thumb-row.is-dragging {
  cursor: grabbing;
}

.mat .thumb-row img {
  pointer-events: none;
  -webkit-user-drag: none;
  user-drag: none;
}