/* ══════════════════════════════════════════════════════════
   HERRERÍA DEL MAR — styles.css
   Reset · Variables · Nav · Hero · Galería · Servicios
   Testimonios · Contacto · Footer · WhatsApp · Responsive
══════════════════════════════════════════════════════════ */

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{display:block;max-width:100%}
a{text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none}
html{scroll-behavior:smooth}

/* VARIABLES */
:root{
  --fire:#E8601C;--ember:#C44A10;--amber:#F4A347;
  --forge:#0F0D0B;--carbon:#1C1814;--ash:#2E2923;
  --bone:#F5F0E8;--cream:#C8BFB0;--metal:#7A7065;
  --bg-light:#F7F5F2;--bg-card:#fff;
  --text-1:#1C1814;--text-2:#5A534C;
  --border:rgba(46,41,35,.10);
  --font-d:'Oswald',sans-serif;--font-b:'Lora',serif;
  --sh-card:0 2px 12px rgba(15,13,11,.07),0 1px 3px rgba(15,13,11,.05);
  --sh-hover:0 12px 40px rgba(15,13,11,.14),0 4px 12px rgba(15,13,11,.08);
  --r:4px;--tr:.26s ease;--nav:64px;--pad:clamp(20px,6vw,80px);
}

body{font-family:var(--font-d);background:var(--forge);color:var(--bone);-webkit-font-smoothing:antialiased}

/* SHARED HELPERS */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--fire);margin-bottom:18px}
.dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--fire);flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);font-size:13px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;padding:14px 26px;border-radius:var(--r);transition:background var(--tr),transform .15s ease,border-color var(--tr);white-space:nowrap}
.btn--primary{background:var(--fire);color:var(--bone);border:1px solid var(--fire)}
.btn--primary:hover{background:var(--ember);border-color:var(--ember);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--cream);border:1px solid rgba(200,191,176,.38)}
.btn--ghost:hover{border-color:rgba(200,191,176,.7);color:var(--bone);transform:translateY(-1px)}
.btn:active{transform:translateY(0)!important}

