/* ═══════════════════════════════════════════════
   DAMER PRODUCCIONES — STYLES
   Tipografía: Barlow Condensed + DM Mono + Barlow
   Estética: Industrial · Técnico · Cuadrado
   ═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,300;0,400;0,600;0,700;0,800;0,900;1,700&family=Barlow:wght@300;400;500;600&family=DM+Mono:wght@300;400;500&display=swap');

:root {
  --orange:  #FF5200;
  --magenta: #D6005F;
  --deep:    #080808;
  --surface: #0f0f0f;
  --card:    #111111;
  --border:  rgba(255,82,0,.14);
  --white:   #F8F6F0;
  --muted:   rgba(248,246,240,.42);
  --mono:    'DM Mono', monospace;
  --display: 'Barlow Condensed', sans-serif;
  --body:    'Barlow', sans-serif;
  --grad:    linear-gradient(90deg, var(--orange) 0%, var(--magenta) 100%);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--deep); color:var(--white); font-family:var(--body); font-weight:400; overflow-x:hidden; }

::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--deep); }
::-webkit-scrollbar-thumb { background:var(--orange); }
::selection { background:var(--orange); color:#000; }

/* ══════════════════════════════
   NAVBAR
══════════════════════════════ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 5%; height:68px;
  background:rgba(8,8,8,.8);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:height .4s, background .4s;
}
.navbar.scrolled { height:56px; background:rgba(8,8,8,.97); border-bottom-color:rgba(255,82,0,.28); }

.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo-mark {
  width:34px; height:34px; background:var(--grad);
  clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:900; font-size:.9rem; color:#fff;
}
.logo-text {
  font-family:var(--display); font-weight:900;
  font-size:1.35rem; letter-spacing:.1em; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.logo-text span { -webkit-text-fill-color:rgba(248,246,240,.4); font-weight:300; }

.nav-links { display:flex; align-items:center; gap:32px; list-style:none; }
.nav-links a {
  font-family:var(--mono); font-size:.67rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted); text-decoration:none;
  transition:color .25s; position:relative; padding-bottom:2px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:100%; height:1px; background:var(--orange);
  transform:scaleX(0); transform-origin:left; transition:transform .25s;
}
.nav-links a:hover { color:var(--white); }
.nav-links a:hover::after { transform:scaleX(1); }

.nav-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 22px; border:1px solid var(--orange); color:var(--orange);
  font-family:var(--mono); font-size:.68rem;
  font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  text-decoration:none; position:relative; overflow:hidden; transition:color .3s;
}
.nav-btn::before {
  content:''; position:absolute; inset:0;
  background:var(--orange); transform:translateX(-101%); transition:transform .3s ease;
}
.nav-btn:hover { color:#000; }
.nav-btn:hover::before { transform:translateX(0); }
.nav-btn i, .nav-btn span { position:relative; z-index:1; }

.hamburger { display:none; flex-direction:column; gap:6px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:24px; height:1.5px; background:var(--white); transition:all .3s; }

.mobile-menu {
  display:none; position:fixed; inset:0; z-index:999;
  background:#080808;
  flex-direction:column; align-items:flex-start;
  justify-content:center; gap:28px; padding:0 8%;
  border-left:3px solid var(--orange);
}
.mobile-menu.open { display:flex; }
.mobile-menu a.mob-link {
  font-family:var(--display); font-size:3.2rem;
  font-weight:900; letter-spacing:.04em; text-transform:uppercase;
  color:var(--white); text-decoration:none; line-height:1; transition:color .2s;
}
.mobile-menu a.mob-link:hover { color:var(--orange); }
.mobile-close { position:absolute; top:24px; right:28px; background:none; border:none; color:var(--muted); font-size:1.4rem; cursor:pointer; }

/* ══════════════════════════════
   HERO — foto de fondo fullscreen
══════════════════════════════ */
.hero {
  position:relative; min-height:100vh;
  display:flex; flex-direction:column;
  justify-content:flex-end; overflow:hidden;
}

