/* Barbería Garcialoredo — landing */

:root {
  --bg: #0b0908;
  --bg-2: #141010;
  --bg-3: #1d1815;
  --paper: #e8dcc4;
  --paper-2: #d9c9a8;
  --paper-dark: #c8b38c;
  --ink: #1a140f;
  --bronze: #b8864a;
  --bronze-2: #d9a968;
  --bronze-deep: #7a5520;
  --oxblood: #6b2c1f;
  --oxblood-2: #8a3a27;
  --steel: #8a8680;
  --fog: #a9a29a;

  --font-display: "UnifrakturCook", serif;
  --font-sig: "Playfair Display SC", "Cormorant Garamond", serif;
  --font-serif: "Playfair Display", "Cormorant Garamond", serif;
  --font-serif-alt: "IM Fell English SC", "Playfair Display", serif;
  --font-body: "Inter", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
  --font-type: "Special Elite", "Courier New", monospace;
  --font-cond: "Bebas Neue", "Oswald", sans-serif;
}

/* palette variants via body.palette-X */
body.palette-bronze { --accent: var(--bronze); --accent-2: var(--bronze-2); --accent-deep: var(--bronze-deep); }
body.palette-steel  { --accent: #b9b3a8; --accent-2: #d8d2c6; --accent-deep: #6a6660; }
body.palette-oxblood{ --accent: #b8563a; --accent-2: #d97352; --accent-deep: var(--oxblood); }

body.type-vintage   { --h-font: var(--font-serif-alt); }
body.type-refined   { --h-font: var(--font-serif); }

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--paper); }
body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

/* ============ Paper texture ============ */
.grain::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.3  0 0 0 0 0.25  0 0 0 0 0.2  0 0 0 0.35 0'/></filter><rect width='300' height='300' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
  opacity: var(--grain-opacity, .55);
  z-index: 3;
}

.scratches::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600'><filter id='s'><feTurbulence type='turbulence' baseFrequency='0.015 0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.1  0 0 0 0 0.08  0 0 0 0 0.05  0 0 0 0.6 0'/></filter><rect width='600' height='600' filter='url(%23s)'/></svg>");
  mix-blend-mode: multiply;
  opacity: .18;
  z-index: 3;
}

/* ============ Typographic helpers ============ */
.display { font-family: var(--font-display); font-weight: 700; letter-spacing: .005em; }
.sig     { font-family: var(--font-sig); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.serif   { font-family: var(--h-font, var(--font-serif)); }
.type    { font-family: var(--font-type); letter-spacing: .02em; }
.mono    { font-family: var(--font-mono); letter-spacing: .02em; }
.cond    { font-family: var(--font-cond); letter-spacing: .08em; }

.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before, .eyebrow::after {
  content: ""; display: inline-block; width: 28px; height: 1px;
  background: currentColor; opacity: .6;
}
.eyebrow.solo::after { display: none; }
.eyebrow.solo-r::before { display: none; }

/* ============ Layout ============ */
.wrap { max-width: 1280px; margin: 0 auto; padding: 0 clamp(20px, 5vw, 56px); position: relative; }
.wrap-narrow { max-width: 960px; margin: 0 auto; padding: 0 clamp(20px, 5vw, 40px); position: relative; }

section { position: relative; }

/* Airmail border (red+blue stripes like envelope) */
.airmail {
  height: 10px;
  background:
    repeating-linear-gradient( 45deg,
      var(--oxblood-2) 0 12px,
      transparent 12px 18px,
      #1b3a5a 18px 30px,
      transparent 30px 36px);
  opacity: .85;
}

/* ============ NAV ============ */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 60;
  padding: 14px clamp(20px, 5vw, 56px);
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(to bottom, rgba(11,9,8,.85) 0%, rgba(11,9,8,.4) 70%, transparent 100%);
  backdrop-filter: blur(6px);
  transition: background .3s;
}
.nav.scrolled {
  background: rgba(11,9,8,.92);
  border-bottom: 1px solid rgba(184,134,74,.25);
}
.nav-brand { display: flex; align-items: center; gap: 12px; }
.nav-brand-mark {
  width: 38px; height: 38px; border-radius: 50%;
  border: 1.5px solid var(--accent);
  display: grid; place-items: center;
  font-family: var(--font-serif); font-style: italic; font-weight: 900;
  font-size: 20px;
  color: var(--accent);
  background: var(--bg-2);
}
.nav-brand-name { font-family: var(--font-sig); font-weight: 700; letter-spacing: .14em; font-size: 13px; color: var(--paper); }
.nav-brand-sub { font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em; color: var(--fog); text-transform: uppercase; }
.nav-links { display: flex; gap: 28px; }
.nav-links a {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--paper); opacity: .72; transition: opacity .2s, color .2s;
}
.nav-links a:hover { opacity: 1; color: var(--accent-2); }
.nav-cta {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase;
  padding: 10px 18px;
  border: 1px solid var(--accent);
  color: var(--accent-2);
  background: transparent;
  transition: all .2s;
}
.nav-cta:hover { background: var(--accent); color: var(--bg); }
@media (max-width: 900px) { .nav-links { display: none; } }