/* ── NAV ────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav);display:flex;align-items:center;justify-content:space-between;gap:20px;padding:0 var(--pad);background:rgba(12,10,8,.72);border-bottom:1px solid rgba(46,41,35,.50);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:background .4s,border-color .4s}
.nav.scrolled{background:rgba(18,15,12,.98);border-bottom-color:rgba(232,96,28,.25);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.nav__logo{font-family:var(--font-d);font-size:17px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bone);user-select:none;flex-shrink:0}
.nav__logo span{color:var(--fire)}
.nav__links{display:flex;align-items:center;gap:28px;margin-left:auto}
.nav__link{font-family:var(--font-d);font-size:12px;font-weight:700;letter-spacing:.10em;text-transform:uppercase;color:#FFFFFF;text-shadow:0 1px 8px rgba(0,0,0,.80),0 0 20px rgba(0,0,0,.40);transition:color var(--tr)}
.nav__link:hover{color:var(--fire)}
.nav__tel{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);font-size:12px;font-weight:700;color:#fff;background:var(--fire);border:2px solid var(--fire);padding:9px 18px;border-radius:2px;flex-shrink:0;transition:background .22s,border-color .22s,transform .15s;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;box-shadow:0 2px 12px rgba(232,96,28,.40)}
.nav__tel svg{color:#fff;flex-shrink:0}
.nav__tel-num{color:#fff}
.nav__tel:hover{background:var(--ember);border-color:var(--ember);transform:translateY(-1px);box-shadow:0 4px 18px rgba(232,96,28,.50)}
.nav__tel:active{transform:translateY(0)}
.nav__burger{display:none;flex-direction:column;justify-content:space-between;width:24px;height:16px;flex-shrink:0;padding:0}
.nav__burger span{display:block;width:100%;height:2px;background:var(--bone);border-radius:1px;transition:transform .3s,opacity .3s}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── HERO ───────────────────────────────────────────────── */
.hero{position:relative;width:100%;height:100vh;min-height:600px;display:flex;align-items:center;overflow:hidden;background:url('img/hero-herreria.jpg') center 40%/cover no-repeat var(--forge)}
.hero::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(10,8,6,.78) 0%,rgba(12,10,8,.73) 30%,rgba(15,13,11,.46) 52%,rgba(15,13,11,.14) 68%,rgba(15,13,11,.04) 100%)}
.hero::after{content:'';position:absolute;inset:0;z-index:2;background:linear-gradient(to top,rgba(10,8,6,.62) 0%,rgba(10,8,6,.21) 30%,transparent 55%),rgba(232,96,28,.05)}
.hero__content{position:relative;z-index:10;width:100%;max-width:680px;padding:var(--nav) var(--pad) 0;display:flex;flex-direction:column;align-items:flex-start}
.hero__badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fire);margin-bottom:20px}
.hero__badge-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--fire)}
.hero__h1{display:flex;flex-direction:column;font-family:var(--font-d);font-size:clamp(52px,7vw,72px);font-weight:700;line-height:1.05;letter-spacing:.025em;text-transform:uppercase;margin-bottom:24px}
.hero__h1 span{color:var(--bone)}
.hero__h1 .soft{color:var(--cream)}
.hero__sub{font-family:var(--font-b);font-size:clamp(15px,1.5vw,17px);line-height:1.78;color:var(--cream);max-width:420px;margin-bottom:40px}
.hero__ctas{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.hero__badges{display:flex;flex-direction:column;gap:9px}
.hero__badges li{display:flex;align-items:center;gap:8px;font-family:var(--font-d);font-size:12px;font-weight:400;letter-spacing:.07em;text-transform:uppercase;color:var(--cream)}
.hero__badges li svg{color:var(--fire);flex-shrink:0}
.hero__scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.38;animation:bounce 2.4s ease-in-out infinite}
.hero__scroll span{width:1px;height:22px;background:var(--metal)}
.hero__scroll svg{color:var(--metal)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(5px)}}


/* ── HERO STATS ─────────────────────────────────────────── */
.hero__stats{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.hero__stat{display:flex;align-items:center;gap:10px;font-family:var(--font-b);font-size:15px;color:var(--cream);line-height:1.3}
.hero__stat strong{color:var(--bone);font-weight:600}
.hero__stat-stars{font-size:14px;letter-spacing:1px;flex-shrink:0}
.hero__stat-icon{font-size:16px;flex-shrink:0;width:22px;text-align:center}

/* ── GOOGLE RATING BADGE ─────────────────────────────────── */
.grating{display:inline-flex;align-items:center;gap:14px;background:linear-gradient(135deg,rgba(244,163,71,.12) 0%,rgba(232,96,28,.08) 100%);border:1.5px solid rgba(244,163,71,.40);border-radius:8px;padding:12px 22px;margin-bottom:24px}
.grating__stars{display:flex;gap:4px}
.grating__stars svg{width:18px;height:18px;color:var(--amber)}
.grating__text{display:flex;flex-direction:column;gap:2px;text-align:left}
.grating__score{font-family:var(--font-d);font-size:17px;font-weight:700;letter-spacing:.04em;color:var(--text-1);text-transform:uppercase}
.grating__sub{font-family:var(--font-d);font-size:10px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--text-2)}

