/* ===========================================================
   Limpiezas Los Peñones — Limpieza y pulido de suelos (Lorca)
   Paleta: cian/aqua (del logo) + navy-teal oscuro + blanco
   =========================================================== */
:root{
  /* Fondos */
  --paper:#ffffff;
  --paper-2:#f3fafd;
  --paper-3:#e8f5fb;
  /* Oscuros (navy-teal) */
  --night-900:#062536;
  --night-800:#082f44;
  --night-700:#0c3b56;
  /* Texto */
  --ink:#0d2330;
  --ink-soft:#465b67;
  --muted:#86a0ad;
  --on-dark:#eaf6fb;
  --on-dark-soft:#a8c6d4;
  /* Marca (cian del logo) */
  --accent:#0f97c9;
  --accent-2:#16b4e6;
  --cyan:#2cc6f0;
  --accent-soft:#d4eef9;
  --accent-tint:#eaf7fc;
  /* Líneas / utilitarios */
  --line:rgba(13,35,48,.10);
  --line-2:rgba(13,35,48,.055);
  --line-dark:rgba(255,255,255,.12);
  --wa:#25d366;
  /* Sistema */
  --maxw:1240px;
  --gutter:clamp(20px,5vw,64px);
  --sec:clamp(64px,9vw,128px);
  --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:32px; --pill:999px;
  --sh-sm:0 2px 10px -4px rgba(8,47,68,.20);
  --sh:0 16px 40px -22px rgba(8,47,68,.34);
  --sh-lg:0 34px 70px -32px rgba(6,37,54,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
  --display:"Sora",system-ui,sans-serif;
  --sans:"Manrope",ui-sans-serif,system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:16.5px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
ul{list-style:none}
::selection{background:var(--cyan);color:#06222f}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.08;letter-spacing:-.02em;text-wrap:balance}
p{text-wrap:pretty}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--sec)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--cyan);border-radius:2px}
.eyebrow.on-dark{color:#8fe0fb}
.sec-head{max-width:720px;margin-bottom:clamp(36px,5vw,60px)}
.sec-head h2{font-size:clamp(30px,4.6vw,52px);margin:14px 0 14px}
.sec-head p{color:var(--ink-soft);font-size:1.06rem}
.center{text-align:center;margin-inline:auto}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 24px;border-radius:var(--pill);border:1px solid transparent;
  font-weight:700;font-size:.97rem;letter-spacing:.01em;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s,border-color .25s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;box-shadow:var(--sh-sm)}