/* ============ HERO ============ */
.hero {
  position: relative; min-height: 100vh;
  overflow: hidden;
  display: grid;
}
.hero-bg {
  position: absolute; inset: 0;
  background-image: var(--hero-img, url(assets/hero-chair-moto.jpg));
  background-size: cover;
  background-position: center;
  filter: contrast(1.1) saturate(.85) brightness(.7);
  z-index: 0;
}
.hero-bg::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(184,134,74,.18), transparent 55%),
    linear-gradient(180deg, rgba(11,9,8,.55) 0%, rgba(11,9,8,.45) 40%, rgba(11,9,8,.85) 100%),
    linear-gradient(90deg, rgba(11,9,8,.7) 0%, transparent 45%, rgba(11,9,8,.5) 100%);
}
.hero-content {
  position: relative; z-index: 2;
  padding-top: 140px;
  padding-bottom: 60px;
  align-self: center;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 40px; align-items: end;
}
.hero-title {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(54px, 9.5vw, 148px);
  line-height: .88;
  letter-spacing: -.015em;
  color: var(--paper);
  margin: 0;
  text-shadow: 0 2px 40px rgba(0,0,0,.7);
}
.hero-title .script {
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-weight: 400;
  color: var(--accent-2);
  display: block;
  font-size: .42em;
  letter-spacing: .01em;
  margin-bottom: -.1em;
  margin-left: .04em;
}
.hero-title .nudge { display: block; margin-top: -.06em; }
.hero-title .ampersand {
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-weight: 400;
  color: var(--accent-2);
}

.hero-sub {
  max-width: 520px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.5;
  color: rgba(232,220,196,.85);
  margin: 28px 0 0;
  padding-left: 20px;
  border-left: 1px solid var(--accent);
}

.hero-meta {
  display: flex; gap: 28px; align-items: center;
  margin-top: 40px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(232,220,196,.75);
  flex-wrap: wrap;
}
.hero-meta .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--accent); }
.hero-meta b { color: var(--paper); font-weight: 500; margin-right: 6px; }

.hero-medallion {
  position: absolute; top: 120px; right: clamp(20px, 5vw, 56px);
  z-index: 2;
  width: 150px; height: 150px;
  display: grid; place-items: center;
  color: var(--accent-2);
  animation: slow-spin 40s linear infinite;
}
@keyframes slow-spin { to { transform: rotate(360deg); } }
@media (max-width: 900px) { .hero-medallion { display: none; } }

.hero-scroll {
  position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
  z-index: 2;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .4em; text-transform: uppercase;
  color: var(--accent-2);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.hero-scroll .line {
  width: 1px; height: 40px; background: currentColor;
  animation: scroll-pulse 2s ease-in-out infinite;
  transform-origin: top;
}
@keyframes scroll-pulse {
  0%, 100% { transform: scaleY(1); opacity: .8; }
  50% { transform: scaleY(.3); opacity: .4; }
}

/* Hero variants */
body.hero-split .hero-content { grid-template-columns: minmax(0, 1fr); }
body.hero-split .hero-title { font-size: clamp(40px, 6.5vw, 94px); }
body.hero-split .hero-bg { background-position: right center; }
body.hero-split .hero-bg::after {
  background:
    linear-gradient(90deg, rgba(11,9,8,.95) 0%, rgba(11,9,8,.85) 45%, transparent 80%);
}

body.hero-wordmark .hero-title { font-size: clamp(64px, 14vw, 220px); text-align: center; line-height: .82; }
body.hero-wordmark .hero-content { grid-template-columns: 1fr; text-align: center; }
body.hero-wordmark .hero-sub { margin: 28px auto 0; text-align: center; border-left: 0; padding-left: 0;
  border-top: 1px solid var(--accent); padding-top: 16px; }
body.hero-wordmark .hero-meta { justify-content: center; }
body.hero-wordmark .hero-bg { filter: contrast(1.2) saturate(.6) brightness(.45); }

/* ============ SECTION: Legacy ============ */
.legacy {
  background: var(--bg);
  padding: clamp(80px, 10vw, 140px) 0;
  overflow: hidden;
}
.legacy-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}
@media (max-width: 860px) { .legacy-grid { grid-template-columns: 1fr; } }

