/* ============================================================
   VALEN IGLESIAS — Sistema de diseño compartido
   Firma visual: B&N por defecto, color al hover.
   ============================================================ */

:root{
  --bone:#EFE8DC;
  --bone-deep:#E5DCCC;
  --ink:#0E0B09;
  --ink-soft:#1A1614;
  --ink-mid:#3A322C;
  --mute:#6B6156;
  --mute-warm:#a89b88;
  --line:#CFC5B5;
  --line-dark:#3a322c;
  --accent:#C4896F;
  --accent-deep:#8B3A2F;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Archivo',sans-serif;
  background:var(--bone);
  color:var(--ink);
  font-size:15px;line-height:1.5;
  overflow-x:hidden;
  position:relative;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.1  0 0 0 0 0.08  0 0 0 0 0.07  0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.4;mix-blend-mode:multiply;
}
.wrap{max-width:1400px;margin:0 auto;padding:0 32px;position:relative;z-index:2}
@media(max-width:600px){.wrap{padding:0 20px}}

/* ===== TOP BAR ===== */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:blur(12px);background:rgba(239,232,220,.82);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  max-width:1400px;margin:0 auto;padding:14px 32px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
}
.brand{
  font-family:'Fraunces',serif;font-size:17px;letter-spacing:.01em;
  text-transform:none;font-weight:500;font-style:italic;
  color:var(--ink);text-decoration:none;
}
.topbar nav{display:flex;gap:28px;align-items:center}
.topbar nav a{color:var(--ink-soft);text-decoration:none;transition:color .2s;position:relative}
.topbar nav a:hover{color:var(--accent-deep)}
.topbar nav a.on{color:var(--accent-deep)}
.topbar nav a.on::after{
  content:'';position:absolute;bottom:-18px;left:0;right:0;height:1px;background:var(--accent-deep);
}
.topbar .cta{color:var(--accent-deep);font-weight:600}
@media(max-width:820px){
  .topbar nav{gap:16px}
  .topbar nav a:not(.cta){display:none}
  .topbar-inner{padding:12px 20px}
}

/* ===== HERO DE VERTICAL ===== */
.v-hero{padding:150px 0 60px;position:relative}
.v-hero-grid{
  display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:end;
  border-top:1px solid var(--line);padding-top:28px;
}
@media(max-width:900px){.v-hero-grid{grid-template-columns:1fr;gap:32px}}
.v-hero-text .breadcrumb{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute);margin-bottom:30px;
}
.v-hero-text .breadcrumb a{color:var(--mute);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:2px}
.v-hero-text .breadcrumb a:hover{color:var(--accent-deep);border-color:var(--accent-deep)}
.v-hero-text .breadcrumb .sep{margin:0 10px}
.v-hero-num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(24px,3vw,36px);color:var(--accent-deep);margin-bottom:16px;
}
.v-hero-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(64px,12vw,180px);line-height:.88;letter-spacing:-.04em;
}
.v-hero-title em{font-style:italic}
.v-hero-tag{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:500;margin-top:30px;
}
.v-hero-tag span{color:var(--accent-deep);margin:0 8px}
.v-hero-photo{
  aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line);
  background-size:cover;background-position:center 25%;
  filter:grayscale(1) brightness(.85);
  animation:colorReveal 2.5s ease 1s forwards;
}
@keyframes colorReveal{to{filter:grayscale(0) brightness(1)}}

/* ===== SECCIONES ===== */
section{padding:100px 0;position:relative}
.sec-head{
  display:grid;grid-template-columns:1fr 2fr;gap:40px;
  margin-bottom:50px;align-items:end;
  border-top:1px solid var(--line);padding-top:22px;
}
.sec-num{
  font-family:'Fraunces',serif;font-size:13px;letter-spacing:.2em;
  color:var(--mute);text-transform:uppercase;
}
.sec-num em{font-style:italic;color:var(--accent-deep);margin-right:10px;font-size:16px}
.sec-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(40px,6vw,80px);line-height:.95;letter-spacing:-.03em;
}
.sec-title em{font-style:italic}
.sec-desc{
  max-width:560px;font-size:15px;line-height:1.7;color:var(--ink-soft);
  margin-bottom:40px;
}
@media(max-width:720px){
  .sec-head{grid-template-columns:1fr;gap:14px}
  section{padding:70px 0}
}

/* ===== DARK SECTION VARIANT ===== */
.dark{background:var(--ink);color:var(--bone)}
.dark .sec-head{border-color:var(--line-dark)}
.dark .sec-num,.dark .sec-desc{color:var(--mute-warm)}
.dark .sec-num em{color:var(--accent)}
.dark .sec-title{color:var(--bone)}

