/* =========================================================
   RV Gráfica · styles.css (rearmado / limpio)
   ========================================================= */

/* ---------------------------
   1) Variables + Base
--------------------------- */
:root{
  --rv-bg: #03061d;
  --rv-dark: #04030f;

  --rv-p: #1544ff;
  --rv-p2:#4c7cff;
  --rv-s: #ff73c5;
  --rv-a: #21f6d9;

  --rv-text: #f4f6ff;
  --rv-muted: rgba(244, 246, 255, 0.72);

  --rv-card: rgba(7, 17, 46, 0.78);
  --rv-stroke: rgba(144, 188, 230, 0.22);

  --rv-radius: 20px;
  --rv-shadow: 0 28px 56px rgba(7, 21, 66, 0.28);
  --rv-shadow-strong: 0 36px 72px rgba(4, 16, 51, 0.42);

  --rv-max: 1100px;

  font-size: 62.5%;
}

*,
*::before,
*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:'Poppins',sans-serif;
  font-size:1.6rem;
  line-height:1.6;
  color:var(--rv-text);

  background:
    radial-gradient(circle at 10% 20%, rgba(76, 124, 255, 0.55), transparent 55%),
    radial-gradient(circle at 85% 15%, rgba(255, 115, 197, 0.35), transparent 55%),
    linear-gradient(180deg, rgba(3, 6, 29, 1), rgba(2, 5, 20, 0.96));
  background-attachment: fixed;
  min-height: 100vh;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
a:hover, a:focus{ color: var(--rv-s); }

/* Containers */
.rv-container,
.container{
  width: min(100% - 4rem, var(--rv-max));
  margin-inline:auto;
}

/* ---------------------------
   2) Botones / Badges
--------------------------- */
.rv-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 1.2rem 2.8rem;
  border-radius: 999px;
  font-weight:700;
  letter-spacing: .10rem;
  text-transform: uppercase;
  border: 1px solid transparent;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

.rv-btn--primary{
  background: linear-gradient(135deg, var(--rv-p), var(--rv-p2));
  color: var(--rv-text);
  border-color: rgba(144,188,230,.35);
  box-shadow: var(--rv-shadow);
}
.rv-btn--primary:hover{ transform: translateY(-2px); box-shadow: var(--rv-shadow-strong); }

.rv-btn--ghost{
  background: rgba(6, 18, 33, 0.35);
  border-color: rgba(144,188,230,.28);
  color: var(--rv-text);
}
.rv-btn--ghost:hover{
  background: rgba(144,188,230,.10);
  border-color: rgba(33,246,217,.28);
  transform: translateY(-2px);
}

.rv-badges{
  margin-top: 2.2rem;
  display:flex;
  flex-wrap:wrap;
  gap: 1rem;
}

.rv-badge{
  display:inline-flex;
  align-items:center;
  padding: .65rem 1.2rem;
  border-radius: 999px;
  background: rgba(9,18,42,.55);
  border: 1px solid rgba(76,124,255,.22);
  color: rgba(244,246,255,.88);
  font-size: 1.25rem;
  letter-spacing: .12rem;
}

/* ---------------------------
   3) Header / Nav (simple)
--------------------------- */
.site-header{
  position: relative;
  padding: 2.2rem 0 0;
}

.header-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 2rem;
}

.branding{ display:flex; flex-direction:column; gap:.6rem; }

.logo{
  display:inline-flex;
  align-items:center;
}

/* ✅ Sin recuadro del logo (clean) */
.logo img{
  width: clamp(9rem, 10vw, 11rem);
  height:auto;
  filter: drop-shadow(0 18px 32px rgba(0,0,0,.45));
}

.tagline{
  margin:0;
  color: var(--rv-muted);
  letter-spacing: .20rem;
  text-transform: uppercase;
  font-size: 1.2rem;
}

.site-nav{ display:flex; align-items:center; justify-content:flex-end; }

