/* ═══════════════════════════════════════════════
   CID IMPRESIONES · Sitio web
   Paleta: negro profundo + verde lima CID + beige
═══════════════════════════════════════════════ */

:root{
  --bg:#0b0b0d;
  --bg2:#121216;
  --bg3:#1a1a20;
  --ink:#f5f5f7;
  --ink2:#b8b8c0;
  --ink3:#74747c;
  --line:#26262c;
  --lime:#c4ff00;
  --lime-d:#9fcc00;
  --lime-l:#dcff5c;
  --f-display:'Archivo Black','Impact','Arial Black',sans-serif;
  --f-body:'Inter',system-ui,-apple-system,sans-serif;
  --radius:14px;
  --mx:min(1280px,92vw);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--f-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ═══ NAV ═══ */
.nav{position:sticky;top:0;z-index:100;background:rgba(11,11,13,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-inner{width:var(--mx);margin:0 auto;padding:14px 0;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center}
.brand-img{height:56px;width:auto;display:block;max-height:64px;object-fit:contain}
@media(max-width:700px){.brand-img{height:46px;max-height:52px}}
.nav-links{display:flex;gap:26px}
.nav-links a{font-size:13px;font-weight:600;color:var(--ink2);transition:color .2s;letter-spacing:.02em}
.nav-links a:hover{color:var(--lime)}
.btn-cot{background:var(--lime);color:#0b0b0d;padding:10px 18px;border-radius:999px;font-weight:800;font-size:13px;letter-spacing:.02em;transition:transform .15s,background .2s}
.btn-cot:hover{background:var(--lime-l);transform:translateY(-1px)}
@media(max-width:900px){.nav-links{display:none}}

/* ═══ HERO ═══ */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;padding:56px 0;overflow:hidden;isolation:isolate}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;filter:brightness(.55) saturate(1.1)}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(800px 500px at 85% 20%, rgba(196,255,0,.18), transparent 60%),
  radial-gradient(600px 400px at 10% 80%, rgba(0,0,0,.5), transparent 60%),
  linear-gradient(180deg,rgba(11,11,13,.55) 0%,rgba(11,11,13,.85) 100%);
  z-index:-1}
.hero-bg::after{content:'';position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:56px 56px;mask-image:radial-gradient(ellipse at center,black 20%,transparent 75%)}
.hero-inner{width:var(--mx);margin:0 auto;position:relative;z-index:1}
.hero-tag{display:inline-block;font-family:var(--f-display);font-size:12px;color:var(--lime);letter-spacing:.35em;padding:7px 14px;border:1px solid rgba(196,255,0,.4);border-radius:999px;background:rgba(196,255,0,.08);margin-bottom:28px}
.hero-title{font-family:var(--f-display);font-size:clamp(48px,9vw,128px);line-height:.92;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:22px}
.hero-title .acc{color:var(--lime);font-style:italic}
.hero-sub{font-size:clamp(16px,1.6vw,20px);color:var(--ink2);max-width:580px;margin-bottom:38px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:60px}
.btn-primary{background:var(--lime);color:#0b0b0d;padding:12px 24px;border-radius:999px;font-weight:800;font-size:15px;letter-spacing:.02em;transition:transform .15s,background .2s,box-shadow .2s;box-shadow:0 10px 40px rgba(196,255,0,.3)}
.btn-primary:hover{background:var(--lime-l);transform:translateY(-2px);box-shadow:0 16px 50px rgba(196,255,0,.45)}
.btn-secondary{background:transparent;color:var(--ink);padding:16px 30px;border:2px solid var(--line);border-radius:999px;font-weight:700;font-size:15px;transition:border-color .2s,background .2s}
.btn-secondary:hover{border-color:var(--lime);background:rgba(196,255,0,.08)}
.btn-big{padding:14px 30px;font-size:17px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding-top:34px;border-top:1px solid var(--line);max-width:780px}
.stat{display:flex;flex-direction:column;gap:4px}
.stat-num{font-family:var(--f-display);font-size:clamp(28px,4vw,44px);color:var(--lime);line-height:1}
.stat-lbl{font-size:12px;color:var(--ink3);text-transform:uppercase;letter-spacing:.08em}
.hero-scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--ink3);letter-spacing:.3em;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,6px)}}
@media(max-width:700px){.hero-stats{grid-template-columns:repeat(2,1fr);gap:14px}}