/* ===== PHOTO PLACEHOLDERS (B&N → color on hover) ===== */
.ph{
  background:linear-gradient(135deg,#4a3a30,#2a211c);
  position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
  filter:grayscale(1) brightness(.75) contrast(1.05);
  transition:filter .6s cubic-bezier(.22,1,.36,1),transform .6s ease;
  cursor:pointer;background-size:cover;background-position:center;
}
.ph:hover{filter:grayscale(0) brightness(1) contrast(1);transform:scale(1.015);z-index:2}
.ph::after{
  content:attr(data-label);
  position:absolute;bottom:12px;left:14px;
  font-size:9px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.phm{
  background:linear-gradient(135deg,#c8b9a3,#8a7866);
  aspect-ratio:3/4;position:relative;overflow:hidden;
  border:1px solid var(--line);
  filter:grayscale(1) brightness(.85) contrast(1.05);
  transition:filter .6s cubic-bezier(.22,1,.36,1),transform .6s ease;
  cursor:pointer;background-size:cover;background-position:center;
}
.phm:hover{filter:grayscale(0) brightness(1) contrast(1);transform:scale(1.015);z-index:2}
.phm::after{
  content:attr(data-label);
  position:absolute;bottom:10px;left:12px;
  font-size:9px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}

/* ===== CTA BLOCK ===== */
.cta-block{
  background:var(--ink);color:var(--bone);
  padding:70px 60px;margin:60px 0 0;
  display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;
}
@media(max-width:820px){.cta-block{grid-template-columns:1fr;padding:40px 28px}}
.cta-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(28px,3.5vw,44px);line-height:1.05;letter-spacing:-.02em;
}
.cta-title em{font-style:italic;color:var(--accent)}
.cta-actions{display:flex;flex-direction:column;gap:12px}
.btn{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  font-family:inherit;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;font-weight:600;
  text-decoration:none;transition:all .25s;cursor:pointer;
}
.btn-primary{background:var(--bone);color:var(--ink)}
.btn-primary:hover{background:var(--accent);color:var(--ink)}
.btn-outline{background:transparent;color:var(--bone);border:1px solid rgba(239,232,220,.3)}
.btn-outline:hover{background:var(--bone);color:var(--ink);border-color:var(--bone)}
.btn::after{content:'→';font-size:16px;letter-spacing:0}

/* ===== FOOTER ===== */
footer{background:var(--ink);color:var(--bone);padding:70px 0 30px}
.f-top{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
  padding-bottom:50px;border-bottom:1px solid var(--line-dark);
}
@media(max-width:720px){.f-top{grid-template-columns:1fr;gap:30px}}
.f-brand{
  font-family:'Fraunces',serif;font-size:56px;font-weight:300;
  letter-spacing:-.03em;line-height:.9;
}
.f-brand em{font-style:italic}
.f-sub{font-size:13px;color:var(--mute-warm);margin-top:20px;max-width:340px;line-height:1.6}
.f-col h4{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute-warm);margin-bottom:16px;
}
.f-col a{
  display:block;color:var(--bone);text-decoration:none;
  padding:4px 0;font-size:14px;opacity:.85;transition:opacity .2s;
}
.f-col a:hover{opacity:1;color:var(--accent)}
.f-bottom{
  display:flex;justify-content:space-between;padding-top:24px;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mute-warm);flex-wrap:wrap;gap:16px;
}

/* ===== COMPONENTES ESPECÍFICOS (grillas, specs, metrics) ===== */
.gallery-12{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:20px}
.g-span-3{grid-column:span 3}.g-span-4{grid-column:span 4}.g-span-5{grid-column:span 5}
.g-span-6{grid-column:span 6}.g-span-7{grid-column:span 7}.g-span-8{grid-column:span 8}
.ph.tall{aspect-ratio:3/4}.ph.wide{aspect-ratio:4/3}.ph.square{aspect-ratio:1}
@media(max-width:720px){
  .gallery-12{grid-template-columns:repeat(2,1fr)}
  .g-span-3,.g-span-4,.g-span-5,.g-span-6,.g-span-7,.g-span-8{grid-column:span 1}
}

.model-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:20px}
.phm.feat{grid-column:span 2;grid-row:span 2;aspect-ratio:1}
@media(max-width:720px){
  .model-grid{grid-template-columns:repeat(2,1fr)}
  .phm.feat{grid-column:span 2;grid-row:auto;aspect-ratio:1}
}

.specs{
  margin-top:40px;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  gap:24px;padding:28px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.spec{text-align:center}
.spec .n{
  font-family:'Fraunces',serif;font-style:italic;font-size:32px;
  font-weight:300;color:var(--accent-deep);display:block;
}
.spec .l{
  font-size:10px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--mute);margin-top:4px;display:block;
}