.legacy-kicker {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .35em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 24px;
}
.legacy h2 {
  font-family: "Big Shoulders Display", "Alfa Slab One", serif;
  font-weight: 900;
  font-size: clamp(44px, 5.6vw, 82px);
  line-height: .92;
  letter-spacing: .005em;
  text-transform: uppercase;
  margin: 0 0 32px;
  color: var(--paper);
  text-shadow: 0 2px 0 rgba(184,134,74,.08);
}
.legacy h2 em {
  font-style: italic;
  color: var(--accent-2);
  font-weight: 400;
  font-family: "Yellowtail", "Allura", cursive;
  text-transform: none;
  letter-spacing: 0;
  font-size: .85em;
  display: inline-block;
  line-height: 1;
  padding: 0 .12em;
}
.legacy-kicker {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .35em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 24px;
  display: inline-flex; align-items: center; gap: 10px;
}
.legacy-kicker::before, .legacy-kicker::after {
  content: "—"; color: var(--accent); opacity: .6;
}
.legacy-body p {
  font-size: 17px; line-height: 1.7;
  color: rgba(232,220,196,.82);
  margin: 0 0 18px;
}
.legacy-body p:first-of-type::first-letter {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: 64px;
  line-height: .85;
  float: left;
  padding: 6px 12px 0 0;
  color: var(--accent);
}
.legacy-signature {
  margin-top: 36px;
  display: flex; align-items: center; gap: 20px;
  padding-top: 24px;
  border-top: 1px solid rgba(184,134,74,.3);
}
.legacy-signature .sig-script {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 28px;
  color: var(--accent-2);
}
.legacy-signature .sig-meta {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .25em;
  text-transform: uppercase; color: var(--fog);
  line-height: 1.6;
}

.legacy-photo {
  position: relative;
}
.legacy-photo .frame {
  aspect-ratio: 3/4;
  background: url(assets/stock-pomada.jpg) center/cover;
  filter: sepia(.25) contrast(1.05);
  position: relative;
}
.legacy-photo .frame::after {
  content: ""; position: absolute; inset: 0;
  box-shadow: inset 0 0 40px rgba(0,0,0,.4);
}
.legacy-photo .frame-border {
  position: absolute; inset: -18px; border: 1px solid var(--accent);
  pointer-events: none;
}
.legacy-photo .corner {
  position: absolute; width: 18px; height: 18px;
  border: 2px solid var(--accent-2);
}
.legacy-photo .corner.tl { top: -26px; left: -26px; border-right: none; border-bottom: none; }
.legacy-photo .corner.tr { top: -26px; right: -26px; border-left: none; border-bottom: none; }
.legacy-photo .corner.bl { bottom: -26px; left: -26px; border-right: none; border-top: none; }
.legacy-photo .corner.br { bottom: -26px; right: -26px; border-left: none; border-top: none; }

.legacy-stamp {
  position: absolute; right: -14px; bottom: -32px;
  width: 128px; height: 128px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--bg);
  display: grid; place-items: center;
  text-align: center;
  transform: rotate(-8deg);
  font-family: var(--font-serif); font-weight: 900;
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
}
.legacy-stamp .n { font-size: 40px; line-height: 1; }
.legacy-stamp .t { font-family: var(--font-mono); font-size: 9px; letter-spacing: .2em; text-transform: uppercase; margin-top: 4px; }

.legacy-stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-top: 80px;
  background: rgba(184,134,74,.2);
}
.legacy-stats .stat {
  background: var(--bg);
  padding: 32px 24px;
  text-align: center;
}
.legacy-stats .n {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(40px, 4.6vw, 68px);
  line-height: 1;
  color: var(--paper);
}
.legacy-stats .n em { font-style: italic; color: var(--accent-2); font-family: "Playfair Display", serif; font-weight: 400; }
.legacy-stats .l {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .28em;
  text-transform: uppercase; color: var(--fog);
  margin-top: 10px;
  max-width: 220px; margin-left: auto; margin-right: auto;
}

/* ============ SECTION: Services ============ */
.services {
  background: var(--paper);
  color: var(--ink);
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  overflow: hidden;
}
.services::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='p'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.5  0 0 0 0 0.4  0 0 0 0 0.3  0 0 0 0.35 0'/></filter><rect width='400' height='400' filter='url(%23p)'/></svg>");
  opacity: .5;
  mix-blend-mode: multiply;
  pointer-events: none;
}

.services-head {
  text-align: center;
  position: relative; z-index: 2;
  margin-bottom: 80px;
}
.services-head .eyebrow { color: var(--oxblood); }
.services-head h2 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(44px, 6vw, 88px);
  line-height: .95;
  margin: 16px 0 0;
  color: var(--ink);
}
.services-head h2 em {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 500;
  color: var(--oxblood);
}
.services-head .sub {
  font-family: var(--font-serif); font-style: italic; font-size: 17px;
  max-width: 560px; margin: 20px auto 0;
  color: rgba(26,20,15,.7);
}