/* Imagen de fondo con zoom suave */
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center top;
  transform:scale(1.05);
  animation:heroBgZoom 18s ease-in-out infinite alternate;
}
@keyframes heroBgZoom { from{transform:scale(1.05)} to{transform:scale(1.0)} }

/* Overlay en capas: oscurecimiento lateral + gradiente inferior */
.hero-overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(8,8,8,.85) 35%, rgba(8,8,8,.15) 75%, rgba(8,8,8,.5) 100%),
    linear-gradient(to top, rgba(8,8,8,.98) 0%, rgba(8,8,8,.5) 30%, transparent 60%);
}

.orb { position:absolute; border-radius:50%; filter:blur(110px); pointer-events:none; z-index:1; }
.orb-1 { width:600px; height:600px; top:-20%; right:-10%; background:radial-gradient(circle,rgba(255,82,0,.16) 0%,transparent 65%); }
.orb-2 { width:400px; height:400px; bottom:-8%; left:-5%; background:radial-gradient(circle,rgba(214,0,95,.12) 0%,transparent 65%); }

.ring { position:absolute; pointer-events:none; border:1px solid rgba(255,82,0,.07); animation:ringPulse 8s ease-in-out infinite; z-index:1; }
.ring-1 { width:500px; height:500px; top:5%; right:2%; clip-path:polygon(0 0,100% 0,100% 85%,85% 100%,0 100%); }
.ring-2 { width:700px; height:700px; top:-10%; right:-6%; border-color:rgba(214,0,95,.04); clip-path:polygon(0 0,100% 0,100% 90%,90% 100%,0 100%); animation-delay:2s; }
@keyframes ringPulse { 0%,100%{opacity:.4} 50%{opacity:1} }

.hero-inner {
  position:relative; z-index:2;
  padding:140px 5% 72px;
}
/* Línea vertical de acento izquierda */
.hero-inner::before {
  content:'';
  position:absolute; left:0; top:-80px; bottom:0;
  width:1px;
  background:linear-gradient(to bottom,transparent,rgba(255,82,0,.22) 30%,rgba(255,82,0,.22) 70%,transparent);
}

.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:.63rem;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--orange); margin-bottom:22px; width:fit-content;
  padding-bottom:6px; border-bottom:1px solid rgba(255,82,0,.3);
}
.hero-badge i { animation:spin 5s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

.hero-title {
  font-family:var(--display); font-weight:900;
  font-size:clamp(3.8rem,10vw,4.5rem);
  line-height:.9; letter-spacing:.01em;
  text-transform:uppercase; margin-bottom:32px;
}
.line-white { display:block; color:var(--white); text-shadow:0 2px 40px rgba(0,0,0,.6); }
.line-grad  { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; display:block; }
.line-stroke { display:block; -webkit-text-stroke:1.5px rgba(251, 251, 251, 0.635); -webkit-text-fill-color:transparent; }

.hero-sub {
  max-width:480px; font-size:1rem; line-height:1.76;
  color:rgba(248,246,240,.72); font-weight:300; margin-bottom:40px;
  padding-left:18px; border-left:2px solid var(--orange);
}
.hero-actions { display:flex; flex-wrap:wrap; align-items:center; gap:12px; margin-bottom:60px; }

/* Estadísticas */
.hero-stats { display:flex; flex-wrap:wrap; gap:0; border-top:1px solid rgba(255,82,0,.2); }
.hstat {
  display:flex; flex-direction:column; gap:4px;
  padding:22px 44px 0 0; margin-right:44px;
  border-right:1px solid rgba(255,82,0,.14);
}
.hstat:last-child { border-right:none; }
.hstat-num {
  font-family:var(--display); font-weight:900;
  font-size:2.4rem; letter-spacing:.02em; line-height:1;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.hstat-label { font-family:var(--mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(248,246,240,.45); }

/* Scroll hint */
.hero-scroll {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  z-index:2; color:rgba(248,246,240,.3); font-size:.8rem;
  animation:bounce 2s ease-in-out infinite;
}
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* Botones globales */
.btn-grad {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px; background:var(--grad); color:#fff;
  font-family:var(--mono); font-size:.7rem;
  font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  text-decoration:none; position:relative; overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% 65%,96% 100%,0 100%);
  transition:filter .3s;
}
.btn-grad::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg,var(--magenta),var(--orange));
  opacity:0; transition:opacity .3s;
}
.btn-grad:hover { filter:brightness(1.1); }
.btn-grad:hover::before { opacity:1; }
.btn-grad span, .btn-grad i { position:relative; z-index:1; }

