/* ═══════════════════════════════════════════════
   CID IMPRESIONES · Sitio web
   Paleta: negro profundo + naranja CID
═══════════════════════════════════════════════ */

:root{
  --bg:#0b0b0d;
  --bg2:#121216;
  --bg3:#1a1a20;
  --ink:#f5f5f7;
  --ink2:#b8b8c0;
  --ink3:#74747c;
  --line:#26262c;
  --orange:#c4ff00;
  --orange-d:#9fcc00;
  --orange-l:#dcff5c;
  --fire:#ff4d4d;
  --gold:#f9ca74;
  --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:44px;width:auto;display:block}
@media(max-width:700px){.brand-img{height:36px}}
.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(--orange)}
.btn-cot{background:var(--orange);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(--orange-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:80px 0 60px;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(--orange);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(--orange);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(--orange);color:#0b0b0d;padding:16px 30px;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(--orange-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(--orange);background:rgba(196,255,0,.08)}
.btn-big{padding:18px 38px;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(--orange);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:120px auto;opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s}
.promos.in{opacity:1;transform:none}
.promos-head{text-align:center;margin-bottom:56px;max-width:720px;margin-left:auto;margin-right:auto}
.promos-kicker{display:inline-block;font-size:10.5px;font-weight:600;color:var(--orange);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(--orange) 0%,var(--orange-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(--orange);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(--orange);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(--orange) 0%,var(--orange-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:52px}
.banner-btn{display:inline-block;background:var(--orange);color:#0b0b0d;padding:20px 40px;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(--orange-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:110px 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 60px;max-width:860px}
.sec-kick{font-size:12px;color:var(--orange);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 ═══ */
.srv-grid{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.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:32px 24px 28px;min-height:220px;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(--orange)}
.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(--orange-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(--orange);color:#fff}
.prod-tag.is-active{background:var(--orange);color:#0b0b0d;border-color:var(--orange);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(--orange)}
@media(max-width:1200px){.srv-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.srv-grid{grid-template-columns:repeat(2,1fr);gap:10px}.srv{min-height:180px;padding:22px 18px}}

/* ═══ 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(--orange-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(--orange);color:var(--orange)}
@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:60px;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(--orange);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:28px 22px;transition:transform .2s,border-color .2s}
.nos-card:hover{transform:translateY(-3px);border-color:var(--orange)}
.nos-card-acc{background:linear-gradient(135deg,var(--orange),var(--orange-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(--orange);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:34px 28px;position:relative;transition:border-color .25s}
.why:hover{border-color:var(--orange)}
.why-n{font-family:var(--f-display);font-size:14px;color:var(--orange);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 ═══ */
.test-grid{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.test{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px}
.test-stars{color:var(--gold);font-size:18px;letter-spacing:.12em;margin-bottom:14px}
.test-quote{font-size:16px;line-height:1.7;color:var(--ink);margin-bottom:16px;font-style:italic}
.test-autor{font-size:13px;color:var(--ink3);font-weight:600}
.test-cta{width:var(--mx);margin:40px auto 0;display:flex;justify-content:center}
@media(max-width:900px){.test-grid{grid-template-columns:1fr}}

/* ═══ CTA FINAL ═══ */
.cta-final{padding:100px 0;text-align:center;background:linear-gradient(135deg,var(--orange) 0%,var(--orange-d) 100%);color:#0b0b0d;opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;position:relative;overflow:hidden}
.cta-final.in{opacity:1;transform:none}
.cta-final::before{content:'';position:absolute;inset:0;background-image:
  linear-gradient(rgba(0,0,0,.06) 1px,transparent 1px),
  linear-gradient(90deg,rgba(0,0,0,.06) 1px,transparent 1px);
  background-size:48px 48px}
.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}
.cta-final p{font-size:18px;margin-bottom:34px;font-weight:600}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-final .btn-primary{background:#0b0b0d;color:var(--orange);box-shadow:none}
.cta-final .btn-primary:hover{background:#1a1a20}
.cta-final .btn-secondary{border-color:#0b0b0d;color:#0b0b0d}
.cta-final .btn-secondary:hover{background:rgba(0,0,0,.08);border-color:#0b0b0d}

/* ═══ FOOTER ═══ */
.foot{background:#050506;padding:80px 0 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(--orange);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(--orange);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(--orange);border-color:var(--orange)}
.foot-link{display:block;color:var(--ink2);font-size:14px;padding:6px 0;transition:color .15s}
.foot-link:hover{color:var(--orange)}
.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)}

/* ═══ 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%}}