.ticket-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  position: relative; z-index: 2;
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 900px) { .ticket-grid { grid-template-columns: 1fr; max-width: 460px; } }

.ticket {
  background: #f3e9d2;
  color: var(--ink);
  position: relative;
  padding: 40px 28px 28px;
  box-shadow: 0 14px 30px rgba(0,0,0,.18), inset 0 0 0 1px rgba(107,44,31,.1);
  transition: transform .3s ease, box-shadow .3s ease;
  font-family: var(--font-body);
  /* Ticket notch edges (top + bottom perforation) */
  --notch: 10px;
  mask:
    radial-gradient(circle var(--notch) at 24px 0, transparent 98%, #000 100%) top left / 48px 100% repeat-x,
    radial-gradient(circle var(--notch) at 24px 100%, transparent 98%, #000 100%) bottom left / 48px 100% repeat-x,
    linear-gradient(#000 0 0);
  mask-composite: intersect;
}
.ticket:hover { transform: translateY(-6px); box-shadow: 0 24px 50px rgba(0,0,0,.25); }

.ticket-num {
  position: absolute; top: 14px; right: 20px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em;
  color: var(--oxblood); text-transform: uppercase;
}
.ticket-label {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em;
  color: var(--oxblood); text-transform: uppercase;
  margin-bottom: 12px;
  display: flex; align-items: center; gap: 10px;
}
.ticket-label::before { content: ""; width: 18px; height: 1px; background: currentColor; }
.ticket-name {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: 36px; line-height: 1;
  margin-bottom: 8px;
  color: var(--ink);
}
.ticket-name em {
  font-style: italic; font-family: "Playfair Display", serif; font-weight: 400;
  color: var(--oxblood);
}
.ticket-desc {
  font-family: var(--font-serif); font-style: italic;
  font-size: 15px; line-height: 1.55;
  color: rgba(26,20,15,.72);
  margin: 10px 0 22px;
  min-height: 84px;
}
.ticket-divider {
  height: 1px;
  background: repeating-linear-gradient(90deg, var(--oxblood) 0 5px, transparent 5px 10px);
  opacity: .4;
  margin: 0 -28px;
}
.ticket-foot {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 22px;
  gap: 16px;
}
.ticket-time {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(26,20,15,.6);
}
.ticket-price {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900; font-size: 28px;
  color: var(--ink);
}
.ticket-price .currency {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em;
  vertical-align: super; margin-right: 3px;
  color: var(--oxblood);
}

.ticket.featured {
  background: var(--ink);
  color: var(--paper);
  box-shadow: 0 14px 30px rgba(0,0,0,.4);
}
.ticket.featured .ticket-num,
.ticket.featured .ticket-label { color: var(--accent-2); }
.ticket.featured .ticket-name { color: var(--paper); }
.ticket.featured .ticket-name em { color: var(--accent-2); }
.ticket.featured .ticket-desc { color: rgba(232,220,196,.72); }
.ticket.featured .ticket-time { color: rgba(232,220,196,.6); }
.ticket.featured .ticket-price { color: var(--paper); }
.ticket.featured .ticket-price .currency { color: var(--accent-2); }
.ticket.featured .ticket-divider {
  background: repeating-linear-gradient(90deg, var(--accent) 0 5px, transparent 5px 10px);
  opacity: .5;
}

.services-extras {
  max-width: 900px; margin: 56px auto 0;
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 2px;
  position: relative; z-index: 2;
  border: 1px solid rgba(107,44,31,.3);
}
.services-extras .row {
  display: contents;
}
.services-extras .cell {
  background: rgba(243, 233, 210, .7);
  padding: 14px 16px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--ink);
  letter-spacing: .03em;
}
.services-extras .cell.head {
  background: var(--ink); color: var(--paper);
  font-size: 10px; letter-spacing: .25em; text-transform: uppercase;
  padding: 12px 16px;
}
.services-extras .cell.name { grid-column: span 3; font-family: var(--font-serif); font-size: 15px; font-style: italic; }
.services-extras .cell.price { text-align: right; font-weight: 500; }
@media (max-width: 700px) {
  .services-extras { grid-template-columns: 1fr 1fr; }
  .services-extras .cell { font-size: 11px; }
  .services-extras .cell.name { grid-column: span 1; }
}

/* ============ SECTION: Diego (Maestro) ============ */
.maestro {
  background: var(--bg);
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  overflow: hidden;
}
.maestro-vertical {
  position: absolute;
  left: -30px; top: 50%;
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: left center;
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(120px, 20vw, 280px);
  line-height: .8;
  color: rgba(184,134,74,.06);
  white-space: nowrap;
  pointer-events: none;
  letter-spacing: -.02em;
}
.maestro-grid {
  display: grid;
  grid-template-columns: .85fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  position: relative;
}
@media (max-width: 860px) { .maestro-grid { grid-template-columns: 1fr; } }
.maestro-photo {
  position: relative;
  aspect-ratio: 3/4;
  background: url(assets/diego-maestro.jpg) center/cover;
  filter: sepia(.15) contrast(1.05);
  border: 1px solid rgba(184,134,74,.3);
}
.maestro-photo::before {
  content: "";
  position: absolute; inset: 10px;
  border: 1px solid rgba(184,134,74,.5);
  pointer-events: none;
}
.maestro-tag {
  position: absolute; bottom: 24px; left: -24px;
  background: var(--accent);
  color: var(--bg);
  padding: 10px 20px 10px 28px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; text-transform: uppercase;
  font-weight: 600;
  clip-path: polygon(14px 0, 100% 0, 100% 100%, 14px 100%, 0 50%);
}

.maestro h2 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: .95;
  margin: 16px 0 24px;
  color: var(--paper);
}
.maestro h2 em { font-style: italic; color: var(--accent-2); font-weight: 400; font-family: "Playfair Display", serif;}
.maestro-body p { color: rgba(232,220,196,.8); font-size: 16px; line-height: 1.75; margin: 0 0 16px; }
.maestro-quote {
  margin: 32px 0 0;
  padding: 20px 0 20px 26px;
  border-left: 2px solid var(--accent);
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 22px;
  line-height: 1.4;
  color: var(--paper);
}
.maestro-quote::before { content: "“"; font-size: 60px; line-height: 0; vertical-align: -20px; color: var(--accent); margin-right: 6px; }
.maestro-bio {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid rgba(184,134,74,.2);
}
.maestro-bio .item .k {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--fog);
}
.maestro-bio .item .v {
  font-family: var(--font-serif); font-size: 17px; font-weight: 700;
  color: var(--paper); margin-top: 6px;
  font-style: italic;
}
.maestro-bio .item .v span { color: var(--accent-2); font-style: normal; font-family: var(--font-mono); font-size: 13px; margin-left: 4px; }