.nav-toggle{
  display:none;
  background: rgba(144,188,230,.15);
  color: var(--rv-text);
  border: 1px solid rgba(144,188,230,.22);
  border-radius: 999px;
  padding: .8rem 1.6rem;
  font-weight:700;
  letter-spacing: .18rem;
  text-transform: uppercase;
}

.nav-list{
  list-style:none;
  display:flex;
  gap: 2.2rem;
  margin:0;
  padding:0;
}

.nav-list a{
  font-size: 1.35rem;
  text-transform: uppercase;
  letter-spacing: .28rem;
  padding-bottom: .55rem;
  position: relative;
}

.nav-list a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:0;
  height:2px;
  background: var(--rv-s);
  transition: width .2s ease;
}
.nav-list a:hover::after,
.nav-list a.is-active::after,
.nav-list a[aria-current="page"]::after{
  width:100%;
}

/* ---------------------------
   4) HERO nuevo (rv-hero)
--------------------------- */
.rv-hero{
  position: relative;
  padding: 8rem 0 4rem;
}

.rv-hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at 18% 18%, rgba(76, 124, 255, 0.55), transparent 55%),
    radial-gradient(circle at 85% 10%, rgba(255, 115, 197, 0.40), transparent 60%),
    linear-gradient(150deg, rgba(4, 16, 51, 0.92), rgba(3, 10, 28, 0.92));
}

.rv-hero__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 4rem;
  align-items:center;
}

.rv-kicker{
  display:inline-flex;
  align-items:center;
  gap:.8rem;
  font-size: 1.25rem;
  letter-spacing: .42rem;
  text-transform: uppercase;
  padding: .7rem 1.4rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(33,246,217,.20), rgba(255,115,197,.25));
  border: 1px solid rgba(33,246,217,.35);
  box-shadow: 0 10px 24px rgba(21, 68, 255, 0.18);
}

.rv-title{
  font-size: clamp(3.4rem, 5.6vw, 5rem);
  line-height: 1.08;
  margin: 1.6rem 0 1.4rem;
}

.rv-accent{ color: var(--rv-s); }

.rv-lead{
  margin:0 0 2.4rem;
  color: var(--rv-muted);
  max-width: 62ch;
}

.rv-hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap: 1.2rem;
  margin-top: 1.2rem;
}

/* Card derecha */
.rv-hero__card{
  background: rgba(7, 17, 46, 0.55);
  border: 1px solid rgba(144,188,230,.22);
  border-radius: calc(var(--rv-radius) + 10px);
  box-shadow: var(--rv-shadow-strong);
  padding: 1.6rem;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* ---------------------------
   5) Before/After PREMIUM (rv-ba)
--------------------------- */
.rv-ba{
  position: relative;
  overflow:hidden;
  border-radius: calc(var(--rv-radius) + 10px);
  border: 1px solid rgba(144,188,230,.22);
  background: rgba(6,18,33,.55);
  box-shadow: 0 38px 90px rgba(0,0,0,.42);
  transform: translateZ(0);
}

.rv-ba::before{
  content:"";
  position:absolute;
  inset:-30%;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 10%, rgba(33, 246, 217, 0.14), transparent 45%),
    radial-gradient(circle at 80% 30%, rgba(255, 115, 197, 0.12), transparent 48%),
    radial-gradient(circle at 55% 90%, rgba(76, 124, 255, 0.12), transparent 50%);
  opacity: .9;
}

.rv-ba__photo{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  filter: saturate(1.06) contrast(1.03);
}

.rv-ba__after{
  position:absolute;
  inset:0;
  z-index:2;
  clip-path: inset(0 45% 0 0); /* JS */
  will-change: clip-path;
}

.rv-ba__label{
  position:absolute;
  top: 1.2rem;
  padding: .6rem 1.1rem;
  border-radius: 999px;
  font-size: 1.12rem;
  letter-spacing: .34rem;
  text-transform: uppercase;
  font-weight: 800;
  z-index:4;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(6,18,33,.52);
  color: rgba(244,246,255,.92);
  box-shadow: 0 18px 40px rgba(0,0,0,.32);
}