/* ── CONTACTO BENEFICIOS ─────────────────────────────────── */
.contacto-beneficios{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.contacto-beneficios li{font-family:var(--font-d);font-size:13px;font-weight:400;letter-spacing:.05em;color:var(--cream);display:flex;align-items:center;gap:8px}
/* ── GOOGLE RATING BADGE ─────────────────────────────────── */
.grating{display:inline-flex;align-items:center;gap:14px;background:linear-gradient(135deg,rgba(244,163,71,.12) 0%,rgba(232,96,28,.08) 100%);border:1.5px solid rgba(244,163,71,.40);border-radius:8px;padding:12px 22px;margin-bottom:24px}
.grating__stars{display:flex;gap:4px}
.grating__stars svg{width:18px;height:18px;color:var(--amber)}
.grating__text{display:flex;flex-direction:column;gap:2px;text-align:left}
.grating__score{font-family:var(--font-d);font-size:17px;font-weight:700;letter-spacing:.04em;color:var(--text-1);text-transform:uppercase}
.grating__sub{font-family:var(--font-d);font-size:10px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--text-2)}

/* ── BANDA CONFIANZA ─────────────────────────────────────── */
.banda{background:var(--carbon);border-top:1px solid var(--ash);border-bottom:1px solid var(--ash);padding:28px var(--pad)}
.banda__inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;max-width:1200px;margin:0 auto}
.banda__item{display:flex;align-items:center;gap:9px;padding:10px 28px;border-right:1px solid rgba(46,41,35,.50);font-family:var(--font-d);font-size:12px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--cream);white-space:nowrap}
.banda__item:last-child{border-right:none}
.banda__icon{font-size:15px;flex-shrink:0}

/* ── CONTACTO EXP ────────────────────────────────────────── */
.contacto__exp{font-family:var(--font-b);font-size:14px;font-style:italic;color:var(--cream);line-height:1.60;margin-bottom:10px;padding:10px 14px;background:rgba(232,96,28,.08);border-left:3px solid var(--fire);border-radius:0 var(--r) var(--r) 0}
/* ── SECTIONS ───────────────────────────────────────────── */
.section{padding:clamp(72px,10vw,120px) var(--pad);position:relative}
.section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--fire),var(--amber))}
.section--light{background:var(--bg-light)}
.section--dark{background:var(--forge);overflow:hidden}
.section--dark::after{content:'';position:absolute;bottom:-120px;right:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(232,96,28,.06) 0%,transparent 70%);pointer-events:none}
.section--mid{background:var(--carbon);padding-top:clamp(40px,5vw,64px)!important;padding-bottom:clamp(40px,5vw,64px)!important}
.section__top{text-align:center;margin-bottom:56px;position:relative;z-index:1}
.section__titulo{font-family:var(--font-d);font-size:clamp(32px,5vw,52px);font-weight:700;letter-spacing:.02em;text-transform:uppercase;line-height:1.06;margin-bottom:16px;position:relative;display:inline-block}
.section--light .section__titulo{color:var(--text-1)}
.section--dark .section__titulo,.section--mid .section__titulo{color:var(--bone)}
.section__titulo::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:48px;height:3px;background:var(--fire);border-radius:1px}
.section__titulo.left{display:block}
.section__titulo.left::after{left:0;transform:none}
.section__sub{font-family:var(--font-b);font-size:clamp(15px,1.4vw,17px);line-height:1.72;max-width:520px;margin:24px auto 0}
.section__sub.left{margin-left:0}
.section--light .section__sub{color:var(--text-2)}
.section--dark .section__sub,.section--mid .section__sub{color:var(--metal)}
.section__cta{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:56px;position:relative;z-index:1}
.section__cta-texto{font-family:var(--font-b);font-size:15px;font-style:italic;color:var(--metal)}