/* Perico aside */
.perico {
  margin-top: clamp(80px, 8vw, 120px);
  display: grid; grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: center;
  max-width: 820px;
  padding: 28px 32px 28px 28px;
  border: 1px solid rgba(184,134,74,.25);
  background: linear-gradient(135deg, rgba(184,134,74,.05), transparent);
  position: relative;
}
.perico::before {
  content: "✦"; position: absolute; top: -14px; left: 28px;
  background: var(--bg); padding: 0 12px;
  color: var(--accent); font-size: 18px;
}
.perico img {
  width: 140px; height: 140px;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid var(--accent);
  filter: sepia(.1) contrast(1.05);
}
.perico h3 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900; font-size: 28px; margin: 0 0 6px;
  color: var(--paper);
}
.perico h3 em { font-style: italic; font-family: "Playfair Display", serif; font-weight: 400; color: var(--accent-2); }
.perico p {
  font-family: var(--font-serif); font-style: italic;
  font-size: 15px; line-height: 1.55; margin: 0;
  color: rgba(232,220,196,.75);
}
.perico .tag {
  display: inline-block; margin-top: 8px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--accent);
}
@media (max-width: 600px) {
  .perico { grid-template-columns: 1fr; text-align: center; }
  .perico img { margin: 0 auto; }
}

/* ============ SECTION: Gallery ============ */
.gallery {
  background: var(--bg-2);
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  border-top: 1px solid rgba(184,134,74,.12);
  border-bottom: 1px solid rgba(184,134,74,.12);
}
.gallery-head {
  display: flex; align-items: end; justify-content: space-between;
  margin-bottom: 48px;
  gap: 40px;
  flex-wrap: wrap;
}
.gallery-head h2 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: .95;
  margin: 12px 0 0;
  color: var(--paper);
}
.gallery-head h2 em { font-style: italic; color: var(--accent-2); font-weight: 400; font-family: "Playfair Display", serif;}
.gallery-head .sub {
  max-width: 400px;
  font-family: var(--font-serif); font-style: italic;
  color: rgba(232,220,196,.7);
  font-size: 15px;
  line-height: 1.5;
}