.rv-ba__label--before{ left: 1.2rem; }
.rv-ba__label--after{ right: 1.2rem; }

.rv-ba__divider{
  position:absolute;
  top:0; bottom:0;
  left:55%;
  width:0;
  z-index:5;
  pointer-events:none;
}

.rv-ba__divider::before{
  content:"";
  position:absolute;
  top:0; bottom:0;
  left:-1px;
  width: 2px;
  background: linear-gradient(
    180deg,
    rgba(255,255,255,0.05),
    rgba(255,255,255,0.62),
    rgba(255,255,255,0.05)
  );
  box-shadow:
    0 0 0 1px rgba(6,18,33,.35),
    0 18px 40px rgba(0,0,0,.35);
}

/* Handle premium */
.rv-ba__handle{
  position:absolute;
  top:50%;
  left:-24px;
  width: 48px;
  height: 48px;
  transform: translateY(-50%);
  border-radius: 999px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(144,188,230,.30);
  background: linear-gradient(135deg, rgba(255,255,255,.16), rgba(6,18,33,.55));
  box-shadow:
    0 22px 55px rgba(0,0,0,.44),
    inset 0 0 0 1px rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Chevrons */
.rv-ba__chev{
  position:absolute;
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(244,246,255,.9);
  border-bottom: 2px solid rgba(244,246,255,.9);
  opacity:.92;
}
.rv-ba__chev--left{ transform: rotate(135deg); left: 14px; }
.rv-ba__chev--right{ transform: rotate(-45deg); right: 14px; }

/* slider usable pero invisible */
.rv-ba__range{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor: ew-resize;
  z-index:6;
  margin:0;
}

/* Hint */
.rv-ba__hint{
  margin: 1.2rem 0 0;
  color: var(--rv-muted);
  font-size: 1.35rem;
}

/* ---------------------------
   6) WhatsApp bubble
--------------------------- */
.whatsapp-bubble{
  position:fixed;
  right:2.4rem;
  bottom:2.4rem;
  width:5.6rem;
  height:5.6rem;
  border-radius:50%;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, #25d366, #128c7e);
  color:#fff;
  z-index:50;
  box-shadow: 0 16px 32px rgba(18, 140, 126, 0.35);
  transition: transform .2s ease, box-shadow .2s ease;
}
.whatsapp-bubble:hover{ transform: translateY(-3px); box-shadow: 0 20px 40px rgba(18, 140, 126, 0.45); }
.whatsapp-icon{ width:2.8rem; height:2.8rem; }

/* ---------------------------
   7) Responsive
--------------------------- */
@media (max-width: 980px){
  .rv-hero__grid{
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .rv-hero{ padding: 6.5rem 0 3rem; }
}

@media (max-width: 900px){
  .nav-toggle{ display:inline-flex; }

  .nav-list{
    position:absolute;
    top: 100%;
    right: 2rem;
    flex-direction:column;
    background: rgba(6,18,33,.95);
    padding: 2rem;
    border-radius: var(--rv-radius);
    border: 1px solid rgba(144,188,230,.25);
    box-shadow: var(--rv-shadow);
    transform: scale(.95);
    opacity:0;
    pointer-events:none;
    transition: opacity .2s ease, transform .2s ease;
  }
  .nav-list.is-open{
    opacity:1;
    transform: scale(1);
    pointer-events:auto;
  }
  .header-top{ position:relative; }
}

@media (max-width: 560px){
  .rv-container,
  .container{
    width: min(100% - 3rem, var(--rv-max));
  }
  .rv-title{ font-size: clamp(3.1rem, 9vw, 4.2rem); }
  .rv-ba__photo{ aspect-ratio: 16 / 11; }
}

/* TEST: forzar tamaño logo (si esto no cambia, no está cargando tu CSS) */
.logo img{
  width: 160px !important;
}
body{
  outline: 8px solid lime !important;
}