/* ── FILTROS ────────────────────────────────────────────── */
.filtros{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;margin-bottom:48px}
.filtro{font-family:var(--font-d);font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--metal);background:transparent;border:1px solid rgba(122,112,101,.30);padding:9px 20px;border-radius:2px;transition:background var(--tr),border-color var(--tr),color var(--tr),transform .15s;outline:none;user-select:none}
.filtro:hover{border-color:var(--fire);color:var(--fire);transform:translateY(-1px)}
.filtro.active{background:var(--fire);border-color:var(--fire);color:#fff;font-weight:600}
.filtro.active:hover{background:var(--ember);border-color:var(--ember)}

/* ── GALERÍA ────────────────────────────────────────────── */
.galeria{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:1280px;margin:0 auto}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-card);cursor:pointer;display:flex;flex-direction:column;opacity:0;transform:translateY(18px);transition:opacity .4s ease,transform .4s ease,box-shadow var(--tr),border-color var(--tr)}
.card.vis{opacity:1;transform:translateY(0)}
.card:hover{transform:translateY(-5px)!important;box-shadow:var(--sh-hover)}
.card.hide{display:none}
.card.in{animation:cardIn .38s ease forwards}
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.card__img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden;background:#E8E4DF}
.card__img{width:100%;height:100%;object-fit:cover;transition:transform .42s ease}
.card:hover .card__img{transform:scale(1.06)}
.card__overlay{position:absolute;inset:0;background:rgba(15,13,11,.42);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--tr)}
.card:hover .card__overlay{opacity:1}
.card__zoom{width:48px;height:48px;border-radius:50%;border:2px solid rgba(245,240,232,.85);display:flex;align-items:center;justify-content:center;color:var(--bone);transform:scale(.8);transition:transform .22s ease}
.card:hover .card__zoom{transform:scale(1)}
.card__info{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.card__cat{font-family:var(--font-d);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fire)}
.card__nombre{font-family:var(--font-d);font-size:15px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--text-1);line-height:1.2}

/* ── LIGHTBOX ───────────────────────────────────────────── */
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.lightbox[hidden]{display:none}
.lightbox.show{animation:lbIn .22s ease forwards}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lb-backdrop{position:absolute;inset:0;background:rgba(15,13,11,.92);cursor:pointer;z-index:1}
.lb-stage{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;max-width:min(90vw,1000px);max-height:90vh;animation:lbSlide .28s ease forwards}
@keyframes lbSlide{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.lb-img{max-width:100%;max-height:calc(90vh - 80px);object-fit:contain;border-radius:2px;box-shadow:0 32px 80px rgba(0,0,0,.6)}
.lb-caption{display:flex;align-items:center;gap:12px;margin-top:18px}
.lb-cat{font-family:var(--font-d);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--fire)}
.lb-nombre{font-family:var(--font-d);font-size:15px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--bone)}
.lb-cerrar{position:fixed;top:20px;right:24px;z-index:20;width:44px;height:44px;border-radius:50%;background:rgba(46,41,35,.8);border:1px solid rgba(122,112,101,.4);color:var(--cream);display:flex;align-items:center;justify-content:center;transition:background var(--tr)}
.lb-cerrar:hover{background:var(--fire);color:#fff}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:20;width:48px;height:48px;border-radius:50%;background:rgba(46,41,35,.8);border:1px solid rgba(122,112,101,.4);color:var(--cream);display:flex;align-items:center;justify-content:center;transition:background var(--tr),transform .15s ease}
.lb-nav:hover{background:var(--fire);color:#fff}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-prev:hover{transform:translateY(-50%) translateX(-2px)}
.lb-next:hover{transform:translateY(-50%) translateX(2px)}

/* ── SERVICIOS ──────────────────────────────────────────── */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto;position:relative;z-index:1}
.srv-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:36px 28px 28px;display:flex;flex-direction:column;box-shadow:var(--sh-card);overflow:hidden;opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease,box-shadow var(--tr),border-color var(--tr)}
.srv-card.vis{opacity:1;transform:translateY(0)}
.srv-card:hover{transform:translateY(-6px)!important;box-shadow:0 16px 48px rgba(15,13,11,.13);border-color:rgba(232,96,28,.2)}
.srv-card:nth-child(even){margin-top:0}
.srv-accent{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--fire),var(--amber));transform:scaleX(0);transform-origin:left;transition:transform .36s ease}
.srv-card:hover .srv-accent{transform:scaleX(1)}
.srv-icon-wrap{position:relative;width:56px;height:56px;margin-bottom:24px;flex-shrink:0}
.srv-icon-bg{position:absolute;inset:0;border-radius:10px;background:rgba(232,96,28,.08);transition:background var(--tr),transform var(--tr)}
.srv-card:hover .srv-icon-bg{background:rgba(232,96,28,.14);transform:rotate(6deg) scale(1.05)}
.srv-icon{position:relative;z-index:1;width:56px;height:56px;stroke:var(--fire);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none;padding:10px;transition:stroke var(--tr),transform var(--tr)}
.srv-card:hover .srv-icon{stroke:var(--ember);transform:scale(1.06)}
.srv-body{flex:1;margin-bottom:24px}
.srv-body h3{font-family:var(--font-d);font-size:17px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--text-1);line-height:1.2;margin-bottom:12px}
.srv-body p{font-family:var(--font-b);font-size:14px;line-height:1.76;color:var(--text-2)}
.srv-footer{border-top:1px solid rgba(46,41,35,.08);padding-top:18px;margin-top:auto}
.srv-footer a{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-d);font-size:12px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--fire);transition:gap var(--tr),color var(--tr)}
.srv-footer a svg{transition:transform var(--tr)}
.srv-footer a:hover{color:var(--ember);gap:11px}
.srv-footer a:hover svg{transform:translateX(3px)}