.gallery-filters {
  display: flex; gap: 4px;
  margin-bottom: 32px;
  flex-wrap: wrap;
  border: 1px solid rgba(184,134,74,.2);
  padding: 4px;
  width: fit-content;
}
.gallery-filter {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .24em; text-transform: uppercase;
  padding: 10px 16px;
  background: transparent;
  color: rgba(232,220,196,.6);
  border: 0;
  transition: all .2s;
}
.gallery-filter.active {
  background: var(--accent);
  color: var(--bg);
}
.gallery-filter:hover:not(.active) { color: var(--paper); }
.gallery-filter .count {
  margin-left: 8px; opacity: .6; font-size: 9px;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 180px;
  gap: 14px;
}
.gallery-cell {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid rgba(184,134,74,.15);
  background: #2a2420 center/cover;
  transition: transform .4s ease, filter .4s ease;
}
.gallery-cell::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.85) 100%);
}
.gallery-cell:hover { transform: scale(1.02); }
.gallery-cell:hover img { filter: sepia(0); }
.gallery-cell img {
  width: 100%; height: 100%; object-fit: cover;
  filter: sepia(.3) contrast(1.08);
  transition: filter .4s ease;
}
.gallery-cell .ribbon {
  position: absolute; bottom: 12px; left: 12px;
  z-index: 2;
  background: var(--accent);
  color: var(--bg);
  padding: 5px 14px 5px 18px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  font-weight: 600;
  clip-path: polygon(0 0, 100% 0, calc(100% - 8px) 50%, 100% 100%, 0 100%);
}
.gallery-cell .caption {
  position: absolute; top: 12px; right: 12px;
  z-index: 2;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(232,220,196,.8);
}

/* Masonry sizes */
.gal-1x1 { grid-column: span 3; grid-row: span 1; }
.gal-2x1 { grid-column: span 4; grid-row: span 1; }
.gal-1x2 { grid-column: span 3; grid-row: span 2; }
.gal-2x2 { grid-column: span 5; grid-row: span 2; }
.gal-3x2 { grid-column: span 6; grid-row: span 2; }

@media (max-width: 900px) {
  .gallery-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 160px; }
  .gal-1x1 { grid-column: span 3; grid-row: span 1; }
  .gal-2x1 { grid-column: span 6; grid-row: span 1; }
  .gal-1x2 { grid-column: span 3; grid-row: span 2; }
  .gal-2x2 { grid-column: span 6; grid-row: span 2; }
  .gal-3x2 { grid-column: span 6; grid-row: span 2; }
}

.gallery-cta {
  margin-top: 48px; text-align: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .28em; text-transform: uppercase;
}
.gallery-cta a { color: var(--accent-2); border-bottom: 1px solid var(--accent); padding-bottom: 3px; }

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(5,3,2,.94);
  display: grid; place-items: center;
  padding: 40px;
  animation: fade-in .25s ease;
}
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
.lightbox-img {
  max-width: min(90vw, 900px);
  max-height: 85vh;
  position: relative;
}
.lightbox-img img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: sepia(.15) contrast(1.08);
  border: 1px solid var(--accent);
}
.lightbox-caption {
  position: absolute; bottom: -48px; left: 0; right: 0;
  text-align: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--accent-2);
}
.lightbox-close {
  position: absolute; top: 20px; right: 24px;
  background: transparent; border: 1px solid var(--accent);
  width: 42px; height: 42px;
  color: var(--accent-2);
  display: grid; place-items: center;
  font-size: 20px;
}
.lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: transparent; border: 1px solid var(--accent);
  width: 48px; height: 48px;
  color: var(--accent-2);
  display: grid; place-items: center;
  font-family: var(--font-serif); font-size: 22px;
}
.lightbox-nav.prev { left: 24px; }
.lightbox-nav.next { right: 24px; }

/* ============ SECTION: El Gran Bastardo ============ */
.bastardo {
  background: var(--bg);
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  overflow: hidden;
}
.bastardo::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 70% 30%, rgba(184,134,74,.08), transparent 60%);
  pointer-events: none;
}
.bastardo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
  position: relative;
}
@media (max-width: 860px) { .bastardo-grid { grid-template-columns: 1fr; } }

.bastardo-visual {
  position: relative;
  aspect-ratio: 1;
  background: linear-gradient(135deg, #1a120a, #0a0705);
  border: 1px solid rgba(184,134,74,.2);
  display: grid; place-items: center;
}
.bastardo-visual .logo-wrap {
  width: 68%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: url(assets/gran-bastardo-logo.png) center/90% auto no-repeat;
  background-color: #0f0a05;
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
  position: relative;
}
.bastardo-visual .logo-wrap::after {
  content: ""; position: absolute; inset: -8px;
  border: 1px dashed rgba(184,134,74,.5);
  border-radius: 50%;
}

.bastardo-visual .bottle {
  position: absolute;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .24em;
  text-transform: uppercase; color: var(--accent-2);
}
.bastardo-visual .bottle.tl { top: 30px; left: 30px; }
.bastardo-visual .bottle.br { bottom: 30px; right: 30px; text-align: right; }
.bastardo-visual .bottle b { display: block; font-family: var(--font-serif); font-style: italic; font-size: 14px; color: var(--paper); margin-top: 4px; font-weight: 400; }

.bastardo-text h2 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: .9;
  margin: 20px 0 20px;
  color: var(--paper);
}
.bastardo-text h2 em { font-style: italic; font-family: "Playfair Display", serif; font-weight: 400; color: var(--accent-2);}
.bastardo-text p {
  color: rgba(232,220,196,.8);
  font-size: 17px; line-height: 1.7;
  margin: 0 0 18px;
}
.bastardo-text .products {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 32px;
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid rgba(184,134,74,.2);
}
.bastardo-text .products .p {
  font-family: var(--font-serif); font-style: italic;
  font-size: 16px;
  color: var(--paper);
  display: flex; align-items: center; gap: 10px;
}
.bastardo-text .products .p::before {
  content: ""; width: 14px; height: 14px;
  border: 1px solid var(--accent);
  flex: 0 0 14px;
  transform: rotate(45deg);
  display: inline-block;
}
.bastardo-text .cta {
  display: inline-flex; align-items: center; gap: 14px;
  margin-top: 36px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--accent-2);
  padding: 14px 22px;
  border: 1px solid var(--accent);
  transition: all .2s;
}
.bastardo-text .cta:hover { background: var(--accent); color: var(--bg); }
.bastardo-text .cta::after { content: "→"; font-size: 14px; }