.btn-outline {
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 28px;
  border:1px solid rgba(248,246,240,.25); color:var(--white);
  font-family:var(--mono); font-size:.7rem;
  font-weight:400; letter-spacing:.12em; text-transform:uppercase;
  text-decoration:none; transition:border-color .3s,color .3s;
  background:rgba(8,8,8,.35); backdrop-filter:blur(8px);
}
.btn-outline:hover { border-color:var(--orange); color:var(--orange); }

/* ══════════════════════════════
   MARQUEE
══════════════════════════════ */
.marquee-wrap {
  overflow:hidden; background:var(--surface);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:14px 0;
}
.marquee-track { display:flex; width:max-content; animation:marquee 26s linear infinite; }
@keyframes marquee { to{transform:translateX(-50%)} }
.marquee-item {
  display:inline-flex; align-items:center; gap:12px;
  padding:0 32px; white-space:nowrap;
  font-family:var(--mono); font-size:.66rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
}
.marquee-item i { color:var(--orange); font-size:.5rem; }

/* ══════════════════════════════
   BASE SECCIONES
══════════════════════════════ */
section { padding:96px 5%; position:relative; }

.section-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--mono); font-size:.63rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--orange); margin-bottom:18px;
}
.section-eyebrow::before { content:''; width:22px; height:1px; background:var(--orange); display:block; }

.section-title {
  font-family:var(--display); font-weight:900;
  font-size:clamp(2.4rem,5vw,4.2rem);
  line-height:.95; letter-spacing:.02em; text-transform:uppercase; margin-bottom:18px;
}
.grad { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }

/* ══════════════════════════════
   SERVICIOS — cards con foto
══════════════════════════════ */
.services-header { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:end; margin-bottom:48px; }
.services-lead { font-size:.95rem; color:var(--muted); line-height:1.8; font-weight:300; }

.services-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border); border:1px solid var(--border);
}
.svc-card {
  background:var(--card); position:relative;
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .35s ease;
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0;
  width:100%; height:2px; background:var(--grad);
  transform:scaleX(0); transform-origin:left; transition:transform .4s ease;
  z-index:3;
}
.svc-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.4); }
.svc-card:hover::before { transform:scaleX(1); }

/* Foto superior de cada card */
.svc-img {
  height:170px; width:100%;
  background-size:cover; background-position:center;
  position:relative; overflow:hidden; flex-shrink:0;
  transition:transform .55s ease;
}
.svc-img::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to bottom,transparent 30%,var(--card) 100%);
}
.svc-card:hover .svc-img { transform:scale(1.06); }

.svc-body { padding:24px 28px 32px; flex:1; position:relative; z-index:2; }
.svc-card::after {
  content:attr(data-num);
  position:absolute; bottom:-14px; right:14px;
  font-family:var(--display); font-weight:900;
  font-size:5.5rem; line-height:1;
  color:rgba(255,82,0,.05); pointer-events:none; user-select:none; z-index:1;
}
.svc-icon-wrap {
  width:44px; height:44px;
  background:rgba(255,82,0,.08); border:1px solid rgba(255,82,0,.22);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px; font-size:1rem; color:var(--orange);
  transition:background .3s,color .3s,border-color .3s;
}
.svc-card:hover .svc-icon-wrap { background:var(--orange); color:#000; border-color:var(--orange); }
.svc-name { font-family:var(--display); font-weight:700; font-size:1.45rem; letter-spacing:.04em; text-transform:uppercase; margin-bottom:8px; line-height:1; }
.svc-desc { font-size:.84rem; color:var(--muted); line-height:1.7; font-weight:300; }

/* ══════════════════════════════
   D&B — con foto de consola
══════════════════════════════ */
.db-section {
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:0; margin:0 5%;
  border:1px solid var(--border); background:var(--card); position:relative;
}
.db-section::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad); z-index:2; }