/* ── TESTIMONIOS ────────────────────────────────────────── */
.tst-deco-l,.tst-deco-r{position:absolute;border-radius:50%;pointer-events:none}
.tst-deco-l{top:10%;left:-60px;width:220px;height:220px;border:1px solid rgba(232,96,28,.07)}
.tst-deco-r{bottom:8%;right:-80px;width:300px;height:300px;border:1px solid rgba(232,96,28,.06)}
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1100px;margin:0 auto;align-items:center;position:relative;z-index:1}
.tst-card{position:relative;background:var(--bg-card);border:1px solid rgba(46,41,35,.10);border-radius:var(--r);padding:36px 32px 28px;display:flex;flex-direction:column;box-shadow:var(--sh-card);overflow:hidden;opacity:0;transform:translateY(28px);transition:opacity .52s ease,transform .52s ease,box-shadow var(--tr)}
.tst-card.vis{opacity:1;transform:translateY(0)}
.tst-card:hover{transform:translateY(-5px)!important;box-shadow:0 20px 56px rgba(15,13,11,.12)}
.tst-featured{background:var(--forge);border-color:rgba(232,96,28,.30);box-shadow:0 24px 64px rgba(15,13,11,.32),0 6px 20px rgba(232,96,28,.18);z-index:2}
.tst-featured.vis{transform:translateY(-12px) scale(1.03)}
.tst-featured:hover{transform:translateY(-18px) scale(1.03)!important}
.tst-accent{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--fire),var(--amber));transform:scaleX(0);transform-origin:left;transition:transform .36s ease}
.tst-card:hover .tst-accent{transform:scaleX(1)}
.tst-featured .tst-accent{transform:scaleX(1)}
.tst-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.tst-stars{display:flex;gap:4px}
.tst-stars svg{width:14px;height:14px;color:var(--amber)}
.tst-comilla{font-family:var(--font-b);font-size:72px;font-style:italic;line-height:.6;color:rgba(232,96,28,.18);user-select:none}
.tst-featured .tst-comilla{color:rgba(232,96,28,.30)}
.tst-texto{font-family:var(--font-b);font-size:15px;font-style:italic;line-height:1.82;color:var(--text-2);flex:1;margin-bottom:28px;quotes:none}
.tst-featured .tst-texto{color:var(--cream);font-size:16px}
.tst-footer{display:flex;align-items:center;gap:14px;border-top:1px solid rgba(46,41,35,.08);padding-top:20px}
.tst-featured .tst-footer{border-top-color:rgba(245,240,232,.10)}
.tst-avatar{width:42px;height:42px;border-radius:50%;background:rgba(232,96,28,.10);border:1.5px solid rgba(232,96,28,.25);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:13px;font-weight:600;color:var(--fire);flex-shrink:0}
.tst-autor{display:block;font-family:var(--font-d);font-size:14px;font-weight:600;font-style:normal;letter-spacing:.04em;text-transform:uppercase;color:var(--text-1)}
.tst-featured .tst-autor{color:var(--bone)}
.tst-srv{display:block;font-family:var(--font-d);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fire);margin-top:3px}