/* ============ SECTION: Horarios + contacto ============ */
.visit {
  background: var(--bg-2);
  color: var(--paper);
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  border-top: 1px solid rgba(184,134,74,.2);
  overflow: hidden;
}

.visit-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
}
@media (max-width: 860px) { .visit-grid { grid-template-columns: 1fr; } }

.visit h2 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: .95;
  margin: 16px 0 32px;
  color: var(--paper);
}
.visit h2 em { font-style: italic; font-family: "Playfair Display", serif; font-weight: 400; color: var(--accent-2);}

.hours-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 28px;
}
.hours-table tr {
  border-bottom: 1px dashed rgba(184,134,74,.25);
}
.hours-table tr:last-child { border-bottom: 0; }
.hours-table tr.today {
  background: linear-gradient(90deg, rgba(184,134,74,.12), transparent);
}
.hours-table td {
  padding: 16px 4px;
  font-family: var(--font-mono);
  letter-spacing: .05em;
}
.hours-table td.day {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 24px;
  font-weight: 600;
  color: var(--paper);
  letter-spacing: 0;
  width: 40%;
}
.hours-table tr.today td.day { color: var(--accent-2); }
.hours-table tr.today td.day::after {
  content: "HOY"; display: inline-block;
  margin-left: 12px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em;
  padding: 3px 8px;
  background: var(--accent); color: var(--bg);
  vertical-align: 4px;
}
.hours-table td.times {
  text-align: right;
  font-size: 14px;
  color: rgba(232,220,196,.75);
}
.hours-table td.closed { color: rgba(232,220,196,.3); font-style: italic; }
.hours-table td.times .slot {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid rgba(184,134,74,.3);
  margin-left: 6px;
  font-size: 13px;
}

.visit-status {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px;
  border: 1px solid var(--accent);
  color: var(--accent-2);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .24em;
  text-transform: uppercase;
  margin-top: 40px;
}
.visit-status .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #6abf6a;
  box-shadow: 0 0 0 4px rgba(106,191,106,.2);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(106,191,106,.2); }
  50% { box-shadow: 0 0 0 8px rgba(106,191,106,0); }
}

.visit-side {
  background: var(--bg-3);
  padding: 40px 36px;
  border: 1px solid rgba(184,134,74,.2);
  position: relative;
}
.visit-side::before {
  content: "⚓"; position: absolute; top: -16px; left: 32px;
  background: var(--bg-2); padding: 0 12px;
  color: var(--accent); font-size: 20px;
}
.visit-side .kicker {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 20px;
}
.visit-side .addr {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900; font-size: 32px; line-height: 1.05;
  color: var(--paper);
  margin: 0 0 4px;
}
.visit-side .addr em { font-family: "Playfair Display", serif; font-style: italic; font-weight: 400; color: var(--accent-2); }
.visit-side .city {
  font-family: var(--font-serif); font-style: italic;
  font-size: 17px;
  color: rgba(232,220,196,.7);
  margin-bottom: 24px;
}
.visit-side .map {
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, #1a1510 0%, #0f0c08 100%);
  margin-top: 8px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(184,134,74,.25);
}
.visit-contact {
  margin-top: 24px;
  display: grid; gap: 10px;
}
.visit-contact .row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(184,134,74,.2);
}
.visit-contact .k {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--fog);
}
.visit-contact .v {
  font-family: var(--font-serif); font-style: italic; font-size: 16px; color: var(--paper);
}

