/* =========================================================
   Reperreus — style.css
   Paleta: rojo #C62828 + grafito #263238 · estilo limpio
   ========================================================= */

/* Fallback métrico para evitar CLS de fuente */
@font-face{
  font-family:'system-ui-fallback';src:local('Arial');
  size-adjust:104%;ascent-override:105%;descent-override:35%;line-gap-override:0%;
}

:root{
  --color-principal:#C62828;
  --color-principal-osc:#A01E1E;
  --color-principal-claro:#E57373;
  --color-secundario:#263238;
  --color-secundario-claro:#37474F;
  --text:#212121;
  --text-suave:#546E7A;
  --white:#ffffff;
  --bg-light:#F5F6F7;
  --border:#E0E0E0;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 4px 16px rgba(38,50,56,.08);
  --shadow-hover:0 8px 28px rgba(38,50,56,.14);
  --container:1180px;
  --space:clamp(48px,7vw,88px);
  --font:'Poppins','system-ui-fallback',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--text);line-height:1.65;background:var(--white);font-size:17px;overflow-x:hidden}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--color-principal);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;color:var(--color-secundario);font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4.5vw,2.9rem);font-weight:800}
h2{font-size:clamp(1.5rem,3.2vw,2.1rem)}
h3{font-size:1.25rem}
p{color:var(--text-suave)}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
section{padding:var(--space) 0}
.bg-light{background:var(--bg-light)}

/* ── Etiqueta de sección ── */
.section-label{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--color-principal);margin-bottom:10px}
.section-label.on-dark{color:#fff}
.section-head{text-align:center;max-width:720px;margin:0 auto 44px}
.section-head p{margin-top:10px}

/* ── Botones ── */
.btn-primary,.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;font-size:1rem;padding:14px 26px;border-radius:var(--radius-sm);
  border:2px solid transparent;cursor:pointer;transition:transform .15s,background .15s,box-shadow .15s;
  text-decoration:none;line-height:1}