.btn--primary:hover{box-shadow:var(--sh)}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn--light{background:#fff;color:var(--ink);border-color:rgba(255,255,255,.5)}
.btn--lg{padding:16px 30px;font-size:1.02rem}
.btn--block{display:flex;width:100%}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Marca / wordmark ---------- */
.brand{display:inline-flex;align-items:center;gap:11px}
.brand__mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,var(--accent),var(--cyan));color:#fff;box-shadow:var(--sh-sm);flex:none}
.brand__mark svg{width:24px;height:24px}
.brand__name{display:block;font-family:var(--display);font-weight:700;font-size:1.2rem;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.brand__txt small{display:block;font-family:var(--sans);font-weight:600;font-size:.56rem;letter-spacing:.26em;color:var(--muted);text-transform:uppercase;margin-top:4px}

/* ---------- Header ---------- */
.header{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .3s,box-shadow .3s,backdrop-filter .3s}
.header__row{display:flex;align-items:center;justify-content:space-between;height:74px}
.header.scrolled{background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(14px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:.95rem;font-weight:600;color:var(--ink);opacity:.82;transition:opacity .2s,color .2s}
.nav a:hover{opacity:1;color:var(--accent)}
.header__cta{display:flex;align-items:center;gap:12px}
/* header sobre hero (transparente, texto claro) */
.header:not(.scrolled) .brand__name{color:#fff}
.header:not(.scrolled) .brand__txt small{color:rgba(255,255,255,.7)}
.header:not(.scrolled) .nav a{color:#fff}
.header:not(.scrolled) .header__cta .btn--ghost{border-color:rgba(255,255,255,.4);color:#fff}
.header:not(.scrolled) .header__cta .btn--ghost:hover{border-color:#fff}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px}
.burger span{width:24px;height:2px;background:currentColor;border-radius:2px;transition:.3s;color:#fff}
.header.scrolled .burger span{color:var(--ink)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  background:radial-gradient(120% 120% at 82% -10%,#0f4a66 0%,var(--night-800) 46%,var(--night-900) 100%);
  color:#fff;overflow:hidden;padding-top:90px}
.hero__blob{position:absolute;border-radius:50%;filter:blur(64px);opacity:.5;pointer-events:none}
.hero__blob.b1{width:520px;height:520px;top:-120px;right:-80px;background:radial-gradient(circle,var(--cyan),transparent 65%)}
.hero__blob.b2{width:460px;height:460px;bottom:-160px;left:-120px;background:radial-gradient(circle,var(--accent),transparent 60%);opacity:.35}
.hero__grid-lines{position:absolute;inset:0;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px);background-size:100% 64px;-webkit-mask-image:linear-gradient(#000,transparent 75%);mask-image:linear-gradient(#000,transparent 75%);opacity:.5}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center;width:100%}
.hero h1{font-size:clamp(38px,6vw,76px);letter-spacing:-.035em;margin-top:18px}
.hero h1 em{font-style:normal;background:linear-gradient(110deg,#9fe7ff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__lead{margin:22px 0 26px;font-size:clamp(1.05rem,1.7vw,1.26rem);color:var(--on-dark-soft);max-width:40ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px}
.hero__meta{display:flex;gap:26px;flex-wrap:wrap;margin-top:34px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14)}
.hero__meta div{font-size:.9rem}
.hero__meta .k{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:3px}
.hero__meta .v{font-weight:600}
/* hero visual card */
.hero__visual{position:relative;aspect-ratio:4/5;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);border:1px solid rgba(255,255,255,.14)}
.hero__visual img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(6,37,54,.5))}
.hero__chip{position:absolute;z-index:2;background:rgba(255,255,255,.96);color:var(--ink);border-radius:14px;padding:11px 15px;box-shadow:var(--sh);font-size:.84rem;font-weight:700}
.hero__chip .s{display:block;font-size:.7rem;font-weight:600;color:var(--accent);letter-spacing:.06em}
.hero__chip.c1{top:18px;left:-14px}
.hero__chip.c2{bottom:20px;right:-12px}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue span{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Trust strip ---------- */
.trust{background:var(--night-900);color:var(--on-dark)}
.trust__row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.08)}
.trust__cell{background:var(--night-900);padding:28px 22px;text-align:center}
.trust__cell b{display:block;font-family:var(--display);font-size:1.35rem;color:#fff;line-height:1.15;margin-bottom:6px}
.trust__cell span{font-size:.82rem;color:var(--on-dark-soft)}

/* ---------- Nosotros ---------- */
.about{background:var(--paper-2)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.about__media{position:relative;aspect-ratio:5/4;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.about__media img{width:100%;height:100%;object-fit:cover}
.about__media .badge{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.96);border-radius:14px;padding:12px 16px;box-shadow:var(--sh-sm);max-width:200px}
.about__media .badge img{width:100%;height:auto}
.about h2{font-size:clamp(28px,4vw,46px);margin:14px 0 18px}
.about p{color:var(--ink-soft);margin-bottom:14px}
.about__points{display:grid;gap:12px;margin-top:22px}
.about__points li{display:flex;gap:12px;align-items:flex-start;font-weight:600;color:var(--ink)}
.about__points svg{flex:none;width:22px;height:22px;color:var(--accent);margin-top:1px}

/* ---------- Servicios ---------- */
.serv__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.serv__card{background:var(--paper);padding:32px 28px;transition:background .3s,transform .3s var(--ease)}
.serv__card:hover{background:var(--accent-tint)}
.serv__num{display:inline-block;font-family:var(--display);font-weight:800;font-size:1rem;color:var(--accent);letter-spacing:.04em;margin-bottom:16px}
.serv__card h3{font-size:1.18rem;margin-bottom:9px}
.serv__card p{font-size:.95rem;color:var(--ink-soft)}

/* ---------- Pulido (antes/después) ---------- */
.pulido{background:var(--paper-3)}
.ba{position:relative;max-width:980px;margin-inline:auto;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);user-select:none;touch-action:none;cursor:ew-resize;border:1px solid var(--line)}
.ba__img{position:absolute;inset:0}
.ba__img img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba__before{width:50%;overflow:hidden;border-right:2px solid rgba(255,255,255,.9)}
.ba__before img{width:auto;max-width:none;height:100%}
/* "antes": apagado, mate, sucio */
.ba__before img{filter:grayscale(.55) brightness(.72) contrast(.92) saturate(.5)}
.ba__before::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(40,44,46,.28),rgba(40,44,46,.12))}
.ba__tag{position:absolute;top:14px;z-index:3;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:var(--pill);backdrop-filter:blur(4px)}
.ba__tag--l{left:14px;background:rgba(13,35,48,.6);color:#fff}
.ba__tag--r{right:14px;background:rgba(255,255,255,.85);color:var(--accent)}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(255,255,255,.9);transform:translateX(-1px);z-index:4}
.ba__line{position:absolute;inset:0;width:2px}
.ba__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:50%;background:#fff;color:var(--accent);display:grid;place-items:center;box-shadow:var(--sh);cursor:ew-resize}
.ba__grip svg{width:22px;height:22px}
.ba__handle:focus-visible{outline:none}
.ba__handle:focus-visible .ba__grip{box-shadow:0 0 0 4px rgba(22,180,230,.4),var(--sh)}

/* ---------- Trabajos (galería) ---------- */
.trabajos{background:var(--paper-2)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gallery figure{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 50%,rgba(6,37,54,.5))}
.gallery .g-wide{grid-column:span 2}
.gallery .g-tall{grid-row:span 2}
.gallery figcaption{position:absolute;left:14px;bottom:12px;z-index:2;color:#fff;font-weight:700;font-size:.9rem;text-shadow:0 1px 6px rgba(0,0,0,.4)}

/* ---------- Por qué ---------- */
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.why__card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.why__card:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:transparent}
.why__ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--accent-tint);color:var(--accent);margin-bottom:16px}
.why__ic svg{width:24px;height:24px}
.why__card h3{font-size:1.12rem;margin-bottom:7px}
.why__card p{font-size:.94rem;color:var(--ink-soft)}

/* ---------- Ubicación + horario ---------- */
.loc__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,48px);align-items:stretch}
.map-card{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);min-height:380px;border:1px solid var(--line)}
.map-card iframe{width:100%;height:100%;min-height:380px;border:0;display:block;filter:grayscale(.1)}
.info-card{display:flex;flex-direction:column;gap:18px}
.info-row{display:flex;gap:14px;align-items:flex-start}
.info-row svg{flex:none;width:22px;height:22px;color:var(--accent);margin-top:2px}
.info-row b{display:block;font-size:.95rem}
.info-row span,.info-row a{color:var(--ink-soft);font-size:.95rem}
.info-row a:hover{color:var(--accent)}
.status{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.92rem;padding:6px 12px;border-radius:var(--pill);width:max-content}
.status .dot{width:9px;height:9px;border-radius:50%}
.status.open{background:#e6f7ee;color:#15803d}.status.open .dot{background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.18)}
.status.closed{background:#fdeaea;color:#b91c1c}.status.closed .dot{background:#ef4444}
.hours-table{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.hours-table .row{display:flex;justify-content:space-between;gap:14px;padding:11px 16px;font-size:.92rem;border-top:1px solid var(--line-2)}
.hours-table .row:first-child{border-top:0}
.hours-table .row.today{background:var(--accent-tint);font-weight:700}
.hours-table .row .d{color:var(--ink-soft)}
.hours-table .row.today .d{color:var(--accent)}

/* ---------- Contacto ---------- */
.contact{background:var(--night-900);color:#fff}
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,5vw,64px);align-items:center}
.contact h2{font-size:clamp(28px,4vw,46px);margin:14px 0 16px}
.contact__lead{color:var(--on-dark-soft);margin-bottom:24px}
.contact__list{display:grid;gap:14px;margin-top:8px}
.contact__list a,.contact__list span{display:flex;gap:12px;align-items:center;color:var(--on-dark);font-weight:600}
.contact__list a:hover{color:#fff}
.contact__list svg{width:20px;height:20px;color:#7ad6f5}
.form{background:rgba(255,255,255,.05);border:1px solid var(--line-dark);border-radius:var(--r-lg);padding:clamp(22px,3vw,34px);backdrop-filter:blur(6px)}
.form .field{margin-bottom:14px}
.form label{display:block;font-size:.82rem;font-weight:600;color:var(--on-dark-soft);margin-bottom:6px}
.form input,.form select,.form textarea{
  width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);color:#fff;font:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}
.form input::placeholder,.form textarea::placeholder{color:rgba(255,255,255,.4)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(44,198,240,.18)}
.form select option{color:#000}
.form textarea{resize:vertical;min-height:96px}
.form .check{display:flex;gap:10px;align-items:flex-start;font-size:.84rem;color:var(--on-dark-soft);margin:6px 0 16px}
.form .check input{width:auto;margin-top:3px}
.form__ok{display:none;text-align:center;padding:14px;border-radius:12px;background:rgba(37,211,102,.14);border:1px solid rgba(37,211,102,.4);color:#bbf7d0;font-weight:600}
.form.sent .form__ok{display:block}

/* ---------- Footer ---------- */
.footer{background:#04202f;color:var(--on-dark-soft);padding-block:clamp(48px,6vw,72px) 28px}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer .brand{margin-bottom:14px}
.footer .brand__name{color:#fff}
.footer p{font-size:.92rem;max-width:38ch;margin-top:4px}
.footer h4{color:#fff;font-family:var(--display);font-size:1rem;margin-bottom:14px}
.footer a{display:block;font-size:.92rem;padding:4px 0;transition:color .2s}
.footer a:hover{color:#fff}
.footer__social{display:flex;gap:12px;margin-top:16px}
.footer__social a{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);color:#fff}
.footer__social a:hover{background:var(--accent)}
.footer__social svg{width:18px;height:18px}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:22px;font-size:.84rem}
.footer__bottom a{display:inline;color:var(--on-dark-soft)}
.footer__legal{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- Call bar móvil ---------- */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);box-shadow:0 -6px 20px -10px rgba(0,0,0,.3)}
.callbar a{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:#fff;font-weight:700;font-size:.95rem}
.callbar a.wa{background:var(--wa);color:#fff}
.callbar svg{width:18px;height:18px}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .nav,.header__cta .btn{display:none}
  .burger{display:flex}
  .header__cta{gap:0}
  .nav.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;
    background:#fff;padding:8px var(--gutter) 18px;box-shadow:var(--sh)}
  .nav.open a{color:var(--ink);padding:13px 0;border-bottom:1px solid var(--line-2);width:100%;opacity:1}
  .hero__inner,.about__grid,.loc__grid,.contact__grid{grid-template-columns:1fr}
  .hero__visual{max-width:440px;order:-1;margin-inline:auto;aspect-ratio:16/12}
  .hero__chip.c1{left:8px}.hero__chip.c2{right:8px}
  .serv__grid{grid-template-columns:1fr 1fr}
  .why__grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .footer__grid{grid-template-columns:1fr 1fr}
  .callbar{display:grid}
  body{padding-bottom:54px}
}
@media(max-width:560px){
  .trust__row{grid-template-columns:1fr 1fr}
  .serv__grid{grid-template-columns:1fr}
  .why__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .hero__meta{gap:18px}
  .gallery .g-wide{grid-column:span 2}
  .gallery .g-tall{grid-row:span 1}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