/* ============ BOOKING CTA strip ============ */
.booking {
  background: var(--paper);
  color: var(--ink);
  padding: clamp(60px, 8vw, 100px) 0;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.booking::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='p'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.5  0 0 0 0 0.4  0 0 0 0 0.3  0 0 0 0.35 0'/></filter><rect width='400' height='400' filter='url(%23p)'/></svg>");
  opacity: .45;
  mix-blend-mode: multiply;
  pointer-events: none;
}
.booking-inner { position: relative; z-index: 2; }
.booking .eyebrow { color: var(--oxblood); }
.booking h2 {
  font-family: var(--h-font, var(--font-serif));
  font-weight: 900;
  font-size: clamp(42px, 6vw, 84px);
  line-height: .9;
  margin: 16px auto 22px;
  color: var(--ink);
  max-width: 12ch;
}
.booking h2 em { font-family: "Cormorant Garamond", serif; font-style: italic; font-weight: 500; color: var(--oxblood); }
.booking p {
  max-width: 520px; margin: 0 auto 32px;
  font-family: var(--font-serif); font-style: italic; font-size: 18px;
  color: rgba(26,20,15,.7);
}
.booking .btns {
  display: inline-flex; gap: 16px; flex-wrap: wrap; justify-content: center;
}
.booking a.primary {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--ink);
  color: var(--paper);
  padding: 16px 28px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .26em; text-transform: uppercase;
  transition: transform .2s, background .2s;
  border: 1px solid var(--ink);
}
.booking a.primary:hover { transform: translateY(-2px); background: var(--oxblood); border-color: var(--oxblood); }
.booking a.secondary {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--ink);
  padding: 16px 28px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .26em; text-transform: uppercase;
  border: 1px solid var(--ink);
  transition: all .2s;
}
.booking a.secondary:hover { background: var(--ink); color: var(--paper); }

/* ============ FOOTER ============ */
.footer {
  background: var(--bg);
  color: rgba(232,220,196,.6);
  padding: 80px 0 32px;
  border-top: 1px solid rgba(184,134,74,.2);
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 56px;
}
@media (max-width: 860px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer h4 {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--accent);
  margin: 0 0 18px;
}
.footer a, .footer .item {
  display: block;
  font-family: var(--font-serif); font-style: italic;
  font-size: 15px; color: rgba(232,220,196,.75);
  margin-bottom: 10px;
  transition: color .2s;
}
.footer a:hover { color: var(--accent-2); }
.footer-brand .mark {
  font-family: "Playfair Display", serif; font-style: italic; font-weight: 900;
  font-size: 40px; color: var(--accent-2);
  margin-bottom: 12px;
}
.footer-brand p {
  font-family: var(--font-serif); font-style: italic; font-size: 15px;
  line-height: 1.55;
  color: rgba(232,220,196,.7);
  max-width: 380px;
}
.footer-bottom {
  padding-top: 24px;
  border-top: 1px solid rgba(184,134,74,.15);
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--fog);
  flex-wrap: wrap; gap: 12px;
}

/* ============ FLOATING WHATSAPP ============ */
.fab-wa {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 90;
  display: flex; align-items: center; gap: 12px;
  background: #25d366;
  color: #0a2618;
  padding: 0;
  border-radius: 999px;
  box-shadow: 0 14px 30px rgba(0,0,0,.35), 0 4px 10px rgba(0,0,0,.25);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  font-weight: 600;
  border: 2px solid #14532d;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
  text-decoration: none;
}
.fab-wa:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 18px 40px rgba(0,0,0,.45); }
.fab-wa .icon {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  flex: 0 0 56px;
}
.fab-wa .txt {
  padding-right: 22px;
  max-width: 220px;
  line-height: 1.2;
}
.fab-wa .txt .s {
  display: block;
  font-family: var(--font-serif); font-style: italic;
  font-size: 11px; letter-spacing: 0; text-transform: none;
  opacity: .7;
  font-weight: 400;
}
.fab-wa::after {
  content: "";
  position: absolute; inset: -4px;
  border-radius: 999px;
  border: 2px solid rgba(37, 211, 102, .4);
  animation: ring 2.2s ease-out infinite;
}
@keyframes ring {
  0% { transform: scale(.95); opacity: .9; }
  100% { transform: scale(1.3); opacity: 0; }
}
@media (max-width: 700px) {
  .fab-wa .txt { display: none; }
  .fab-wa { padding: 0; }
}

/* ============ Reveal animations ============ */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1);
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal.d1 { transition-delay: .1s; }
.reveal.d2 { transition-delay: .2s; }
.reveal.d3 { transition-delay: .3s; }
.reveal.d4 { transition-delay: .4s; }

/* ============ Section divider ============ */
.divider {
  display: flex; align-items: center; justify-content: center;
  padding: 0 0 0;
  gap: 20px;
  color: var(--accent);
}
.divider .line {
  height: 1px; background: currentColor; flex: 0 0 100px; opacity: .4;
}
.divider .anchor { font-size: 20px; }
