:root{
  --text:#0f172a;
  --muted:#6b7280;
  --card:#fff;
  --muted-bg:#f6f7fb;
  --brand:#368BC1;
  --brand-rgb:54,139,193;
  --wa:#25D366;
  --wa-rgb:37,211,102;
  --radius:16px;
  --shadow:0 20px 48px rgba(0,0,0,.18);
  --nav-h:56px;
  --car-h:320px;
  --sales-h:380px;
  --svc-min-h:276px;
  --svc-gap:36px
}

/* Reset & base */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:21px;color:var(--text);background:#fff;line-height:1.65;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale
}
@media (max-width:1023px){body{font-size:19px}}
@media (max-width:699px){body{font-size:17px}}
.container{width:min(1200px,92%);margin-inline:auto}

/* Titles with Manrope */
.hero-title,.section-title{
  font-family:"Manrope","Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-weight:800;letter-spacing:-.01em
}
.hero-title{font-size:clamp(28px,5vw,58px);line-height:1.12;margin:0 0 10px}
.section-title{font-size:clamp(22px,3.2vw,34px);line-height:1.18;margin:0 0 16px}
.hero-subtitle{color:#fff;max-width:680px;margin:0;font-size:clamp(16px,1.9vw,20px)}
.btn{font-size:clamp(14px,1.6vw,16px)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(var(--brand-rgb),.95)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;min-height:var(--nav-h)}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff}
.brand .logo{height:var(--nav-h);display:block}
.brand-name{font-weight:700;letter-spacing:.2px;color:#fff;white-space:nowrap}
.nav-toggle{display:none;background:transparent;border:0;font-size:22px;color:#fff}
.nav-menu{display:flex;gap:16px;list-style:none;margin:0;padding:0;align-items:center}
.nav-link{display:inline-flex;align-items:center;gap:6px;padding:10px 6px;color:#fff;text-decoration:none;font-weight:600}
.nav-link:hover{opacity:.9}
.nav-cta{margin-left:6px}
@media (max-width:860px){
  :root{--nav-h:54px}
  .nav-toggle{display:inline-block}
  .nav-menu{
    position:absolute;right:0;top:calc(var(--nav-h) + 4px);
    background:rgba(var(--brand-rgb),.6);border-radius:12px;padding:12px;
    display:none;flex-direction:column;min-width:260px;gap:10px
  }
  .nav-link{color:#fff}
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.6);color:#0f172a;font-weight:700;text-decoration:none;cursor:pointer;
  backdrop-filter:saturate(140%) blur(2px);transition:background .2s,box-shadow .2s,transform .1s
}
.btn:hover{background:rgba(255,255,255,.9);box-shadow:0 6px 18px rgba(0,0,0,.12)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:rgba(var(--brand-rgb),.6);border-color:rgba(var(--brand-rgb),.6);color:#fff}
.btn.btn-wa,a.btn.btn-wa{
  background:transparent!important;border:none!important;color:#fff!important;backdrop-filter:none!important;
  background-color:rgba(37,211,102,.92)!important;box-shadow:0 10px 24px rgba(37,211,102,.30)!important
}
@keyframes waBeat{
  0%{transform:scale(1);box-shadow:0 0 0 0 rgba(37,211,102,.45)}
  18%{transform:scale(1.08);box-shadow:0 0 0 12px rgba(37,211,102,0)}
  32%{transform:scale(1);box-shadow:0 0 0 0 rgba(37,211,102,0)}
  100%{transform:scale(1);box-shadow:0 0 0 0 rgba(37,211,102,0)}
}
.btn-wa.pulse-cta{animation:waBeat 4s ease-in-out infinite!important}
.btn.btn-wa,a.btn.btn-wa{-webkit-text-fill-color:#fff}
.btn-tel{background:rgba(var(--brand-rgb),.60);color:#fff;border:none;box-shadow:0 8px 20px rgba(var(--brand-rgb),.22)}
.btn-tel:hover{background:rgba(var(--brand-rgb),.80)}
.tel-ico{margin-right:8px}

/* FAB (solo móvil) */
.fab-bar{position:fixed;z-index:60;bottom:12px;right:12px;display:none;gap:10px}
@media (max-width:700px){
  .fab-bar{display:flex}
  .fab-bar .fab-tel{width:44px;height:44px;padding:0;border-radius:999px;background:rgba(var(--brand-rgb),.15);border:1px solid rgba(var(--brand-rgb),.5)}
  .fab-bar .fab-tel .tel-text{display:none}
  .fab-bar .fab-tel .tel-ico{margin:0}
}

/* Hero */
.hero-panorama{position:relative;color:#fff;min-height:760px;overflow:hidden;display:grid;place-items:center}
.hero-panorama .hero-bg{
  position:absolute;inset:0;
  background-image:url('./assets/img/hero-aire-climatec-malaga-1920x1080.webp');
  background-size:cover;background-position:center 40%;z-index:0
}
.hero-inner{position:relative;z-index:1;margin-left:auto;margin-right:6%;max-width:720px;text-align:left}

/* Tablet */
@media (max-width:1023px){
  .hero-panorama{min-height:700px}
  :root{--car-h:280px}
}

/* Móvil: centrado y 15% más abajo */
@media (max-width:699px){
  .hero-panorama{ min-height: calc(100svh - var(--nav-h)); }
  .hero-inner{
    place-self: center; margin: 0 auto; text-align: center; padding: 0 18px 72px;
    max-width: 680px; transform: translateY(15%); /* 15% más abajo */
  }
  .hero-title, .hero-subtitle{ margin-left: auto; margin-right: auto; }
  :root{--car-h:240px}
}

/* Ofertas card — oculta en móvil */
.showcase{position:absolute;left:2.5%;top:50%;transform:translateY(-50%);width:min(500px,44vw);z-index:2}
@media (max-width:700px){.showcase{display:none}}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow)}
.showcase-inner{padding:12px}
.showcase-header{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 8px;color:#0f172a;font-weight:800}
.dotset{display:flex;gap:6px}
.dot{width:7px;height:7px;border-radius:50%;background:#d1d5db}
.dot.is-active{background:#111827}
.carousel{position:relative;width:100%;height:var(--car-h);border-radius:12px;overflow:hidden;background:#fff}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.slide.is-active{opacity:1}
.slide img{width:100%;height:100%;object-fit:contain;display:block;background:#fff;padding:6% 6% 2%}

/* Etiqueta modelo (abajo-izquierda) */
.slide .badge{
  position:absolute;left:16px;bottom:14px;z-index:3;
  padding:6px 10px;border-radius:999px;background:rgba(15,23,42,.88);
  color:#fff;font-weight:700;font-size:14px;line-height:1;box-shadow:0 6px 16px rgba(0,0,0,.18);pointer-events:none
}
@media (max-width:1023px){.slide .badge{font-size:13px;padding:5px 9px;left:12px;bottom:12px}}

/* Precio celeste con efecto */
.price-bar{height:calc(var(--car-h)*.20);display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:10px}
.btn-price{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:999px;background:#fff;border:2px solid rgba(var(--brand-rgb),.25);text-decoration:none}
.btn-price .currency{color:var(--brand);font-weight:800}
.btn-price .amount{color:var(--brand);font-weight:900}
@keyframes priceGlow{0%,100%{box-shadow:0 0 0 rgba(54,139,193,0)}50%{box-shadow:0 0 22px rgba(54,139,193,.35)}}
.btn-price{animation:priceGlow 3.8s ease-in-out infinite}

/* Secciones */
.section{padding:56px 0}
.section-muted{background:var(--muted-bg)}
@media (max-width:1023px){.section{padding:48px 0}}
@media (max-width:699px){.section{padding:40px 0}}

/* Servicios — móvil 1 por fila */
.svc-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--svc-gap)}
@media (max-width:920px){.svc-grid-2{grid-template-columns:1fr}}
.svc-item{
  display:grid;grid-template-columns:1fr 1.2fr;min-height:var(--svc-min-h);
  background:#fff;border-radius:16px;overflow:hidden;text-decoration:none;color:inherit;
  box-shadow:0 10px 28px rgba(0,0,0,.07);transition:transform .2s,box-shadow .2s;border:1px solid rgba(var(--brand-rgb),.35)
}
.svc-item:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.1);border-color:rgba(var(--brand-rgb),.55)}
.svc-img{background:#f0f4fa;display:flex;align-items:center;justify-content:center;overflow:hidden}
.svc-img img{width:100%;height:100%;object-fit:cover}
.svc-txt{padding:26px 22px}
.svc-txt p{margin:0 0 10px;color:#6b7280}
.svc-cta{font-weight:700;color:var(--brand)}
@media (max-width:920px){
  .svc-item{grid-template-columns:1fr;min-height:auto}
  .svc-img{aspect-ratio:4/3}
  .svc-img img{object-fit:contain;padding:10px}
}

/* Ventas (transiciones suaves) */
.sales-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.offer-card{
  background:#fff;border-radius:16px;box-shadow:var(--shadow);overflow:hidden;padding:12px;
  display:flex;flex-direction:column;border:1px solid rgba(var(--brand-rgb),.35);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease
}
.offer-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.1);border-color:rgba(var(--brand-rgb),.55)}
.offer-head{display:flex;align-items:center;justify-content:flex-end;padding:2px 4px 8px}
.sales-mini{height:var(--sales-h);border-radius:12px;overflow:hidden;background:#fff;margin-bottom:10px;display:flex;align-items:center;justify-content:center}
.sales-mini img{width:100%;height:100%;object-fit:contain;transition:opacity .35s ease, transform .35s ease}
.price-panel{border:1px solid rgba(var(--brand-rgb),.35);border-radius:12px;padding:12px 12px 14px 12px;background:#fff}
.price-line{display:flex;align-items:baseline;gap:6px;justify-content:flex-end}
.price-line span{color:var(--brand);font-weight:800}
.price-line strong{color:var(--brand);font-weight:900;font-size:clamp(18px,2.2vw,22px)}
.desc{color:#4b5563;margin:8px 0 10px 0}
.offer-link{font-weight:700;color:var(--brand);text-decoration:none}
.fade-smooth{transition:opacity .35s ease, transform .35s ease}

@media (max-width:1200px){:root{--sales-h:340px}}
@media (max-width:1023px){
  .sales-grid{grid-template-columns:repeat(2,1fr)}
  :root{--sales-h:300px}
}
@media (max-width:699px){
  .sales-grid{grid-template-columns:1fr}
  :root{--sales-h:260px}
}

/* Trabajos */
.tri-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tri{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 10px 28px rgba(0,0,0,.07);border:1px solid rgba(var(--brand-rgb),.35)}
.tri-view{position:relative;height:300px}
.tri-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s ease-in-out,transform 6s ease-out;transform:scale(1.02)}
.tri-slide.is-active{opacity:1;transform:scale(1)}
@media (max-width:1023px){.tri-view{height:260px}}
@media (max-width:900px){
  .tri-wrap{grid-template-columns:1fr 1fr;gap:14px}
  .tri-view{height:240px}
  .tri:nth-child(3){display:none}
}
@media (max-width:699px){.tri-view{height:220px}}

/* Logos */
.section-logos{background:#fff;padding:22px 0}
.container-wide{width:100%;max-width:none;margin:0;padding:0}
.brands{overflow:hidden;position:relative;padding:0;background:#fff}
.brand-track{
  display:flex;align-items:center;gap:34px;width:max-content;
  animation:brandScroll var(--brand-dur,28s) linear infinite;will-change:transform
}
.brand-track img{height:52px;width:auto;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:8px 14px}
@media (max-width:1023px){
  .brand-track{gap:28px}
  .brand-track img{height:46px;padding:7px 12px}
}
@media (max-width:699px){
  .brand-track{gap:22px}
  .brand-track img{height:40px;padding:6px 10px}
}
@keyframes brandScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* FAQ */
.faq{display:grid;gap:10px}
.faq-item{border:1px solid rgba(var(--brand-rgb),.35);border-radius:12px;overflow:hidden;background:#fff}
.faq-item>summary{list-style:none;cursor:pointer;padding:14px 16px;font-weight:700;display:flex;align-items:center;justify-content:space-between}
.faq-item>summary::-webkit-details-marker{display:none}
.faq-item>summary::after{content:"+";font-weight:800;color:var(--brand)}
.faq-item[open]>summary::after{content:"–"}
.faq-content{padding:0 16px 14px 16px;color:#6b7280}
.faq-more{
  display:block;text-decoration:none;font-weight:700;color:#0f172a;
  background:rgba(var(--brand-rgb),.4);border:1px solid rgba(var(--brand-rgb),.5);
  border-radius:12px;padding:14px 16px;text-align:center;box-shadow:0 10px 28px rgba(0,0,0,.07);margin-top:12px
}

/* Soy Víctor — imagen circular */
.about{display:grid;grid-template-columns:1fr 1.2fr;gap:26px;align-items:center}
.about-media{background:#fff;border:1px solid rgba(var(--brand-rgb),.35);border-radius:16px;overflow:hidden;box-shadow:0 10px 28px rgba(0,0,0,.07)}
.about-media img{width:100%;height:auto;display:block;object-fit:cover}
.about-ctas{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.about-bullets{margin:0;padding-left:18px;color:#334155}
.about-bullets li{margin:6px 0}
.about-inverse .about-media.circle{border-radius:9999px;max-width:260px;justify-self:center}
.about-inverse .about-media.circle img{aspect-ratio:1/1;object-fit:cover}
.btn-more{background:#fff;border:1px solid rgba(var(--brand-rgb),.45)}
@media (max-width:1023px){.about{gap:22px}}
@media (max-width:900px){.about{grid-template-columns:1fr}.about-inverse .about-media.circle{max-width:220px}}

/* Contacto & mapa */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:0 8px 24px rgba(0,0,0,.06);border:1px solid rgba(var(--brand-rgb),.35)}
.contact-card label{display:block;margin:12px 0 6px 0;font-weight:700}
.contact-card input,.contact-card textarea{width:100%;padding:10px;border:1px solid rgba(var(--brand-rgb),.45);border-radius:10px;font:inherit}
.contact-card input:focus,.contact-card textarea:focus{outline:none;border-color:rgba(var(--brand-rgb),.9);box-shadow:0 0 0 3px rgba(var(--brand-rgb),.15)}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;justify-content:flex-end}
@media (min-width:992px){
  .contact-grid{grid-template-columns:1.6fr 1fr;align-items:stretch}
  .contact-card,.map-wrap{height:100%}
  .map-wrap{display:flex}
  .map-static{width:100%;height:100%;object-fit:cover}
}
@media (max-width:1023px){.contact-grid{gap:18px}}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.06);border:1px solid rgba(var(--brand-rgb),.35)}
.map-static{width:100%;height:auto;display:block;object-fit:cover}

/* Footer */
.site-footer{background:var(--brand);color:#fff}
.footer-inner{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  grid-template-areas:"links links links" "copy . social";
  row-gap:10px;padding:18px 0
}
.footer-links{grid-area:links;justify-self:center}
.footer-links a{color:#fff;text-decoration:none;margin-right:14px;opacity:.9;font-size:clamp(13px,1.5vw,15px)}
.footer-links a:hover{opacity:1}
.footer-copy{grid-area:copy;justify-self:center;margin:0;white-space:nowrap;font-size:clamp(13px,1.6vw,15px)}
.social{grid-area:social;justify-self:end;display:flex;gap:12px}
.social-ico{color:#fff;text-decoration:none;display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(255,255,255,.4)}
@media (max-width:1023px){.footer-inner{row-gap:8px}}
@media (max-width:699px){
  .footer-inner{grid-template-columns:1fr;grid-template-areas:"links" "social" "copy";row-gap:12px}
  .social{justify-self:center}
}