/* ═══ PROMOS POR DÍA — VIP, editorial ═══ */
.promos{width:var(--mx);margin:48px auto;padding:40px 0;opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s}
.promos.in{opacity:1;transform:none}
.promos-head{text-align:center;margin-bottom:28px;max-width:720px;margin-left:auto;margin-right:auto}
.promos-kicker{display:inline-block;font-size:10.5px;font-weight:600;color:var(--lime);text-transform:uppercase;letter-spacing:.42em;margin-bottom:22px;padding:7px 18px;border:1px solid rgba(196,255,0,.25);border-radius:999px;background:linear-gradient(180deg,rgba(196,255,0,.04),transparent)}
.promos-title{font-family:var(--f-display);font-size:clamp(42px,6vw,76px);font-weight:900;letter-spacing:-.025em;line-height:.95;text-transform:uppercase;background:linear-gradient(180deg,#fff 0%,#999 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.promos-title .acc{background:linear-gradient(180deg,var(--lime) 0%,var(--lime-d) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.promos-sub{color:var(--ink2);font-size:15px;margin-top:22px;line-height:1.6;font-weight:300}
.promos-sub strong{color:var(--lime);font-weight:600}
.promos-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:36px}
.promo-card{position:relative;overflow:hidden;padding:30px 24px 26px;border-radius:18px;min-height:440px;display:flex;flex-direction:column;background:linear-gradient(170deg,#1a1a20 0%,#0d0d11 100%);border:1px solid rgba(255,255,255,.05);transition:transform .5s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s;color:#fff;isolation:isolate;cursor:default}
.promo-card::before{content:"";position:absolute;top:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(196,255,0,.5) 30%,rgba(196,255,0,.8) 50%,rgba(196,255,0,.5) 70%,transparent 100%);opacity:.4;transition:opacity .4s;z-index:2}
.promo-card::after{content:"";position:absolute;inset:-60% -40% auto auto;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(196,255,0,.18) 0%,transparent 60%);filter:blur(60px);pointer-events:none;transition:opacity .6s,transform 1s;opacity:.5;animation:breathe 9s ease-in-out infinite alternate;z-index:0}
@keyframes breathe{0%{transform:translate(0,0) scale(1);opacity:.45}100%{transform:translate(-30px,20px) scale(1.25);opacity:.7}}
.promo-card:hover{transform:translateY(-8px);border-color:rgba(196,255,0,.35);box-shadow:0 30px 60px -25px rgba(196,255,0,.35),0 0 0 1px rgba(196,255,0,.12) inset}
.promo-card:hover::before{opacity:1}
.promo-card:hover::after{opacity:.85}
.promo-card > *{position:relative;z-index:1}
.promo-idx{font-family:var(--f-display);font-size:10px;font-weight:700;letter-spacing:.36em;color:var(--ink3);text-transform:uppercase;margin-bottom:28px}
.promo-day{display:flex;flex-direction:column;margin-bottom:auto}
.promo-day .d1{font-family:var(--f-display);font-size:11px;font-weight:800;letter-spacing:.42em;color:var(--lime);text-transform:uppercase;margin-bottom:16px}
.promo-day .d2{font-family:var(--f-display);font-size:clamp(20px,2.2vw,26px);font-weight:900;letter-spacing:-.015em;color:#fff;line-height:1.08;text-transform:uppercase}
.promo-price{font-family:var(--f-display);font-weight:900;line-height:.82;display:flex;align-items:flex-start;margin-top:32px;margin-bottom:4px;background:linear-gradient(180deg,#fff 0%,#a8a8a8 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.promo-price .dollar{font-size:clamp(20px,2vw,26px);margin-top:12px;background:linear-gradient(180deg,var(--lime) 0%,var(--lime-d) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;font-weight:700}
.promo-price .amount{font-size:clamp(60px,6.5vw,96px);letter-spacing:-.05em}
.promo-price .unit{font-size:10px;margin-top:18px;margin-left:8px;color:var(--ink3);letter-spacing:.3em;font-weight:600;text-transform:uppercase;-webkit-text-fill-color:var(--ink3);background:none}
.promo-foot{font-size:11px;font-weight:400;letter-spacing:.01em;margin-top:22px;color:var(--ink3);line-height:1.65;border-top:1px solid rgba(255,255,255,.06);padding-top:16px}
.promos-cta{text-align:center;margin-top:28px}
.banner-btn{display:inline-block;background:var(--lime);color:#0b0b0d;padding:14px 28px;border-radius:999px;font-weight:700;font-size:14px;transition:transform .25s,box-shadow .25s,background .25s;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 14px 40px rgba(196,255,0,.22)}
.banner-btn:hover{transform:translateY(-3px);background:var(--lime-l);box-shadow:0 20px 55px rgba(196,255,0,.4)}
@media(max-width:1100px){.promos-grid{grid-template-columns:repeat(3,1fr)}.promo-card{min-height:380px}}
@media(max-width:700px){.promos-grid{grid-template-columns:repeat(2,1fr);gap:10px}.promo-card{min-height:320px;padding:24px 18px 20px}}

/* ═══ SECCIONES genéricas ═══ */
.sec{padding:56px 0;opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.sec.in{opacity:1;transform:none}
.sec-dark{background:var(--bg2)}
.sec-head{width:var(--mx);margin:0 auto 32px;max-width:860px}
.sec-kick{font-size:12px;color:var(--lime);letter-spacing:.3em;font-weight:700;margin-bottom:14px;text-transform:uppercase}
.sec-title{font-family:var(--f-display);font-size:clamp(32px,5vw,60px);line-height:1;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:16px}
.sec-lead{font-size:17px;color:var(--ink2);max-width:620px}

/* ═══ SERVICIOS ═══ */
/* 🆕 Carrusel horizontal scroll-snap · 4 visibles desktop · scroll lateral mobile */
.srv-grid{
  width:var(--mx);margin:0 auto;
  display:grid;grid-auto-flow:column;grid-auto-columns:calc(25% - 11px);
  gap:14px;overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  padding:8px 4px 24px;
  scrollbar-width:thin;scrollbar-color:var(--lime) #161618;
}
.srv-grid::-webkit-scrollbar{height:6px}
.srv-grid::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:99px}
.srv-grid::-webkit-scrollbar-thumb{background:var(--lime);border-radius:99px}
.srv-grid > .srv{scroll-snap-align:start}
.srv{position:relative;overflow:hidden;background:linear-gradient(170deg,#16161c 0%,#0c0c10 100%);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:22px 18px 18px;min-height:160px;transition:transform .5s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s;display:flex;flex-direction:column;justify-content:space-between;isolation:isolate;cursor:pointer}
.srv::before{content:attr(data-num);position:absolute;top:20px;right:24px;font-family:var(--f-display);font-size:11px;font-weight:700;line-height:1;letter-spacing:.3em;color:var(--ink3);transition:color .3s;z-index:1}
.srv::after{content:"";position:absolute;inset:-60% -40% auto auto;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(196,255,0,.14) 0%,transparent 60%);filter:blur(55px);pointer-events:none;transition:opacity .6s,transform 1s;opacity:.35;animation:breathe 8s ease-in-out infinite alternate;z-index:0}
.srv > *{position:relative;z-index:1}
.srv:hover{transform:translateY(-6px);border-color:rgba(196,255,0,.4);box-shadow:0 24px 50px -22px rgba(196,255,0,.38),0 0 0 1px rgba(196,255,0,.1) inset}
.srv:hover::before{color:var(--lime)}
.srv:hover::after{opacity:.75}
.srv h3{font-family:var(--f-display);font-size:clamp(26px,2.4vw,38px);font-weight:900;letter-spacing:-.025em;text-transform:uppercase;line-height:.92;color:#fff;margin:0 0 8px;transition:color .3s}
.srv:hover h3{background:linear-gradient(180deg,#fff 0%,var(--lime-l) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.srv-sub{font-size:11px;font-weight:500;color:var(--ink3);letter-spacing:.02em;line-height:1.5;display:block;margin-top:auto;padding-top:18px;border-top:1px solid rgba(255,255,255,.06)}

.prod-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:30px;margin-bottom:10px}
.prod-tag{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.05em;padding:8px 16px;border-radius:999px;border:1px solid var(--line);color:var(--ink2);background:rgba(255,255,255,.02);cursor:pointer;transition:all .2s;user-select:none}
.prod-tag:hover{border-color:var(--lime);color:#fff}
.prod-tag.is-active{background:var(--lime);color:#0b0b0d;border-color:var(--lime);font-weight:800}

.prod-foot{width:var(--mx);margin:48px auto 0;text-align:center;position:relative;padding:40px 24px;background:linear-gradient(180deg,transparent,rgba(196,255,0,.04));border-top:1px dashed rgba(196,255,0,.25)}
.prod-foot-txt{font-size:18px;color:var(--ink);margin-bottom:22px}
.prod-foot-txt strong{color:var(--lime)}
@media(max-width:1200px){.srv-grid{grid-auto-columns:calc(33.33% - 10px)}}
@media(max-width:760px){.srv-grid{grid-auto-columns:calc(50% - 7px);gap:10px}.srv{min-height:170px;padding:18px 16px}}
@media(max-width:480px){.srv-grid{grid-auto-columns:calc(70% - 7px)}}
.srv h3{font-size:clamp(20px,2.4vw,30px) !important;line-height:.95 !important;letter-spacing:-.6px}

/* ═══ GALERÍA / portfolio ═══ */
.gal-grid{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:12px}
.gal-item{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--bg3);cursor:pointer;transform:translateZ(0)}
.gal-big{grid-column:span 2;grid-row:span 2}
.gal-tall{grid-row:span 2}
.gal-wide{grid-column:span 2}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;filter:saturate(1.05) contrast(1.02)}
.gal-item:hover img{transform:scale(1.08)}
.gal-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 55%);opacity:.85;transition:opacity .3s}
.gal-item:hover::after{opacity:1}
.gal-cap{position:absolute;bottom:16px;left:18px;right:18px;z-index:1;font-family:var(--f-display);font-size:14px;letter-spacing:.05em;text-transform:uppercase;color:var(--lime-l)}
.gal-mas{width:var(--mx);margin:40px auto 0;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-ghost{background:transparent;color:var(--ink);padding:12px 24px;border:1px solid var(--line);border-radius:999px;font-weight:600;font-size:13px;transition:all .2s}
.btn-ghost:hover{border-color:var(--lime);color:var(--lime)}
@media(max-width:900px){.gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}.gal-big,.gal-wide{grid-column:span 2}.gal-tall{grid-row:span 1}}

/* ═══ NOSOTROS ═══ */
.nos-wrap{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr;gap:36px;align-items:start}
.nos-text .sec-title{margin-bottom:28px}
.nos-p{color:var(--ink2);margin-bottom:18px;font-size:16px;line-height:1.75}
.nos-p strong{color:var(--ink);font-weight:700}
.nos-firma{font-family:var(--f-display);color:var(--lime);font-size:18px;margin-top:28px;letter-spacing:.04em}
.nos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;position:sticky;top:100px}
.nos-card{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:20px 16px;transition:transform .2s,border-color .2s}
.nos-card:hover{transform:translateY(-3px);border-color:var(--lime)}
.nos-card-acc{background:linear-gradient(135deg,var(--lime),var(--lime-d));border-color:transparent}
.nos-card-acc .nos-num,.nos-card-acc .nos-lbl{color:#0b0b0d}
.nos-num{font-family:var(--f-display);font-size:40px;color:var(--lime);line-height:1;margin-bottom:8px}
.nos-lbl{font-size:12px;color:var(--ink2);letter-spacing:.1em;text-transform:uppercase;line-height:1.3}
@media(max-width:900px){.nos-wrap{grid-template-columns:1fr;gap:40px}.nos-grid{position:static}}

/* ═══ POR QUÉ CID ═══ */
.why-grid{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.why{background:var(--bg3);border:1px solid var(--line);border-radius:var(--radius);padding:22px 20px;position:relative;transition:border-color .25s}
.why:hover{border-color:var(--lime)}
.why-n{font-family:var(--f-display);font-size:14px;color:var(--lime);letter-spacing:.1em;margin-bottom:14px}
.why h3{font-family:var(--f-display);font-size:20px;text-transform:uppercase;letter-spacing:.02em;margin-bottom:12px;line-height:1.15}
.why p{color:var(--ink2);font-size:14px;line-height:1.65}
@media(max-width:900px){.why-grid{grid-template-columns:1fr}}

/* ═══ TESTIMONIOS · ELIMINADOS 2026-04-27 (reemplazados por catálogo CTA) ═══ */

/* ═══ CTA FINAL ═══ · 2026-04-26 invertido por contraste */
.cta-final{padding:56px 0;text-align:center;background:#0a0a0a;color:#f0e8da;opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-final.in{opacity:1;transform:none}
.cta-final::before{content:'';position:absolute;inset:0;background-image:
  linear-gradient(rgba(196,255,0,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(196,255,0,.04) 1px,transparent 1px);
  background-size:48px 48px;pointer-events:none}
.cta-inner{position:relative;z-index:1;width:var(--mx);margin:0 auto}
.cta-final h2{font-family:var(--f-display);font-size:clamp(32px,5vw,58px);text-transform:uppercase;margin-bottom:14px;line-height:1;color:var(--lime)}
.cta-final p{font-size:18px;margin-bottom:34px;font-weight:500;color:rgba(245,240,232,.85)}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-final .btn-primary{background:var(--lime);color:#0a0a0a;box-shadow:0 12px 36px rgba(196,255,0,.25)}
.cta-final .btn-primary:hover{background:var(--lime-l);transform:translateY(-2px);box-shadow:0 16px 50px rgba(196,255,0,.4)}
.cta-final .btn-secondary{border-color:var(--lime);color:var(--lime);background:transparent}
.cta-final .btn-secondary:hover{background:rgba(196,255,0,.08);border-color:var(--lime-l);color:var(--lime-l)}

/* ═══ FOOTER ═══ */
.foot{background:#050506;padding:48px 22px 30px;border-top:1px solid var(--line)}
.foot-grid{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot-col h4{font-family:var(--f-display);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--lime);margin-bottom:16px}
.foot-brand{display:flex;align-items:baseline;gap:8px;margin-bottom:16px}
.foot-logo{font-family:var(--f-display);font-size:28px;color:var(--lime);letter-spacing:.04em}
.foot-sub{font-family:var(--f-display);font-size:12px;color:var(--ink);letter-spacing:.3em}
.foot-desc{color:var(--ink2);font-size:14px;line-height:1.65;max-width:340px;margin-bottom:16px}
.foot-social{display:flex;gap:14px}
.foot-social a{font-size:13px;color:var(--ink2);border:1px solid var(--line);padding:7px 14px;border-radius:999px;transition:all .2s}
.foot-social a:hover{color:var(--lime);border-color:var(--lime)}
.foot-link{display:block;color:var(--ink2);font-size:14px;padding:6px 0;transition:color .15s}
.foot-link:hover{color:var(--lime)}
.foot-p{color:var(--ink2);font-size:14px;margin-bottom:6px}
.foot-bot{width:var(--mx);margin:50px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;color:var(--ink3);font-size:13px;flex-wrap:wrap;gap:10px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}

/* ═══ WHATSAPP FLOTANTE ═══ */
.wa-float{position:fixed;bottom:24px;right:24px;width:60px;height:60px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 12px 40px rgba(37,211,102,.45);z-index:90;transition:transform .2s}
.wa-float:hover{transform:scale(1.1)}

/* ═══════════════════════════════════════════════════
   MOBILE COMPACT · ≤640px — densidad editorial para teléfono
═══════════════════════════════════════════════════ */
@media(max-width:640px){
  body{font-size:15px;line-height:1.55}
  :root{--mx:min(1280px,94vw)}
  .nav-inner{padding:10px 0;gap:10px}
  .btn-cot{padding:8px 14px;font-size:12px}
  .brand-img{height:44px;max-height:50px}

  /* HERO original (.hero) */
  .hero{min-height:auto;padding:36px 0 28px}
  .hero-title{font-size:clamp(36px,10vw,60px) !important;margin-bottom:14px}
  .hero-sub{font-size:14px;margin-bottom:20px}
  .hero-cta{margin-bottom:32px;gap:10px}
  .btn-primary,.btn-secondary{padding:10px 18px;font-size:13px}
  .btn-big{padding:12px 22px;font-size:14px}
  .hero-stats{padding-top:22px;gap:12px}
  .hero-scroll{display:none}

  /* PROMOS */
  .promos{margin:24px auto;padding:20px 0}
  .promos-head{margin-bottom:18px}
  .promos-kicker{font-size:9.5px;letter-spacing:.32em;margin-bottom:14px;padding:5px 14px}
  .promos-title{font-size:clamp(30px,8.5vw,48px) !important}
  .promos-sub{font-size:13px;margin-top:14px}
  .promos-grid{grid-template-columns:repeat(2,1fr) !important;gap:8px !important;margin-top:22px}
  .promo-card{min-height:230px !important;padding:18px 14px 14px !important;border-radius:12px}
  .promo-idx{font-size:9px;margin-bottom:16px;letter-spacing:.28em}
  .promo-day .d1{font-size:9.5px;margin-bottom:10px;letter-spacing:.32em}
  .promo-day .d2{font-size:14px !important;line-height:1.08}
  .promo-price{margin-top:18px}
  .promo-price .amount{font-size:clamp(36px,12vw,56px) !important}
  .promo-price .dollar{font-size:16px !important;margin-top:6px}
  .promo-price .unit{font-size:9px;margin-top:10px;letter-spacing:.2em}
  .promo-foot{font-size:10px;margin-top:14px;padding-top:10px;line-height:1.45}
  .promos-cta{margin-top:18px}
  .banner-btn{padding:11px 20px;font-size:12px;letter-spacing:.08em}

  /* SECCIONES */
  .sec{padding:36px 0}
  .sec-head{margin:0 auto 20px}
  .sec-kick{font-size:10.5px;letter-spacing:.24em;margin-bottom:10px}
  .sec-title{font-size:clamp(26px,8vw,40px) !important;margin-bottom:10px}
  .sec-lead{font-size:14px}

  /* SERVICIOS */
  .srv-grid{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
  .srv{min-height:130px !important;padding:16px 14px 14px !important;border-radius:12px}
  .srv h3{font-size:clamp(18px,5.5vw,26px) !important;margin:0 0 6px}
  .srv-sub{font-size:10px;padding-top:10px;line-height:1.4}
  .srv::before{top:12px;right:14px;font-size:10px}
  .prod-tags{gap:6px;margin-top:20px}
  .prod-tag{font-size:11px;padding:6px 12px}
  .prod-foot{margin:28px auto 0;padding:24px 16px}
  .prod-foot-txt{font-size:14px;margin-bottom:16px}

  /* GALERÍA */
  .gal-grid{grid-auto-rows:130px !important;gap:8px !important}
  .gal-cap{font-size:11px;bottom:10px;left:12px;right:12px}
  .gal-mas{margin:24px auto 0;gap:8px}
  .btn-ghost{padding:9px 16px;font-size:12px}

  /* NOSOTROS */
  .nos-wrap{gap:24px !important}
  .nos-p{font-size:14px;margin-bottom:12px;line-height:1.6}
  .nos-firma{font-size:15px;margin-top:18px}
  .nos-grid{gap:8px}
  .nos-card{padding:14px 12px}
  .nos-num{font-size:28px;margin-bottom:4px}
  .nos-lbl{font-size:10.5px;letter-spacing:.08em}

  /* POR QUÉ CID */
  .why{padding:16px 14px}
  .why-n{font-size:12px;margin-bottom:8px}
  .why h3{font-size:15px;margin-bottom:8px}
  .why p{font-size:13px;line-height:1.55}

  /* TESTIMONIOS eliminados 2026-04-27 */

  /* CTA FINAL */
  .cta-final{padding:36px 18px}
  .cta-final h2{font-size:clamp(26px,8vw,40px) !important;margin-bottom:10px}
  .cta-final p{font-size:14px;margin-bottom:22px}
  .cta-btns{gap:10px}

  /* FOOTER */
  .foot{padding:28px 18px 20px}
  .foot-grid{gap:22px}
  .foot-col h4{font-size:11px;margin-bottom:10px;letter-spacing:.14em}
  .foot-desc{font-size:13px;line-height:1.55}
  .foot-link{font-size:13px;padding:4px 0}
  .foot-p{font-size:13px}
  .foot-social a{font-size:11px;padding:5px 10px}
  .foot-bot{margin:28px auto 0;padding-top:16px;font-size:11px;flex-direction:column;align-items:flex-start;gap:6px}

  /* WHATSAPP FLOAT */
  .wa-float{width:52px;height:52px;font-size:22px;bottom:16px;right:16px}
}

/* ═══ SECCIONES que aún no tienen foto — placeholder ═══ */
.gal-item img[src^="fotos/"]:not([src*=".jpg"]):not([src*=".jpeg"]):not([src*=".png"]){display:none}
.gal-item:has(img:not([src])),.gal-item img:not([src]){background:linear-gradient(135deg,#1a1a20,#26262c)}
/* Placeholder visible cuando la foto falla */
.gal-item img{background:linear-gradient(135deg,#1a1a20 25%,#26262c 50%,#1a1a20 75%);background-size:400% 400%;animation:shimmer 3s ease-in-out infinite}
@keyframes shimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ═══ MOBILE OVERFLOW FIX 2026-04-25 ═══ */
*,*::before,*::after{box-sizing:border-box}
html,body{
  max-width:100vw !important;
  overflow-x:hidden !important;
}
img,video,iframe,svg{
  max-width:100%;
  height:auto;
}
h1,h2,h3,h4,h5,h6,p,span,a,div{
  word-wrap:break-word;
  overflow-wrap:break-word;
  max-width:100%;
}
.wrap,.container,main,section,article,aside{
  max-width:100%;
}
table{display:block;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}

@media(max-width:600px){
  body{padding-left:0 !important;padding-right:0 !important}
  .wrap,.container,main > section,main > div{
    padding-left:14px !important;
    padding-right:14px !important;
    max-width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
  }
  .btn,button,a.btn{
    max-width:100%;
    word-break:break-word;
    white-space:normal;
  }
  header,.nav,nav,.hdr,.header,.topbar{
    padding-left:12px !important;
    padding-right:12px !important;
  }
  footer,.foot,.ftr{
    padding-left:14px !important;
    padding-right:14px !important;
  }
  .gal-grid,.steps,.contact{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }
  .nos-wrap{
    grid-template-columns:1fr !important;
    gap:24px !important;
  }
  .nos-grid,.why-grid{
    grid-template-columns:repeat(2,1fr) !important;
    gap:10px !important;
  }
}

@media(max-width:380px){
  body{font-size:14.5px}
  h1{font-size:26px !important;line-height:1}
  h2{font-size:22px !important;line-height:1.05}
  h3{font-size:17px !important}
  .btn,button,a.btn{font-size:12px !important;padding:10px 12px !important}
  .nos-num{font-size:32px !important}
  .gal-cap{font-size:11px !important}
}

/* ═══ MOBILE FIXES ESPECÍFICOS 2026-04-25 ═══
   - Catálogo: grid 2 col en mobile (no carrusel · más visible)
   - Trust bar 3 col responsive
   - Section titles · word break
   - DTF/última card no queda sola */
@media(max-width:600px){
  .srv-grid{
    grid-auto-flow:row !important;
    grid-template-columns:repeat(2,1fr) !important;
    grid-auto-columns:auto !important;
    overflow-x:visible !important;
    scroll-snap-type:none !important;
    width:100% !important;
    padding:0 14px !important;
  }
  .srv-grid > .srv{
    scroll-snap-align:none !important;
    min-height:120px !important;
    padding:16px 14px !important;
  }
  .srv h3{font-size:16px !important;line-height:1.1 !important}
  .srv-sub{font-size:11px !important;line-height:1.3 !important}

  .tb2-grid{
    grid-template-columns:repeat(3,1fr) !important;
    gap:8px !important;
  }
  .tb2-card{padding:14px 8px !important}
  .tb2-card:nth-child(4){grid-column:1 / 3 !important}
  .tb2-card:nth-child(5){grid-column:3 / 4 !important}

  .sec-title{
    font-size:clamp(20px,7vw,32px) !important;
    line-height:1.05 !important;
    letter-spacing:-.5px !important;
    word-break:break-word !important;
    overflow-wrap:break-word !important;
  }
  .sec-kick{font-size:10px !important;letter-spacing:.2em !important}
  .sec-lead{font-size:13.5px !important;line-height:1.5 !important}


  .cta-final{padding:48px 18px !important}
  .cta-title{font-size:clamp(26px,7vw,40px) !important;line-height:1.05 !important}
}
@media(max-width:380px){
  .srv h3{font-size:14.5px !important}
  .srv-sub{font-size:10.5px !important}
  .tb2-name{font-size:13px !important}
  .tb2-desc{font-size:9px !important;letter-spacing:.1em !important}
}

/* ═══ FIXES TOPO 2026-04-25 NOCHE-2 ═══
   - Apagar hover verde brillante en touch devices (no se quede pintado al tap)
   - Compactar Así trabajamos en mobile
   - Compactar pw-video-banner en mobile */

/* Hover verde solo en dispositivos con cursor real (PC con mouse). En touch (cel/tablet)
   el :hover queda activado tras el tap = se ven verdes raras. */
@media (hover:none){
  .srv:hover{
    transform:none !important;
    border-color:rgba(255,255,255,.05) !important;
    box-shadow:none !important;
  }
  .srv:hover::before{color:var(--ink3) !important}
  .srv:hover h3{
    background:none !important;
    -webkit-text-fill-color:#fff !important;
    color:#fff !important;
  }
  .srv:hover::after{opacity:.35 !important}
  /* Active sí se ve para feedback al tap */
  .srv:active{
    transform:scale(.98) !important;
    background:linear-gradient(170deg,#1c1c24 0%,#10101a 100%) !important;
  }
}

/* Compactar "Así trabajamos" en mobile · cards más chicas */
@media(max-width:600px){
  .accion-carousel{margin:18px auto 24px !important;padding:0 14px !important}
  .ac-slide{flex:0 0 calc(72% - 7px) !important;aspect-ratio:4/3 !important;border-radius:8px !important}
  .ac-tag{font-size:9px !important;letter-spacing:.18em !important}
  .ac-h{font-size:13px !important}
  .ac-cap{padding:14px 12px 10px !important}
}

/* Compactar pw-video-banner en mobile · ya no tan invasivo */
@media(max-width:600px){
  .pw-video-banner{aspect-ratio:16/10 !important;margin-bottom:24px !important;border-radius:12px !important}
  .pw-vb-h{font-size:18px !important;line-height:1.05 !important;max-width:100% !important}
  .pw-vb-tag{font-size:10px !important;letter-spacing:.18em !important}
  .pw-vb-meta{font-size:9.5px !important;letter-spacing:.14em !important;flex-wrap:wrap !important;gap:6px !important}
  .pw-vb-content{padding:14px !important}
}
@media(max-width:400px){
  .pw-video-banner{aspect-ratio:4/3 !important}
  .pw-vb-h{font-size:16px !important}
}

/* ════════════════════════════════════════════════════════
   FIXES TOPO 2026-04-25 NOCHE-3 · servicios desplegables + footer compacto centrado
════════════════════════════════════════════════════════ */

/* SERVICIOS · ocultar extras hasta que se expanda */
.srv-grid .srv-extra{display:none}
.srv-grid.srv-expanded .srv-extra{
  display:flex;
  animation:srvFadeIn .35s ease-out;
}
@keyframes srvFadeIn{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}
.srv-toggle{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin:18px auto 0;padding:14px 28px;
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.22);
  border-radius:99px;cursor:pointer;
  font-family:'Oswald',sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  transition:all .2s;
}
.srv-toggle:hover{
  border-color:#c4ff00;color:#c4ff00;
  background:rgba(196,255,0,.06);
}
.srv-toggle .srv-toggle-ico{transition:transform .3s}
.srv-grid.srv-expanded + .srv-toggle .srv-toggle-ico{transform:rotate(180deg)}
@media(hover:none){
  .srv-toggle:hover{border-color:rgba(255,255,255,.22) !important;color:#fff !important;background:transparent !important}
  .srv-toggle:active{border-color:#c4ff00 !important;color:#c4ff00 !important}
}

/* FOOTER COMPACTO Y CENTRADO */
.foot-c{
  background:#0a0a0a;
  padding:60px 24px 28px;
  border-top:1px solid rgba(255,255,255,.08);
}
.foot-c-inner{
  max-width:540px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;
}
.foot-c-brand{
  display:flex;align-items:baseline;justify-content:center;gap:10px;
}
.foot-c-logo{
  font-family:'Archivo Black',sans-serif;
  font-size:38px;color:#c4ff00;
  letter-spacing:-1.5px;line-height:.9;
}
.foot-c-sub{
  font-family:'Oswald',sans-serif;
  font-size:13px;letter-spacing:.32em;
  color:#fff;text-transform:uppercase;font-weight:500;
}
.foot-c-desc{
  font-family:'Inter',sans-serif;
  font-size:13.5px;line-height:1.55;
  color:rgba(255,255,255,.62);
  margin:0;max-width:380px;
}
.foot-c-cta{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
}
.foot-c-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 20px;border-radius:99px;
  text-decoration:none;font-family:'Oswald',sans-serif;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  transition:all .2s;
}
.foot-c-btn-wa{
  background:#c4ff00;color:#0a0a0a;
}
.foot-c-btn-wa:hover{background:#fff;transform:translateY(-1px)}
.foot-c-btn-mail{
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.22);
}
.foot-c-btn-mail:hover{border-color:#c4ff00;color:#c4ff00}
.foot-c-meta{
  display:flex;flex-direction:column;gap:10px;
  width:100%;max-width:460px;
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.foot-c-meta-row{
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.foot-c-tag{
  font-family:'Oswald',sans-serif;font-size:10px;letter-spacing:.28em;
  color:#c4ff00;font-weight:700;
}
.foot-c-val{
  font-family:'Inter',sans-serif;font-size:12.5px;
  color:rgba(255,255,255,.78);line-height:1.4;
}
.foot-c-social{
  display:flex;align-items:center;justify-content:center;gap:8px;
  flex-wrap:wrap;
  font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
}
.foot-c-social a{
  color:rgba(255,255,255,.7);text-decoration:none;
  transition:color .2s;
}
.foot-c-social a:hover{color:#c4ff00}
.foot-c-dot{color:rgba(255,255,255,.25)}
@media(max-width:400px){
  .foot-c{padding:48px 18px 22px}
  .foot-c-logo{font-size:32px}
  .foot-c-sub{font-size:11px;letter-spacing:.24em}
  .foot-c-desc{font-size:12.5px}
  .foot-c-meta{padding:14px 0}
  .foot-c-val{font-size:12px}
}
@media(hover:none){
  .foot-c-btn-wa:hover{background:#c4ff00 !important;transform:none !important}
  .foot-c-btn-mail:hover{border-color:rgba(255,255,255,.22) !important;color:#fff !important}
  .foot-c-social a:hover{color:rgba(255,255,255,.7) !important}
  .foot-c-btn-wa:active{background:#fff !important;transform:scale(.97) !important}
  .foot-c-btn-mail:active{border-color:#c4ff00 !important;color:#c4ff00 !important}
}

/* ═══════════════════════════════════════════════════════════════════════
   v217 · NAVEGACIÓN HORIZONTAL ESTILO iPhone (Topo: scroll horizontal panels)
   Hero (90vh) queda VERTICAL · 5 panels horizontales 100vw cada uno
   Reduce scroll vertical de 768vh → ~200vh (74% menos)
   ═══════════════════════════════════════════════════════════════════════ */

/* Container de panels horizontales */
.hpanels{
  position:relative;
  display:flex;
  width:100vw;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  /* Hint visual de "arrastrable" */
  cursor:grab;
  /* Altura fija · cada panel ocupa exactamente la ventana */
  height:100vh;
  /* Permite swipe horizontal libre · evita conflicto con scroll vertical de la página */
  overscroll-behavior-x:contain;
  /* Background base para evitar flash blanco entre paneles */
  background:#0a0a0a;
}
.hpanels:active{cursor:grabbing}
.hpanels::-webkit-scrollbar{display:none}

/* Cada panel · ancho exacto = viewport · scroll vertical interno si rebasa */
.hpanel{
  flex:0 0 100vw;
  width:100vw;
  height:100vh;
  scroll-snap-align:start;
  scroll-snap-stop:always;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  position:relative;
  /* block layout · permite que cada section interna fluya con su padding nativo */
  display:block;
}
/* Hide scrollbar del scroll vertical interno · estilo iOS */
.hpanel::-webkit-scrollbar{width:6px}
.hpanel::-webkit-scrollbar-thumb{background:rgba(196,255,0,.25);border-radius:99px}
.hpanel::-webkit-scrollbar-track{background:transparent}

/* Anular animación opacity:0 / transform de .sec.in (que tarda en activarse y dejaría invisible) */
.hpanel > section,
.hpanel > section.sec,
.hpanel > .hpanel-wrap{
  width:100%;
  opacity:1 !important;
  transform:none !important;
  /* fuerza que la section sea visible inmediatamente · sin esperar IntersectionObserver */
}

/* ═══ DOTS NAVEGACIÓN · indicador panel activo (Apple-style) ═══ */
.hpanels-dots{
  position:fixed;
  z-index:95;
  display:flex;
  gap:10px;
  /* Mobile: dots horizontales abajo centrados (sticky bar style) */
  bottom:18px;
  left:50%;
  transform:translateX(-50%);
  padding:10px 18px;
  background:rgba(10,10,10,.78);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(196,255,0,.18);
  border-radius:99px;
  box-shadow:0 8px 28px rgba(0,0,0,.5);
  pointer-events:auto;
  /* Solo visible cuando estás dentro del rango de paneles (JS lo toggle) */
  opacity:0;
  transition:opacity .25s, transform .25s;
}
.hpanels-dots.show{opacity:1}

.hpanels-dot{
  width:9px;height:9px;border-radius:50%;
  background:#3a3a3e;border:none;cursor:pointer;
  transition:all .2s;padding:0;
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.hpanels-dot:hover{background:#a8a196;transform:scale(1.18)}
.hpanels-dot.active{
  background:#c4ff00;
  width:28px;border-radius:99px;
  box-shadow:0 0 12px rgba(196,255,0,.55);
}
/* Tooltip · accesibilidad · sólo desktop (hover) */
.hpanels-dot::after{
  content:attr(aria-label);
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(4px);
  background:#161618;color:#c4ff00;
  font-family:'Oswald',sans-serif;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:700;
  padding:5px 10px;border-radius:6px;
  white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .15s, transform .15s;
  border:1px solid rgba(196,255,0,.2);
}
.hpanels-dot:hover::after,
.hpanels-dot:focus-visible::after{
  opacity:1;transform:translateX(-50%) translateY(0);
}

/* ═══ FLECHAS LATERALES · sólo desktop ═══ */
.hpanels-arrow{
  position:fixed;top:50%;
  transform:translateY(-50%);
  z-index:94;
  width:48px;height:48px;border-radius:50%;
  background:rgba(10,10,10,.82);color:#c4ff00;
  border:2px solid rgba(196,255,0,.4);
  cursor:pointer;
  display:none; /* JS muestra cuando paneles visibles */
  align-items:center;justify-content:center;
  font-size:22px;font-family:'Archivo Black',sans-serif;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 8px 24px rgba(0,0,0,.5);
  transition:all .2s;
  opacity:0;
}
.hpanels-arrow.show{display:flex;opacity:1}
.hpanels-arrow:hover{background:#c4ff00;color:#0a0a0a;border-color:#c4ff00;transform:translateY(-50%) scale(1.08)}
.hpanels-arrow:disabled{opacity:.25;cursor:not-allowed;pointer-events:none}
.hpanels-arrow-l{left:18px}
.hpanels-arrow-r{right:18px}

/* Mobile: ocultar flechas · sólo dots + swipe táctil */
@media(max-width:1024px){
  .hpanels-arrow{display:none !important}
}

/* ═══ HINT inicial "Desliza →" · primer panel de paquetes (sólo 1 vez) ═══ */
.hpanels-swipe-hint{
  position:absolute;
  bottom:80px;right:24px;
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(90deg,#c4ff00,#a3d600);
  color:#0a0a0a;
  font-family:'Oswald',sans-serif;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;font-weight:800;
  padding:9px 16px;border-radius:99px;
  box-shadow:0 6px 20px rgba(196,255,0,.4);
  z-index:6;
  pointer-events:none;
  animation:hpanelsHint 2.4s ease-in-out infinite;
}
@keyframes hpanelsHint{
  0%,100%{transform:translateX(0); opacity:.95}
  50%{transform:translateX(8px); opacity:1}
}
@media(max-width:520px){
  .hpanels-swipe-hint{bottom:80px; right:14px; font-size:10px; padding:7px 12px}
}

/* ═══ KEEP HEIGHT · ajustar paneles para tablet/mobile ═══ */
@media(max-width:780px){
  .hpanels{height:calc(100vh - 0px)}
  .hpanel{height:calc(100vh - 0px)}
  .hpanels-dots{bottom:14px;padding:8px 14px;gap:8px}
  .hpanels-dot{width:8px;height:8px}
  .hpanels-dot.active{width:24px}
  /* En mobile NO mostrar tooltips · ocupan mucho */
  .hpanels-dot::after{display:none}
}
@media(max-width:480px){
  .hpanels-dots{bottom:10px}
}

/* ═══ Reducir motion · accessibility ═══ */
@media (prefers-reduced-motion: reduce){
  .hpanels{scroll-behavior:auto}
  .hpanels-swipe-hint{animation:none}
}

/* ═══ Hard-block para que padding/margin de body no rompa el 100vw ═══ */
.hpanels-section{
  width:100vw;
  position:relative;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
}