.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin-top:20px}
.metric{background:var(--bone);padding:32px 28px}
.metric .platform{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);margin-bottom:12px}
.metric .count{font-family:'Fraunces',serif;font-size:48px;font-weight:300;line-height:1;letter-spacing:-.02em}
.metric .count em{font-style:italic;color:var(--accent-deep)}
.metric .sub{font-size:13px;color:var(--ink-soft);margin-top:10px;line-height:1.5}

.credits{
  margin-top:40px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:24px;padding-top:30px;border-top:1px solid var(--line-dark);
}
.credit{font-size:13px;color:var(--mute-warm)}
.credit .yr{font-family:'Fraunces',serif;font-style:italic;color:var(--accent);font-size:15px;margin-right:8px}
.credit strong{color:var(--bone);font-weight:500;display:block;margin-top:2px;font-family:'Fraunces',serif;font-size:16px}

.reel-block{margin-top:40px}
.reel{
  aspect-ratio:16/9;
  background:#1a1614;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  position:relative;
}
.reel iframe{width:100%;height:100%;display:block;border:0}
.reel-caption{
  display:flex;gap:18px;align-items:baseline;flex-wrap:wrap;
  padding:18px 2px 0;
  border-top:1px solid rgba(255,255,255,.08);margin-top:14px;
}
.reel-year{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:20px;color:var(--accent);
}
.reel-title{
  font-family:'Fraunces',serif;font-size:18px;font-weight:400;color:var(--bone);
  letter-spacing:-.01em;
}
.reel-credit{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mute-warm);margin-left:auto;
}
@media(max-width:600px){.reel-credit{margin-left:0;width:100%;margin-top:4px}}

.brands-title{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);margin-bottom:20px;margin-top:40px;padding-top:30px;border-top:1px solid var(--line)}
.brands-row{display:flex;gap:40px;flex-wrap:wrap;font-family:'Fraunces',serif;font-size:22px;font-style:italic;font-weight:300;color:var(--ink-soft)}


/* ===== V-INTRO (sección editorial entre hero y dark) ===== */
.v-intro{padding:40px 0 110px;position:relative}
.intro-text-block{max-width:780px;margin-bottom:60px;padding-top:10px}
.intro-tag{
  display:inline-block;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute);margin-bottom:26px;font-weight:500;
}
.intro-lead{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:clamp(22px,2.5vw,32px);line-height:1.35;
  color:var(--ink-soft);letter-spacing:-.015em;
}
.intro-lead em{font-style:normal;color:var(--accent-deep);font-weight:400}

/* Reel caption en light bg (dentro de v-intro) */
.v-intro .reel-caption{border-top-color:var(--line)}
.v-intro .reel-title{color:var(--ink)}
.v-intro .reel-credit{color:var(--mute)}
.v-intro .reel-year{color:var(--accent-deep)}
.v-intro .reel{background:var(--ink-soft);border-color:var(--line)}

/* ===== METRICS LABEL (fecha de actualización) ===== */
.metrics-label{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--mute);margin-bottom:14px;font-weight:500;
  display:inline-block;padding:6px 0;border-top:1px solid var(--line);
}

/* ===== METRIC LINK (tarjeta clickable hacia perfil) ===== */
.metric-link{
  text-decoration:none;color:inherit;display:block;
  transition:background .25s ease;
  position:relative;
}
.metric-link:hover{background:var(--bone-deep)}
.metric-link .platform .arrow{
  opacity:0;transform:translateX(-4px);display:inline-block;
  transition:opacity .25s ease,transform .25s ease;
  color:var(--accent-deep);margin-left:4px;
}
.metric-link:hover .platform .arrow{opacity:1;transform:translateX(0)}
.metric-link:hover .count em{color:var(--accent)}

/* ===== BOTÓN WHATSAPP (en CTA blocks) ===== */
.btn-wa{
  background:transparent;color:var(--bone);
  border:1px solid rgba(37,211,102,.4);
  position:relative;
}
.btn-wa:hover{
  background:#25D366;color:#fff;border-color:#25D366;
}
.btn-wa svg{opacity:.9}
.btn-wa:hover svg{opacity:1}

/* Icono WA en footer (más sutil) */
.f-col a svg{opacity:.7;transition:opacity .2s}
.f-col a:hover svg{opacity:1}

/* ===== BRAND HOVER (click = scroll to top) ===== */
.brand{cursor:pointer;transition:color .2s ease}
.brand:hover{color:var(--accent-deep)}