.db-left { padding:72px 56px; display:flex; flex-direction:column; justify-content:center; border-right:1px solid var(--border); }
.db-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:.6rem;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--orange); margin-bottom:22px; width:fit-content;
}
.db-title { font-family:var(--display); font-weight:900; font-size:clamp(2rem,3.5vw,3rem); text-transform:uppercase; letter-spacing:.02em; line-height:.95; margin-bottom:18px; }
.db-text { color:var(--muted); font-size:.9rem; line-height:1.8; font-weight:300; margin-bottom:36px; }

.db-specs { display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--border); }
.db-spec { padding:18px 20px; border-right:1px solid var(--border); border-bottom:1px solid var(--border); }
.db-spec:nth-child(2n) { border-right:none; }
.db-spec:nth-child(n+3) { border-bottom:none; }
.db-spec-val { font-family:var(--display); font-weight:900; font-size:1.6rem; letter-spacing:.03em; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.db-spec-label { font-family:var(--mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:5px; }

.db-right { position:relative; overflow:hidden; min-height:380px; display:flex; align-items:center; justify-content:center; }

.db-photo {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform .8s ease;
}
.db-section:hover .db-photo { transform:scale(1.04); }

.db-photo-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(255,82,0,.4) 0%, rgba(8,8,8,.65) 100%);
}
.db-grid-lines {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,82,0,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,82,0,.06) 1px,transparent 1px);
  background-size:40px 40px;
  z-index:1;
}
.waveform { display:flex; align-items:center; gap:3px; position:relative; z-index:2; }
.wf-bar { width:3px; background:linear-gradient(180deg,var(--orange),var(--magenta)); animation:wfAnim 1s ease-in-out infinite alternate; opacity:.85; }
@keyframes wfAnim { from{transform:scaleY(.1)} to{transform:scaleY(1)} }

/* ══════════════════════════════
   BRANDS
══════════════════════════════ */
.brands-grid {
  display:grid; grid-template-columns:repeat(6,1fr);
  gap:0; margin-top:44px;
  border:1px solid var(--border); background:var(--border);
}
.brand-pill {
  background:var(--card); padding:22px 12px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:.64rem;
  font-weight:400; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); transition:all .25s; text-align:center;
}
.brand-pill:hover { color:var(--white); background:#181818; box-shadow:inset 0 2px 0 var(--orange); }

/* ══════════════════════════════
   COBERTURA — foto ciudad fondo
══════════════════════════════ */
.cobertura-section { position:relative; padding:100px 5%; overflow:hidden; }

.cob-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.03);
}
.cob-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(8,8,8,.93) 0%, rgba(8,8,8,.75) 55%, rgba(8,8,8,.9) 100%);
}
.cob-inner { position:relative; z-index:1; }
.cob-lead { max-width:560px; font-size:.96rem; color:var(--muted); line-height:1.8; font-weight:300; margin-bottom:44px; }

