/* =========================================================
   DJ PONTE v2 — Conversion-First CSS
   Sistema: oscuro base / claro en secciones alternadas
   ========================================================= */
/* =========================================================
   FUENTES AUTOALOJADAS — sin dependencia de Google Fonts
   ========================================================= */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/montserrat-latin-400-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/montserrat-latin-600-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/montserrat-latin-700-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root{
  --negro:#0E0D0B;
  --vinilo:#1A1713;
  --card-dark:#231E17;
  --crema:#F5F0E8;
  --crema-2:#EDE6D5;
  --oro:#B98E3F;
  --oro-claro:#D4A84B;
  --tinta:#FAF7F0;
  --tinta-suave:#B8AD9E;
  --wa:#25D366;
  --wa-dark:#179848;
  --r:14px;
  --max:1100px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;color-scheme:only light;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:'Montserrat',system-ui,sans-serif;font-size:16px;line-height:1.65;
  color:var(--tinta);background:var(--negro);-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px;box-sizing:border-box}

/* ── Tipografía ─────────────────────────────────────── */
h1,h2,h3,h4{font-family:Georgia,serif;font-weight:600;
  line-height:1.1;color:var(--tinta);letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5.5vw,4rem)}
h2{font-size:clamp(1.9rem,3.8vw,2.8rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}
h1 em,h2 em{font-style:italic;color:var(--oro-claro)}
p{margin-bottom:.9em;color:var(--tinta-suave)}
p:last-child{margin-bottom:0}
.eyebrow{display:block;font-size:.7rem;font-weight:700;letter-spacing:.25em;
  text-transform:uppercase;color:var(--oro);margin-bottom:12px}
.lead{font-size:1.05rem;line-height:1.7;color:var(--tinta-suave)}

/* Secciones claras: override de colores */
.light h1,.light h2,.light h3,.light h4{color:#1A1510}
.light p,.light .lead{color:#5C4E3A}
.light .eyebrow{color:var(--oro)}
.light{background:var(--crema);color:#1A1510}
.light-alt{background:var(--crema-2)}
.light-alt h1,.light-alt h2,.light-alt h3{color:#1A1510}
.light-alt p,.light-alt .lead{color:#5C4E3A}

/* ── Botones ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.82rem;
  letter-spacing:.09em;text-transform:uppercase;text-decoration:none;
  padding:16px 30px;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s,color .15s;
  min-height:52px;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:1.2em;height:1.2em;flex:none;fill:currentColor}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 8px 24px rgba(37,211,102,.35)}
.btn-wa:hover{background:var(--wa-dark)}
.btn-sec{background:transparent;color:var(--tinta);border-color:var(--oro)}
.btn-sec:hover{background:var(--oro);color:#0E0D0B}
.light .btn-sec{color:#1A1510}
.btn-ghost{background:transparent;color:var(--oro);border-color:transparent;
  text-decoration:underline;text-underline-offset:4px;padding:8px 0}
.btn-ghost:hover{transform:none;color:var(--oro-claro)}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.micro{font-size:.78rem;color:var(--tinta-suave);margin-top:12px}
.light .micro{color:#8A7A65}

/* ── Header ────────────────────────────────────────── */
.header{position:fixed;inset:0 0 auto;z-index:100;
  background:rgba(14,13,11,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(185,142,63,.2)}
.nav{display:flex;align-items:center;justify-content:space-between;
  height:64px;max-width:var(--max);margin:0 auto;padding:0 20px}
.logo{font-family:Georgia,serif;font-size:1.4rem;font-weight:600;
  color:var(--crema);letter-spacing:.04em}
.logo span{color:var(--oro)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:.78rem;font-weight:600;letter-spacing:.07em;
  text-transform:uppercase;color:var(--tinta-suave);transition:color .15s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--oro-claro)}
.nav-toggle{display:none;background:none;border:none;color:var(--crema);
  font-size:1.6rem;cursor:pointer;padding:6px;line-height:1}
.nav-cta{display:flex;align-items:center;gap:.4em;font-family:'Montserrat',sans-serif;
  font-weight:700;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;
  color:#fff!important;background:var(--wa);padding:9px 18px;border-radius:999px;
  transition:background .15s}
.nav-cta:hover{background:var(--wa-dark)}
.nav-cta svg{width:1em;height:1em;fill:#fff}

/* ── HERO ───────────────────────────────────────────── */
.hero{padding:100px 0 70px;min-height:90vh;
  display:flex;align-items:center;background:var(--negro)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.hero-img{position:relative;width:100%}
.hero-img img{width:100%;max-width:480px;border-radius:20px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);margin:0 auto;
  display:block;object-fit:contain;background:transparent}
.hero-badge{position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);
  background:var(--oro);color:#0E0D0B;font-weight:700;font-size:.78rem;
  letter-spacing:.06em;text-transform:uppercase;padding:10px 20px;
  border-radius:999px;white-space:nowrap;box-shadow:0 8px 24px rgba(185,142,63,.4)}
.trust-strip{display:flex;flex-wrap:wrap;gap:6px 20px;margin-top:22px;
  font-size:.8rem;font-weight:600;color:var(--tinta-suave)}
.trust-strip b{color:var(--oro-claro)}
.urgency{display:inline-block;margin-top:20px;font-size:.82rem;font-weight:600;
  color:#E8C97A;background:rgba(185,142,63,.12);border:1px solid rgba(185,142,63,.3);
  padding:8px 16px;border-radius:999px}

/* ── Prueba social inmediata ────────────────────────── */
.proof-hero{padding:60px 0;background:var(--vinilo);text-align:center;
  border-top:1px solid rgba(185,142,63,.15);border-bottom:1px solid rgba(185,142,63,.15)}
.proof-hero blockquote{font-family:Georgia,serif;font-size:clamp(1.5rem,3.5vw,2.2rem);
  font-style:italic;font-weight:500;color:var(--tinta);max-width:780px;margin:0 auto 16px;
  line-height:1.35}
.proof-hero .stars{font-size:1.3rem;color:var(--oro);letter-spacing:.15em;margin-bottom:18px}
.proof-hero figcaption{font-size:.82rem;font-weight:600;color:var(--tinta-suave)}

/* ── Secciones genéricas ────────────────────────────── */
.section{padding:80px 0}
.section-head{margin-bottom:44px}
.section-head.center{text-align:center;max-width:680px;margin-inline:auto;margin-bottom:44px}

/* ── Emilio/Por qué yo ──────────────────────────────── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.why-img img{border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.why-pills{display:flex;flex-direction:column;gap:20px;margin-top:28px}
.pill{display:flex;gap:16px;align-items:flex-start}
.pill-num{font-family:Georgia,serif;font-size:2.2rem;font-weight:600;
  color:var(--oro);line-height:1;min-width:36px;padding-top:2px}
.pill h3{margin-bottom:4px;font-size:1.1rem;color:var(--tinta)}
.pill p{font-size:.92rem;margin:0;color:var(--tinta-suave)}

/* ── Servicios ──────────────────────────────────────── */
.services-hero{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;
  align-items:center;margin-bottom:50px}
.service-main h2{margin-bottom:14px}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service-card{background:var(--card-dark);border:1px solid rgba(185,142,63,.2);
  border-radius:var(--r);padding:22px 18px;transition:border-color .2s,transform .2s}
.service-card:hover{border-color:var(--oro);transform:translateY(-3px)}
.service-card h3{font-size:1.05rem;margin-bottom:8px;color:var(--tinta)}
.service-card p{font-size:.88rem;margin-bottom:14px;color:var(--tinta-suave)}
.service-card .price{font-size:.8rem;font-weight:700;color:var(--oro);
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.service-card a{font-size:.75rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--oro-claro);text-decoration:none}
.service-card a:hover{text-decoration:underline}

/* ── Galería ────────────────────────────────────────── */
.gallery-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;
  grid-template-rows:auto auto;gap:14px}
.gallery-grid .g1{grid-row:1/3}
.gallery-grid img{width:100%;height:100%;object-fit:cover;border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);transition:transform .3s}
.gallery-grid img:hover{transform:scale(1.02)}

/* ── Vídeos ─────────────────────────────────────────── */
.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:32px}
.video-thumb{position:relative;border-radius:12px;overflow:hidden;
  cursor:pointer;aspect-ratio:16/9}
.video-thumb img{width:100%;height:100%;object-fit:cover;
  transition:transform .3s;display:block}
.video-thumb:hover img{transform:scale(1.05)}
.play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);transition:background .2s}
.video-thumb:hover .play-btn{background:rgba(0,0,0,.5)}
.play-btn svg{width:52px;height:52px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}

/* ── Reseñas ─────────────────────────────────────────── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.review{background:var(--crema);border-radius:var(--r);padding:28px 24px}
.review .stars{color:var(--oro);font-size:1rem;letter-spacing:.15em;margin-bottom:14px}
.review blockquote{font-size:.94rem;font-style:italic;color:#2A1F12;margin-bottom:14px;line-height:1.6}
.review figcaption{font-size:.78rem;font-weight:700;color:#7A6A55}
.review-photo img{border-radius:10px;width:100%;height:auto;margin-bottom:14px}

/* ── Carrusel ────────────────────────────────────────── */
.carousel-wrap{overflow:hidden;margin-top:30px}
.carousel-track{display:flex;transition:transform .42s cubic-bezier(.4,0,.2,1);will-change:transform;contain:layout}
.c-card{min-width:100%;box-sizing:border-box;padding:0 4px}
@media(min-width:640px){.c-card{min-width:50%}}
@media(min-width:960px){.c-card{min-width:33.333%}}
.c-card .review{height:100%;display:flex;flex-direction:column}
.c-card .review blockquote{flex:1}
.carousel-nav{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:20px}
.c-btn{background:none;border:2px solid var(--oro);color:var(--oro);
  width:40px;height:40px;border-radius:50%;font-size:1.1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.c-btn:hover{background:var(--oro);color:#0E0D0B}
.c-dots{display:flex;gap:8px}
.c-dot{width:8px;height:8px;border-radius:50%;background:var(--tinta-suave);
  border:none;cursor:pointer;padding:0;margin:0;position:relative;
  transition:background .2s,transform .2s}
.c-dot::after{content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);width:44px;height:44px}
.c-dot.on{background:var(--oro);transform:scale(1.3)}
.google-link{display:inline-block;margin-top:24px;font-size:.84rem;font-weight:700;
  color:var(--oro);letter-spacing:.04em}
.light .google-link{color:#8A5F20}
.google-link:hover{text-decoration:underline}

/* ── Precios ─────────────────────────────────────────── */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price-card{background:var(--card-dark);border:1px solid rgba(185,142,63,.22);
  border-radius:var(--r);padding:30px 26px;transition:border-color .2s}
.price-card.featured{border-color:var(--oro);background:#1F1A11}
.price-card .from{font-family:Georgia,serif;font-size:2.5rem;
  font-weight:600;color:var(--oro);line-height:1;margin:10px 0 16px}
.price-card .from small{font-size:.38em;font-family:'Montserrat',sans-serif;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.price-card h3{font-size:1.1rem;margin-bottom:8px;color:var(--tinta)}
.checklist{display:flex;flex-direction:column;gap:8px;margin:16px 0}
.checklist li{font-size:.86rem;color:var(--tinta-suave);display:flex;gap:8px;align-items:flex-start}
.checklist li::before{content:"✓";color:var(--oro);font-weight:700;flex:none;margin-top:1px}
.price-note{font-size:.8rem;color:var(--tinta-suave);margin-top:20px;
  border-top:1px solid rgba(185,142,63,.15);padding-top:20px;text-align:center}

/* ── Vinyl Set diferenciador ─────────────────────────── */
.vinyl-strip{background:var(--vinilo);border-top:1px solid rgba(185,142,63,.2);
  border-bottom:1px solid rgba(185,142,63,.2);padding:60px 0}
.vinyl-inner{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.vinyl-inner img{border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.5)}

/* ── FAQ ─────────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column;gap:10px}
details{background:var(--card-dark);border:1px solid rgba(185,142,63,.18);
  border-radius:var(--r);overflow:hidden}
.light details{background:#FBF7F0;border-color:rgba(185,142,63,.35)}
summary{cursor:pointer;list-style:none;padding:18px 52px 18px 22px;
  font-family:Georgia,serif;font-size:1.12rem;font-weight:600;
  color:var(--tinta);position:relative;user-select:none}
.light summary{color:#1A1510}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";position:absolute;right:20px;top:50%;
  transform:translateY(-50%);color:var(--oro);font-size:1.4rem;
  font-family:'Montserrat',sans-serif;font-weight:400;transition:transform .2s}
details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
details p{padding:0 22px 20px;font-size:.92rem;color:var(--tinta-suave)}
.light details p{color:#5C4E3A}

/* ── CTA Final ───────────────────────────────────────── */
.cta-final{background:var(--vinilo);padding:90px 0;text-align:center;
  border-top:1px solid rgba(185,142,63,.2)}
.cta-final h2{max-width:600px;margin:0 auto 16px;color:var(--tinta)}
.cta-final p{max-width:540px;margin:0 auto;color:var(--tinta-suave)}
.cta-final .btn-row{justify-content:center}
.cta-final .urgency{margin-bottom:28px}

/* ── Footer ──────────────────────────────────────────── */
.footer{background:var(--negro);border-top:1px solid rgba(185,142,63,.18);
  padding:56px 0 30px;font-size:.85rem;color:var(--tinta-suave)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo{font-family:Georgia,serif;font-size:1.6rem;font-weight:600;
  color:var(--crema);display:inline-block;margin-bottom:12px}
.footer-logo span{color:var(--oro)}
.footer h4{color:var(--crema);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:14px;font-weight:700;font-family:'Montserrat',sans-serif}
.footer a{color:var(--tinta-suave);transition:color .15s}
.footer a:hover{color:var(--oro-claro)}
.footer li{margin-bottom:8px}
.footer-bottom{border-top:1px solid rgba(185,142,63,.12);padding-top:22px;
  display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:space-between;
  font-size:.75rem}
.nap{font-size:.85rem;line-height:1.9}

/* ── WhatsApp flotante ───────────────────────────────── */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:99;
  width:56px;height:56px;border-radius:50%;background:var(--wa);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.35);transition:transform .15s}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:28px;height:28px;fill:#fff}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:920px){
  .hero{padding:100px 0 60px;min-height:auto}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-img{order:2;max-width:340px;margin:0 auto 28px;position:relative;padding-bottom:18px}
  .hero-img img{max-height:340px;object-fit:cover;object-position:center top}
  .why-grid,.vinyl-inner,.services-hero{grid-template-columns:1fr;gap:32px}
  .service-grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;max-width:100%}
  .gallery-grid .g1{grid-row:auto}
  .video-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none;position:fixed;top:64px;inset:64px 0 auto;
    flex-direction:column;background:var(--negro);padding:16px 20px 24px;
    border-bottom:1px solid rgba(185,142,63,.2);gap:0}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.9rem}
  .nav-links .nav-cta{
    margin-top:8px;width:100%;justify-content:center;
    border-radius:12px;padding:16px 20px;font-size:.9rem;
  }
  .nav-toggle{display:block}
}
@media(max-width:600px){
  .service-grid,.gallery-grid,.video-grid,.reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .btn{width:100%}
  .btn-row{flex-direction:column}
  .hero h1{font-size:2.2rem}
}

/* Badge de reseñas fuera de la imagen hero */
.hero-badge-ext{
  display:block;text-align:center;margin-top:14px;
  background:var(--oro);color:#0E0D0B;font-weight:700;font-size:.82rem;
  letter-spacing:.06em;text-transform:uppercase;padding:10px 22px;
  border-radius:999px;white-space:nowrap;box-shadow:0 8px 24px rgba(185,142,63,.4);
}

/* Botón Instagram */
.btn-insta{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.86rem;
  letter-spacing:.07em;text-transform:uppercase;text-decoration:none;
  padding:15px 30px;border-radius:999px;
  background:#1A1510;color:#FAF7F0;
  box-shadow:0 6px 20px rgba(0,0,0,.18);
  transition:transform .15s,box-shadow .15s,background .15s;
  min-height:52px;border:none;cursor:pointer;
}
.btn-insta:hover{background:#2E261C;transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.25)}

/* Fix CLS — imágenes carousel y cards */
.carousel-track img{height:auto}
.c-card{contain:layout style}

.nav-cta,.nav-cta *{color:#fff!important}