.btn-primary{background:var(--color-principal);color:#fff}
.btn-primary:hover{background:var(--color-principal-osc);text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.12);text-decoration:none}
.btn-secondary{background:var(--color-secundario);color:#fff}
.btn-secondary:hover{background:var(--color-secundario-claro);text-decoration:none;transform:translateY(-2px)}

/* ── HEADER ── */
header{position:sticky;top:0;z-index:900;background:#fff;box-shadow:0 1px 0 var(--border)}
.header-top{background:var(--color-secundario);color:#fff;font-size:.85rem}
.header-top-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:7px 20px}
.header-top a{color:#fff;font-weight:600}
.header-main{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 20px}
.logo img{height:46px;width:auto}
.nav-desktop{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav-desktop>a,.nav-link{padding:10px 14px;color:var(--color-secundario);font-weight:600;font-size:.97rem;
  background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:4px}
.nav-desktop>a:hover,.nav-link:hover{background:var(--bg-light);text-decoration:none}
.nav-desktop a[aria-current="page"]{color:var(--color-principal)}
.chevron{font-size:.7em}
.nav-dropdown{position:relative}
.nav-dropdown-menu{position:absolute;top:100%;left:0;min-width:240px;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s,transform .18s,visibility .18s;z-index:950}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{display:block;padding:10px 14px;color:var(--color-secundario);font-weight:500;border-radius:6px;font-size:.95rem}
.nav-dropdown-menu a:hover{background:var(--bg-light);text-decoration:none}
.header-cta{padding:10px 20px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:3px;background:var(--color-secundario);border-radius:2px;transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ── MENÚ MÓVIL (visibility, no display:none) ── */
.mobile-nav{display:flex;flex-direction:column;background:var(--white);border-top:1px solid var(--border);
  padding:12px 0;transform:translateY(-8px);opacity:0;visibility:hidden;pointer-events:none;
  position:absolute;left:0;right:0;top:100%;z-index:800;
  transition:transform .2s ease,opacity .2s ease,visibility .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.1);
  max-height:calc(100vh - 120px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-nav.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
.mobile-nav a,.mobile-dropdown-toggle{display:block;padding:12px 20px;color:var(--text);text-decoration:none;
  font-size:15px;font-weight:500;border:none;background:none;width:100%;text-align:left;font-family:inherit;cursor:pointer}
.mobile-nav a[aria-current="page"]{color:var(--color-principal);font-weight:700}
.mobile-dropdown-menu{overflow:hidden;max-height:0;transition:max-height .25s ease;background:var(--bg-light)}
.mobile-dropdown-menu.open{max-height:320px}
.mobile-dropdown-menu a{padding-left:36px;font-size:14px}
.mobile-cta{margin:12px 20px 4px;width:calc(100% - 40px);text-align:center}

/* ── HERO ── */
.hero{position:relative;color:#fff;min-height:clamp(420px,62vh,580px);display:flex;align-items:center;
  background:linear-gradient(rgba(38,50,56,.62),rgba(38,50,56,.62)),var(--hero-img) center/cover no-repeat;
  background-color:var(--color-secundario)}
.hero .container{position:relative;z-index:2}
.hero-inner{max-width:680px}
.hero h1{color:#fff;margin-bottom:18px}
.hero p{color:rgba(255,255,255,.92);font-size:1.15rem;margin-bottom:28px;max-width:600px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:26px;font-size:.92rem;color:rgba(255,255,255,.92)}
.hero-badges span{display:inline-flex;align-items:center;gap:7px}

/* ── Tarjetas de servicio ── */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.card img{width:100%;aspect-ratio:3/2;object-fit:cover}
.card-body{padding:22px;display:flex;flex-direction:column;flex:1}
.card-body h3{margin-bottom:8px}
.card-body p{font-size:.96rem;flex:1}
.card-link{margin-top:14px;font-weight:600;color:var(--color-principal);display:inline-flex;align-items:center;gap:6px}
.card-link:hover{text-decoration:none;gap:10px}

/* ── Por qué elegirnos ── */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.feature{display:flex;gap:14px;align-items:flex-start;background:#fff;padding:20px;border-radius:var(--radius);border:1px solid var(--border)}
.feature .ico{flex:0 0 42px;width:42px;height:42px;border-radius:10px;background:rgba(198,40,40,.1);
  display:grid;place-items:center;color:var(--color-principal);font-size:1.2rem;font-weight:800}
.feature h3{font-size:1.05rem;margin-bottom:4px}
.feature p{font-size:.92rem}

/* ── Listas (averías / tipos) ── */
.check-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px 28px}
.check-list li{position:relative;padding-left:30px;color:var(--text);line-height:1.55}
.check-list li::before{content:"";position:absolute;left:0;top:7px;width:18px;height:18px;border-radius:50%;
  background:var(--color-principal);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z' fill='white'/></svg>") center/13px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z' fill='white'/></svg>") center/13px no-repeat}

/* ── Proceso ── */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;counter-reset:step}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px 22px;position:relative}
.step::before{counter-increment:step;content:counter(step);display:grid;place-items:center;width:40px;height:40px;
  border-radius:50%;background:var(--color-principal);color:#fff;font-weight:800;margin-bottom:14px}
.step h3{font-size:1.08rem;margin-bottom:6px}
.step p{font-size:.93rem}

/* ── Coste ── */
.coste-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.coste-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center}
.coste-card .nivel{display:inline-block;margin:8px 0;padding:4px 14px;border-radius:20px;font-size:.82rem;font-weight:700;
  background:rgba(198,40,40,.1);color:var(--color-principal)}

/* ── Reseñas ── */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.review{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.stars{color:#F5A623;font-size:1.05rem;letter-spacing:2px;margin-bottom:10px}
.review p{color:var(--text);font-style:italic;margin-bottom:14px}
.review .who{font-weight:600;color:var(--color-secundario);font-style:normal;font-size:.95rem}
.review .date{display:block;font-size:.8rem;color:var(--text-suave);font-weight:400;margin-top:2px}
.rating-summary{text-align:center;margin-bottom:36px;font-weight:600;color:var(--color-secundario)}
.rating-summary .big{font-size:2.4rem;color:var(--color-principal);font-weight:800;line-height:1}

/* ── Zonas ── */
.zonas-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.zonas-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.zonas-list span{background:#fff;border:1px solid var(--border);border-radius:20px;padding:7px 16px;font-size:.9rem;color:var(--color-secundario);font-weight:500}
.zonas-img img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* ── FAQ ── */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:18px 22px;font-size:1.02rem;font-weight:600;
  color:var(--color-secundario);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;font-family:inherit}
.faq-q .plus{flex:0 0 auto;font-size:1.4rem;color:var(--color-principal);transition:transform .2s;line-height:1}
.faq-item.open .faq-q .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease}
.faq-a p{padding:0 22px 18px;font-size:.97rem}
.faq-item.open .faq-a{max-height:400px}

/* ── CTA banda ── */
.cta-band{background:linear-gradient(135deg,var(--color-secundario),var(--color-secundario-claro));color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.9);max-width:620px;margin:12px auto 26px}
.cta-band .hero-ctas{justify-content:center}

/* ── CONTACTO ── */
.contact-section{background:var(--bg-light)}
.contact-header{text-align:center;max-width:680px;margin:0 auto 40px}
.contact-header p{margin-top:8px}
.contact-grid{display:grid;grid-template-columns:1.3fr .8fr;gap:32px;align-items:start}
.contact-form-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-weight:600;font-size:.9rem;color:var(--color-secundario);margin-bottom:6px}
input,textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-family:inherit;font-size:1rem;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s}
input:focus,textarea:focus{outline:none;border-color:var(--color-principal);box-shadow:0 0 0 3px rgba(198,40,40,.15)}
.hp-field{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0}
.form-checkbox .checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-weight:400}
.form-checkbox input{position:absolute;opacity:0;width:0;height:0}
.checkbox-custom{flex:0 0 20px;width:20px;height:20px;border:2px solid var(--border);border-radius:5px;margin-top:2px;transition:.15s}
.form-checkbox input:checked+.checkbox-custom{background:var(--color-principal);border-color:var(--color-principal)}
.form-checkbox input:checked+.checkbox-custom::after{content:"✓";color:#fff;display:block;text-align:center;font-size:13px;line-height:18px}
.form-checkbox input:focus-visible+.checkbox-custom{box-shadow:0 0 0 3px rgba(198,40,40,.25)}
.checkbox-text{font-size:.88rem;color:var(--text-suave);line-height:1.5}
.btn-submit{width:100%;margin-top:6px}
.form-message{margin-top:14px;padding:12px 16px;border-radius:var(--radius-sm);font-size:.95rem}
.form-message.ok{background:#E8F5E9;color:#1B5E20}
.form-message.error{background:#FDECEA;color:#B71C1C}
.contact-info-wrap{display:flex;flex-direction:column;gap:16px}
.contact-info-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.contact-info-card h3{font-size:1rem;margin-bottom:8px}
.contact-info-card p{font-size:.92rem}
.contact-phone{font-size:1.4rem;font-weight:800;color:var(--color-principal)}
.contact-schedule{font-size:.85rem;margin-top:4px}
.contact-nap{font-style:normal;font-size:.92rem;color:var(--text-suave);line-height:1.7}
.contact-nap a{font-weight:600}

/* ── FOOTER ── */
.site-footer{background:var(--color-secundario);color:rgba(255,255,255,.8);padding:56px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:32px}
.footer-logo img{height:42px;margin-bottom:14px}
.footer-tagline{font-size:.9rem;color:rgba(255,255,255,.65);max-width:300px}
.footer-col h3{color:#fff;font-size:1rem;margin-bottom:14px}
.footer-col a{display:block;color:rgba(255,255,255,.78);font-size:.92rem;padding:5px 0}
.footer-col a:hover{color:#fff;text-decoration:none}
.footer-nap{font-style:normal;font-size:.9rem;color:rgba(255,255,255,.78);line-height:1.8}
.footer-nap a{color:rgba(255,255,255,.9);display:inline}
.footer-nap strong{color:#fff}
.footer-urgencias{color:var(--color-principal-claro);font-weight:600}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:36px;padding-top:20px;text-align:center}
.footer-bottom p{font-size:.85rem;color:rgba(255,255,255,.6)}

/* ── Breadcrumb ── */
.breadcrumb{padding:14px 0;font-size:.86rem;background:var(--bg-light)}
.breadcrumb a{color:var(--text-suave)}
.breadcrumb span{color:var(--color-secundario);font-weight:600}

/* ── Bloque servicios relacionados ── */
.related-services{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.related-services a{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px 20px;
  font-weight:600;color:var(--color-secundario);display:flex;justify-content:space-between;align-items:center;gap:10px}
.related-services a:hover{text-decoration:none;border-color:var(--color-principal);color:var(--color-principal)}

/* ── Contenido subpágina ── */
.prose{max-width:820px}
.prose h3{margin:28px 0 8px;color:var(--color-secundario)}
.prose p{margin-bottom:14px}
.prose p strong{color:var(--color-secundario)}
.media-text{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.media-text img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* ── COOKIE BANNER (sin CLS) ── */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--color-secundario);color:#fff;z-index:1000;
  transform:translateY(100%);transition:transform .25s ease;box-shadow:0 -4px 20px rgba(0,0,0,.2)}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 20px;flex-wrap:wrap}
.cookie-text{font-size:.88rem;color:rgba(255,255,255,.85);flex:1;min-width:240px;margin:0}
.cookie-text a{color:#fff;text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-cookie{padding:9px 18px;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;cursor:pointer;border:2px solid transparent;text-decoration:none}
.btn-cookie-accept{background:var(--color-principal);color:#fff;border:none}
.btn-cookie-accept:hover{background:var(--color-principal-osc)}
.btn-cookie-reject{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-cookie-config{background:transparent;color:rgba(255,255,255,.85);text-decoration:underline;align-self:center}

/* ── Accesibilidad ── */
:focus-visible{outline:3px solid var(--color-principal-claro);outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--color-principal);color:#fff;padding:10px 16px;z-index:1100}
.skip-link:focus{left:8px;top:8px}

/* ── Responsive ── */
@media (max-width:980px){
  .contact-grid,.zonas-wrap,.media-text{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .media-text img{order:-1}
}
@media (max-width:820px){
  .nav-desktop,.header-cta{display:none}
  .burger{display:flex}
  body{font-size:16px}
}
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .header-top-left{display:none}
  .header-top-inner{justify-content:center}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn-primary,.hero-ctas .btn-ghost{width:100%}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ── Galería de imágenes ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.gal-item{margin:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.gal-item img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block}
.gal-item figcaption{padding:12px 14px;font-size:.9rem;font-weight:600;color:var(--color-secundario)}