.cob-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:rgba(255,82,0,.12); border:1px solid rgba(255,82,0,.18);
}
.cob-item {
  background:rgba(10,10,10,.75); backdrop-filter:blur(10px);
  padding:28px 22px; position:relative; transition:background .3s;
}
.cob-item::before {
  content:''; position:absolute; top:0; left:0;
  width:0; height:2px; background:var(--grad); transition:width .4s ease;
}
.cob-item:hover { background:rgba(255,82,0,.08); }
.cob-item:hover::before { width:100%; }
.cob-more { border:1px dashed rgba(255,82,0,.25); background:transparent !important; }
.cob-icon { font-size:1.1rem; color:var(--orange); margin-bottom:12px; display:block; }
.cob-name { font-family:var(--display); font-weight:700; font-size:1.3rem; letter-spacing:.04em; text-transform:uppercase; margin-bottom:4px; line-height:1; }
.cob-desc { font-family:var(--mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

/* ══════════════════════════════
   PROCESO
══════════════════════════════ */
.process-wrap {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; background:var(--border); border:1px solid var(--border); margin-top:56px;
}
.process-step { background:var(--card); padding:44px 30px; position:relative; overflow:hidden; }
.process-step::before {
  content:''; position:absolute; top:0; left:0;
  width:0; height:2px; background:var(--grad); transition:width .5s ease;
}
.process-step:hover::before { width:100%; }
.process-step::after { content:''; position:absolute; top:0; right:0; width:1px; height:100%; background:var(--border); }
.process-step:last-child::after { display:none; }
.process-num { font-family:var(--display); font-weight:900; font-size:4rem; line-height:1; letter-spacing:.02em; color:rgba(255,82,0,.08); margin-bottom:20px; display:block; }
.process-icon { width:38px; height:38px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--orange); font-size:.85rem; margin-bottom:18px; transition:all .3s; }
.process-step:hover .process-icon { background:var(--orange); color:#000; border-color:var(--orange); }
.process-title { font-family:var(--display); font-weight:700; font-size:1.2rem; letter-spacing:.04em; text-transform:uppercase; margin-bottom:10px; line-height:1; }
.process-desc { font-size:.82rem; color:var(--muted); line-height:1.7; font-weight:300; }

/* ══════════════════════════════
   GALERÍA — grid asimétrica
══════════════════════════════ */
.gallery-section { padding:96px 5%; }

.gallery-grid {
  display:grid;
  grid-template-columns:1.8fr 1fr;
  grid-template-rows:220px 220px;
  gap:2px; margin-top:44px;
}
.gal-item {
  position:relative; overflow:hidden;
  background-size:cover; background-position:center;
  cursor:default;
  transition:background-size .55s ease;
}
.gal-item:hover { background-size:110%; }
.gal-item::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(8,8,8,.7) 0%,transparent 50%);
  transition:opacity .4s;
}
.gal-item:hover::after { opacity:.5; }
.gal-tall { grid-row:1/3; }
.gal-wide { grid-column:1/3; }

.gal-label {
  position:absolute; bottom:14px; left:14px; z-index:1;
  font-family:var(--mono); font-size:.6rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:rgba(248,246,240,.8);
  padding:5px 10px; background:rgba(8,8,8,.55);
  border-left:2px solid var(--orange);
  backdrop-filter:blur(4px);
}