/* ── CONTACTO ───────────────────────────────────────────── */
.contacto-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:1100px;margin:0 auto;align-items:center;position:relative;z-index:1}
.contacto-datos{display:flex;flex-direction:column;gap:14px;margin:20px 0 22px}
.contacto-datos li{display:flex;align-items:center;gap:14px}
.dato-icon{width:38px;height:38px;border-radius:50%;background:rgba(232,96,28,.12);border:1px solid rgba(232,96,28,.25);display:flex;align-items:center;justify-content:center;color:var(--fire);flex-shrink:0}
.contacto-datos a,.contacto-datos span{font-family:var(--font-d);font-size:14px;color:var(--cream);letter-spacing:.04em}
.contacto-datos a:hover{color:var(--fire)}
.contacto-mapa{height:100%;min-height:200px;max-height:340px;border-radius:var(--r);overflow:hidden;border:1px solid rgba(46,41,35,.30);box-shadow:0 8px 32px rgba(0,0,0,.30)}
.contacto-mapa iframe{display:block;width:100%;height:100%}

/* ── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--forge);border-top:1px solid var(--ash)}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;max-width:1100px;margin:0 auto;padding:clamp(48px,7vw,80px) var(--pad) clamp(32px,5vw,56px)}
.footer-logo{font-family:var(--font-d);font-size:20px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--bone);margin-bottom:14px}
.footer-logo span{color:var(--fire)}
.footer-brand p{font-family:var(--font-b);font-size:14px;color:var(--metal);line-height:1.7}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav-title{font-family:var(--font-d);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--fire);margin-bottom:4px}
.footer-nav a,.footer-nav span{font-family:var(--font-d);font-size:13px;color:var(--metal);letter-spacing:.04em;transition:color var(--tr)}
.footer-nav a:hover{color:var(--cream)}
.footer-bottom{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding:20px var(--pad);border-top:1px solid var(--ash);font-family:var(--font-d);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--metal)}

/* ── WHATSAPP ───────────────────────────────────────────── */
.wa{position:fixed;bottom:28px;right:28px;z-index:9999;display:flex;align-items:center;text-decoration:none;opacity:0;transform:translateY(20px) scale(.88);pointer-events:none;transition:opacity .42s cubic-bezier(.34,1.56,.64,1),transform .42s cubic-bezier(.34,1.56,.64,1)}
.wa.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.wa-pulse,.wa-pulse2{position:absolute;border-radius:50%;pointer-events:none}
.wa-pulse{inset:-6px;background:rgba(37,211,102,.28);animation:waPulse 3s ease-out infinite}
.wa-pulse2{inset:-12px;background:rgba(37,211,102,.12);animation:waPulse 3s ease-out infinite .8s}
@keyframes waPulse{0%{transform:scale(1);opacity:1}70%{transform:scale(1.45);opacity:0}100%{transform:scale(1.45);opacity:0}}
.wa-circle{position:relative;z-index:1;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4),0 2px 8px rgba(0,0,0,.18);transition:transform .22s ease,background .22s ease}
.wa:hover .wa-circle{background:#20BA5A;transform:scale(1.10)}
.wa:active .wa-circle{transform:scale(.96)}
.wa-icon{width:30px;height:30px;fill:#fff;flex-shrink:0}
.wa-badge{position:absolute;top:-3px;right:-3px;z-index:2;width:18px;height:18px;border-radius:50%;background:var(--fire);border:2px solid var(--bg-light);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:10px;font-weight:600;color:#fff;animation:waBadge 3s ease-in-out infinite 2s}
@keyframes waBadge{0%,85%,100%{transform:scale(1)}90%{transform:scale(1.25)}95%{transform:scale(.92)}}
.wa-label{position:absolute;right:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(6px);background:var(--carbon);color:var(--bone);font-family:var(--font-d);font-size:12px;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;padding:8px 14px;border-radius:3px;pointer-events:none;opacity:0;transition:opacity .22s ease,transform .22s ease;box-shadow:0 4px 16px rgba(0,0,0,.20)}
.wa-label::after{content:'';position:absolute;top:50%;right:-6px;transform:translateY(-50%);border:6px solid transparent;border-right:none;border-left-color:var(--carbon)}
.wa:hover .wa-label{opacity:1;transform:translateY(-50%) translateX(0)}

/* ── FADE-IN ────────────────────────────────────────────── */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}
.fade-in.vis{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .srv-grid{grid-template-columns:repeat(2,1fr)}
  .srv-card:nth-child(even){margin-top:0}
  .srv-card:nth-child(3n){margin-top:16px}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:960px){
  .tst-grid{grid-template-columns:1fr;max-width:520px;gap:20px}
  .tst-featured{order:-1}
  .tst-featured.vis{transform:translateY(0) scale(1)!important}
  .tst-featured:hover{transform:translateY(-5px) scale(1)!important}
  .contacto-inner{grid-template-columns:1fr;gap:48px}
  .contacto-mapa{height:200px;max-height:200px}
}
@media(max-width:768px){
  :root{--nav:54px;--pad:24px}
  .nav__links{display:none;position:fixed;top:var(--nav);left:0;right:0;bottom:0;background:rgba(15,13,11,.98);flex-direction:column;align-items:center;justify-content:center;gap:0;z-index:99}
  .nav__links.open{display:flex}
  .nav__links.open .nav__link{font-size:20px;padding:16px 0;letter-spacing:.12em}
  .nav__burger{display:flex}
  .hero{align-items:flex-end;padding-bottom:56px}
  .hero::before{background:rgba(15,13,11,.50)}
  .hero__content{max-width:100%;align-items:center;text-align:center;padding-top:0}
  .hero__h1{align-items:center;font-size:clamp(40px,11vw,54px);margin-bottom:18px}
  .hero__sub{font-size:15px;max-width:100%;margin-bottom:32px}
  .hero__ctas{flex-direction:column;width:100%;gap:10px;margin-bottom:24px}
  .hero__ctas .btn{width:100%;justify-content:center;padding:16px 0}
  .hero__badges{align-items:center}
  .hero__stats{align-items:center}
  .hero__stat{font-size:14px;justify-content:center}
  .hero__badges .sep{display:none}
  .hero__scroll{display:none}
  .galeria{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
  .srv-grid{grid-template-columns:1fr;gap:16px}
  .srv-card:nth-child(even),.srv-card:nth-child(3n){margin-top:0}
  .footer-inner{grid-template-columns:1fr;gap:32px}
  .wa{bottom:20px;right:20px}
  .wa-circle{width:52px;height:52px}
  .wa-icon{width:26px;height:26px}
  .wa-label{display:none}

  .banda__item{padding:8px 16px;border-right:none;border-bottom:1px solid rgba(46,41,35,.30);width:50%;justify-content:center}
  .banda__item:nth-child(odd){border-right:1px solid rgba(46,41,35,.30)}
  .banda__item:last-child{border-bottom:none;width:100%;border-right:none}
  .lb-prev{left:8px}
  .lb-next{right:8px}
  .lb-nav{width:40px;height:40px}
}
@media(max-width:480px){
  .galeria{grid-template-columns:1fr 1fr;gap:12px}
  .card__info{padding:12px 14px 14px}
  .card__nombre{font-size:13px}
}
@media(max-width:400px){
  .hero__h1{font-size:36px}
  .galeria{grid-template-columns:1fr}
}