/* ══════════════════════════════
   TESTIMONIOS
══════════════════════════════ */
.testimonials-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border); border:1px solid var(--border); margin-top:44px;
}
.testi-card { background:var(--card); padding:36px 28px; transition:background .3s; }
.testi-card:hover { background:#141414; }
.testi-stars { display:flex; gap:4px; color:var(--orange); font-size:.7rem; margin-bottom:16px; }
.testi-text { font-size:.88rem; line-height:1.75; color:rgba(248,246,240,.62); margin-bottom:24px; font-style:italic; font-weight:300; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:38px; height:38px; background:var(--grad); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:800; font-size:.85rem; color:#fff;
  clip-path:polygon(0 0,100% 0,100% 75%,75% 100%,0 100%);
}
.testi-name { font-family:var(--display); font-weight:700; font-size:.95rem; text-transform:uppercase; letter-spacing:.04em; }
.testi-role { font-family:var(--mono); font-size:.6rem; color:var(--muted); letter-spacing:.08em; margin-top:2px; }

/* ══════════════════════════════
   CTA BAND — foto de fondo
══════════════════════════════ */
.cta-band {
  margin:0 5%; position:relative;
  border:1px solid var(--border);
  padding:88px 7%;
  display:flex; align-items:center; justify-content:space-between;
  gap:40px; overflow:hidden;
}
.cta-photo {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform .8s ease;
}
.cta-band:hover .cta-photo { transform:scale(1.03); }
.cta-photo-overlay {
  position:absolute; inset:0;
  background:linear-gradient(110deg,rgba(8,8,8,.93) 0%,rgba(255,82,0,.22) 50%,rgba(8,8,8,.88) 100%);
}
.cta-band::after {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:4px; background:var(--grad); z-index:2;
}
.cta-content { position:relative; z-index:2; }
.cta-title { font-family:var(--display); font-weight:900; font-size:clamp(2.5rem,5vw,4rem); text-transform:uppercase; letter-spacing:.02em; line-height:.95; color:var(--white); }
.cta-sub { font-family:var(--mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(248,246,240,.55); margin-top:14px; }
.cta-actions { display:flex; flex-direction:column; gap:12px; align-items:flex-start; position:relative; z-index:2; flex-shrink:0; }

.btn-white {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 30px; background:var(--white); color:#000;
  font-family:var(--mono); font-size:.7rem;
  font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  text-decoration:none; white-space:nowrap;
  clip-path:polygon(0 0,100% 0,100% 65%,96% 100%,0 100%);
  transition:background .3s,color .3s;
}
.btn-white:hover { background:var(--orange); color:#fff; }
.btn-white-ghost {
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 26px; border:1px solid rgba(248,246,240,.22);
  color:var(--muted);
  font-family:var(--mono); font-size:.68rem;
  letter-spacing:.12em; text-transform:uppercase;
  text-decoration:none; white-space:nowrap; transition:border-color .3s,color .3s;
}
.btn-white-ghost:hover { border-color:var(--white); color:var(--white); }

/* ══════════════════════════════
   CONTACTO
══════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:80px; align-items:start; }
.contact-info-item { display:flex; align-items:flex-start; gap:14px; margin-bottom:28px; }
.contact-icon { width:40px; height:40px; flex-shrink:0; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--orange); font-size:.85rem; transition:all .3s; }
.contact-info-item:hover .contact-icon { background:var(--orange); color:#000; border-color:var(--orange); }
.contact-info-label { font-family:var(--mono); font-size:.6rem; letter-spacing:.15em; text-transform:uppercase; color:var(--orange); margin-bottom:5px; }
.contact-info-val { font-size:.9rem; color:var(--white); line-height:1.6; text-decoration:none; display:block; transition:color .3s; }
a.contact-info-val:hover { color:var(--orange); }

.socials { display:flex; gap:8px; margin-top:36px; }
.social-btn { width:40px; height:40px; border:1px solid var(--border); background:transparent; color:var(--muted); display:flex; align-items:center; justify-content:center; font-size:.85rem; text-decoration:none; transition:all .25s; }
.social-btn:hover { border-color:var(--orange); color:var(--orange); background:rgba(255,82,0,.08); }

.form-card { background:var(--card); border:1px solid var(--border); border-top:3px solid var(--orange); padding:44px 36px; }
.form-title { font-family:var(--display); font-weight:800; font-size:1.6rem; letter-spacing:.04em; text-transform:uppercase; margin-bottom:28px; line-height:1; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-field { display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-field label { font-family:var(--mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.form-field input,
.form-field select,
.form-field textarea {
  background:rgba(255,255,255,.025); border:none;
  border-bottom:1px solid rgba(255,82,0,.22);
  color:var(--white); font-family:var(--body);
  font-size:.9rem; font-weight:300; padding:12px 14px;
  outline:none; transition:border-color .3s,background .3s;
  -webkit-appearance:none; appearance:none;
}
.form-field textarea { resize:vertical; min-height:100px; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus { border-color:var(--orange); background:rgba(255,82,0,.04); }
.form-field input::placeholder,
.form-field textarea::placeholder { color:rgba(248,246,240,.18); font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; }
.form-field select option { background:#111; }
.form-submit {
  width:100%; padding:15px; border:none; background:var(--grad); color:#fff;
  font-family:var(--mono); font-size:.7rem;
  font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  gap:10px; transition:filter .3s; margin-top:6px;
  clip-path:polygon(0 0,100% 0,100% 65%,97% 100%,0 100%);
}
.form-submit:hover { filter:brightness(1.12); }

/* ══════════════════════════════
   FOOTER
══════════════════════════════ */
.footer { padding:56px 5% 36px; border-top:1px solid var(--border); background:var(--surface); }
.footer-top { display:flex; justify-content:space-between; align-items:flex-start; gap:48px; flex-wrap:wrap; margin-bottom:44px; }
.footer-brand p { color:var(--muted); font-size:.83rem; max-width:260px; line-height:1.75; margin-top:12px; font-weight:300; }
.footer-links-col h4 { font-family:var(--mono); font-size:.6rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--orange); margin-bottom:18px; }
.footer-links-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links-col a { color:var(--muted); font-size:.84rem; text-decoration:none; transition:color .25s; }
.footer-links-col a:hover { color:var(--white); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; padding-top:26px; border-top:1px solid var(--border); }
.footer-copy { font-family:var(--mono); font-size:.63rem; letter-spacing:.08em; color:var(--muted); }
.footer-copy span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; font-weight:600; }

/* ══════════════════════════════
   REVEAL
══════════════════════════════ */
.reveal { opacity:0; transform:translateY(22px); transition:opacity .6s ease,transform .6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.rd1 { transition-delay:.1s; }
.rd2 { transition-delay:.2s; }
.rd3 { transition-delay:.3s; }

/* ══════════════════════════════
   RESPONSIVE
══════════════════════════════ */
@media (max-width:1100px) {
  .services-grid { grid-template-columns:1fr 1fr; }
  .brands-grid { grid-template-columns:repeat(4,1fr); }
  .cob-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px) {
  .nav-links,.nav-btn { display:none; }
  .hamburger { display:flex; }
  .hero-title { font-size:clamp(3.5rem,13vw,6rem); }
  .hero-inner { padding:120px 5% 60px; }
  .services-header { grid-template-columns:1fr; gap:16px; }
  .db-section { grid-template-columns:1fr; margin:0 4%; }
  .db-right { min-height:260px; }
  .db-left { padding:48px 32px; border-right:none; border-bottom:1px solid var(--border); }
  .process-wrap { grid-template-columns:1fr 1fr; }
  .testimonials-grid { grid-template-columns:1fr 1fr; }
  .gallery-grid { grid-template-columns:1fr 1fr; grid-template-rows:200px 200px 200px; }
  .gal-tall { grid-row:auto; }
  .gal-wide { grid-column:auto; }
  .cob-grid { grid-template-columns:repeat(2,1fr); }
  .cta-band { flex-direction:column; align-items:flex-start; padding:64px 6%; margin:0 4%; }
  .cta-actions { width:100%; }
  .contact-grid { grid-template-columns:1fr; gap:48px; }
  .form-card { padding:32px 24px; }
  .hstat { padding:18px 28px 0 0; margin-right:28px; }
}
@media (max-width:600px) {
  section { padding:64px 5%; }
  .hero-inner { padding:100px 5% 52px; }
  .services-grid { grid-template-columns:1fr; }
  .brands-grid { grid-template-columns:repeat(2,1fr); }
  .cob-grid { grid-template-columns:repeat(2,1fr); }
  .process-wrap { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr; grid-template-rows:220px 180px 180px 180px; }
  .form-row { grid-template-columns:1fr; }
  .footer-top { flex-direction:column; gap:32px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .btn-white,.btn-white-ghost { width:100%; justify-content:center; }
  .hstat { padding:14px 20px 0 0; margin-right:20px; }
}
