/* ============================================================
   SANTIAGO NAZARENO — Bass Player, Córdoba
   Design system + 3 switchable directions
   ============================================================ */

/* ---------- Base tokens (shared) ---------- */
:root{
  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 72px);

  /* These three are overridden per-direction + by Tweaks */
  --bg:        #f7f4ee;
  --paper:     #fffdf8;
  --ink:       #211c17;
  --ink-soft:  #6b6258;
  --line:      #e4ddd1;
  --accent:    #e6452f;
  --accent-ink:#ffffff;

  --font-display: "Anton", sans-serif;
  --font-serif:   "DM Serif Display", serif;
  --font-body:    "Work Sans", sans-serif;

  --display-spacing: -0.01em;
  --display-transform: uppercase;
  --display-weight: 400;
  --display-line: 0.92;
}

/* ============================================================
   DIRECTION 1 — "MARQUEE"  (poster energy, vermillion)
   ============================================================ */
[data-direction="marquee"]{
  --bg:#f5f1e8; --paper:#fffdf7; --ink:#1d1813; --ink-soft:#6f655a;
  --line:#e2dac9; --accent:#e6452f; --accent-ink:#fffaf4;
  --font-display:"Anton", sans-serif;
  --font-serif:"DM Serif Display", serif;
  --font-body:"Work Sans", sans-serif;
  --display-transform: uppercase;
  --display-spacing:-0.005em;
  --display-weight:400;
  --display-line:0.9;
}

/* ============================================================
   DIRECTION 2 — "SOUL"  (editorial serif, terracotta, airy)
   ============================================================ */
[data-direction="soul"]{
  --bg:#f3ece1; --paper:#fbf6ee; --ink:#26201a; --ink-soft:#7a6f62;
  --line:#e6dccb; --accent:#c5642e; --accent-ink:#fdf6ee;
  --font-display:"DM Serif Display", serif;
  --font-serif:"DM Serif Display", serif;
  --font-body:"Work Sans", sans-serif;
  --display-transform: none;
  --display-spacing:-0.015em;
  --display-weight:400;
  --display-line:1.0;
}

/* ============================================================
   DIRECTION 3 — "ENCORE"  (high-contrast modern grotesk)
   ============================================================ */
[data-direction="encore"]{
  --bg:#efede8; --paper:#ffffff; --ink:#16130f; --ink-soft:#615a52;
  --line:#ddd8cf; --accent:#d23a1f; --accent-ink:#fff7f2;
  --font-display:"Archivo", sans-serif;
  --font-serif:"DM Serif Display", serif;
  --font-body:"Archivo", sans-serif;
  --display-transform: uppercase;
  --display-spacing:-0.03em;
  --display-weight:900;
  --display-line:0.88;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}

.display{
  font-family:var(--font-display);
  font-weight:var(--display-weight);
  text-transform:var(--display-transform);
  letter-spacing:var(--display-spacing);
  line-height:var(--display-line);
}

.wrap{max-width:var(--maxw); margin:0 auto; padding-left:var(--gut); padding-right:var(--gut);}

/* ---------- Eyebrow / labels ---------- */
.eyebrow{
  font-family:var(--font-body);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.22em;
  font-size:12px;
  color:var(--accent);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; width:26px; height:2px; background:var(--accent); display:inline-block;
}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  mix-blend-mode:normal;
  transition:background .3s, border-color .3s, padding .3s;
  border-bottom:1px solid transparent;
}
/* over the hero photo → light chrome */
.topbar .brand{color:#fff;}
.topbar .nav a{color:rgba(255,255,255,.82);}
.topbar .nav a:hover{color:#fff;}
.topbar .nav-toggle span{background:#fff;}
.topbar.scrolled{
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding-top:13px; padding-bottom:13px;
}
.topbar.scrolled .brand{color:var(--ink);}
.topbar.scrolled .nav a{color:var(--ink-soft);}
.topbar.scrolled .nav a:hover{color:var(--ink);}
.topbar.scrolled .nav-toggle span{background:var(--ink);}
.brand{
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:0.02em;
  font-size:20px;
  font-weight:var(--display-weight);
  display:flex; align-items:center; gap:11px;
}
.brand .dot{width:9px; height:9px; border-radius:50%; background:var(--accent); flex:none;}
.nav{display:flex; align-items:center; gap:30px;}
.nav a{font-size:13px; font-weight:600; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-soft); transition:color .2s;}
.nav a:hover{color:var(--ink);}
.nav .btn-book{
  background:var(--accent); color:var(--accent-ink);
  padding:10px 18px; border-radius:100px; font-size:12px; letter-spacing:0.08em;
  white-space:nowrap;
}
.nav .btn-book:hover{color:var(--accent-ink); filter:brightness(.94);}
.nav-toggle{display:none;}

/* right cluster: nav + language switch + mobile toggle */
.top-right{display:flex; align-items:center; gap:22px;}

/* language switch — two simple pills, EN / ES */
.lang-switch{
  display:flex; align-items:center; gap:2px;
  padding:3px; border-radius:100px;
  border:1px solid rgba(255,255,255,.28);
}
.lang-switch button{
  font-family:var(--font-display, inherit);
  font-size:11px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase;
  line-height:1; cursor:pointer; border:none; background:none;
  color:rgba(255,255,255,.7); padding:6px 9px; border-radius:100px;
  transition:color .2s, background .2s;
}
.lang-switch button:hover{color:#fff;}
.lang-switch button.active{background:var(--accent); color:var(--accent-ink);}
/* scrolled → dark chrome */
.topbar.scrolled .lang-switch{border-color:var(--line);}
.topbar.scrolled .lang-switch button{color:var(--ink-soft);}
.topbar.scrolled .lang-switch button:hover{color:var(--ink);}
.topbar.scrolled .lang-switch button.active{background:var(--accent); color:var(--accent-ink);}

/* ============================================================
   HERO  — full-bleed photo background, copy overlaid
   ============================================================ */
.hero{
  position:relative;
  min-height:min(92vh, 860px);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  background:var(--ink);
}
/* full-bleed image */
.hero-bg{
  position:absolute !important;
  inset:0;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  z-index:0;
  filter:brightness(1.12) contrast(1.03) saturate(1.05);
}
.hero-bg img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  display:block;
}
/* legibility scrim — darker bottom-left where the copy sits */
.hero-scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(to top, rgba(10,7,5,.74) 0%, rgba(10,7,5,.24) 30%, rgba(10,7,5,0) 56%),
    linear-gradient(to right, rgba(10,7,5,.40) 0%, rgba(10,7,5,.04) 42%, transparent 66%);
}
.hero-inner{
  position:relative; z-index:2; width:100%;
  padding-top:clamp(140px, 22vh, 240px);
  padding-bottom:clamp(40px, 7vh, 80px);
}
.hero-kicker{margin-bottom:22px; color:#fff;}
.hero-kicker::before{background:var(--accent);}
.hero h1{
  font-size:clamp(52px, 9vw, 132px);
  margin:0 0 8px;
  color:#fdfaf5;
  text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.hero h1 .line2{color:var(--accent); text-shadow:0 2px 30px rgba(0,0,0,.45);}
.hero-sub{
  font-size:clamp(17px,1.5vw,21px);
  color:rgba(255,255,255,.82);
  max-width:34ch;
  margin:22px 0 34px;
  line-height:1.5;
}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px; align-items:center;}
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-weight:600; font-size:15px; letter-spacing:0.01em;
  padding:15px 26px; border-radius:100px; cursor:pointer; border:1.5px solid transparent;
  transition:transform .15s, background .2s, color .2s, border-color .2s;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--accent); color:var(--accent-ink);}
.btn-primary:hover{filter:brightness(.93);}
.btn-ghost{border-color:var(--ink); color:var(--ink); background:transparent;}
.btn-ghost:hover{background:var(--ink); color:var(--bg);}
/* ghost button sits on the photo in the hero → light treatment */
.hero-cta .btn-ghost{border-color:rgba(255,255,255,.6); color:#fff;}
.hero-cta .btn-ghost:hover{background:#fff; color:var(--ink);}
.arrow{font-size:18px; line-height:1;}

.hero-badge{
  position:absolute; right:0; top:clamp(140px,22vh,240px);
  background:var(--accent); color:var(--accent-ink);
  font-family:var(--font-display); text-transform:uppercase;
  letter-spacing:0.04em;
  padding:14px 20px; font-size:clamp(15px,1.4vw,19px);
  display:flex; align-items:center; gap:12px;
  box-shadow:0 20px 40px -20px rgba(0,0,0,.5);
}
.hero-badge .big{color:var(--accent-ink); font-size:1.6em; line-height:.8;}

/* marquee strip under hero */
.marquee{
  position:relative; z-index:2;
  border-top:1.5px solid rgba(255,255,255,.18); border-bottom:0;
  overflow:hidden; white-space:nowrap;
  background:var(--ink); color:var(--bg);
}
.marquee-track{display:inline-flex; gap:0; animation:scroll 28s linear infinite;}
.marquee-track span{
  font-family:var(--font-display); text-transform:uppercase;
  font-size:clamp(22px,2.6vw,34px); padding:14px 0; letter-spacing:0.02em;
  display:inline-flex; align-items:center;
}
.marquee-track span::after{content:"●"; color:var(--accent); font-size:.5em; margin:0 28px; vertical-align:middle;}
@keyframes scroll{from{transform:translateX(0);} to{transform:translateX(-50%);}}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{position:relative;}
.section-pad{padding:clamp(64px,10vh,130px) 0;}
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:24px; margin-bottom:clamp(34px,5vh,60px); flex-wrap:wrap;
}
.section-head h2{
  font-size:clamp(36px,6vw,82px); max-width:14ch;
}
.section-head .lead{max-width:34ch; color:var(--ink-soft); font-size:17px;}
.section-num{
  font-family:var(--font-body); font-weight:700; color:var(--accent);
  font-size:13px; letter-spacing:0.2em;
}

/* ============================================================
   ABOUT
   ============================================================ */
.about{background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.about-grid{display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(30px,6vw,80px); align-items:center;}
.about-photo picture{ display:block; width:100%; }
.about-photo picture img{ width:100%; height:auto; aspect-ratio:2/3; object-fit:cover; object-position:top; border:1px solid var(--line); display:block; }
.about-body p{font-size:clamp(18px,1.7vw,22px); line-height:1.6; margin-bottom:22px; color:var(--ink); text-wrap:pretty;}
.about-body p .hl{color:var(--accent); font-weight:600;}
.about-sign{font-family:var(--font-serif); font-size:30px; margin-top:8px;}
.stats{display:flex; gap:38px; margin-top:36px; flex-wrap:wrap;}
.stat .n{font-family:var(--font-display); font-size:clamp(38px,4vw,58px); line-height:1; color:var(--ink);}
.stat .l{font-size:12px; text-transform:uppercase; letter-spacing:0.12em; color:var(--ink-soft); margin-top:8px;}

/* ============================================================
   SAMPLES (audio/video placeholders)
   ============================================================ */
/* ============================================================
   VIDEOS  (YouTube click-to-play facades)
   ============================================================ */
.videos-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px;}
.video{
  position:relative; aspect-ratio:16/9; overflow:hidden;
  border:1px solid var(--line); background:var(--ink);
  cursor:pointer; transition:border-color .2s, transform .2s, box-shadow .2s;
}
.video.wide{grid-column:span 2; aspect-ratio:21/8;}
.video:hover{border-color:var(--accent); transform:translateY(-3px); box-shadow:0 24px 50px -28px rgba(0,0,0,.5);}
.video-thumb{
  position:absolute; inset:0; background-size:cover; background-position:center;
  background-color:var(--ink);
}
.video-thumb::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(8,6,4,.78) 0%, rgba(8,6,4,.10) 46%, rgba(8,6,4,.18) 100%);
  transition:background .25s;
}
.video:hover .video-thumb::after{background:linear-gradient(to top, rgba(8,6,4,.80) 0%, rgba(8,6,4,.22) 55%, rgba(8,6,4,.28) 100%);}
.video-play{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:66px; height:66px; border-radius:50%; border:0; cursor:pointer;
  background:var(--accent); color:var(--accent-ink);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; padding-left:5px; z-index:2;
  box-shadow:0 12px 30px -10px rgba(0,0,0,.5);
  transition:transform .2s, filter .2s;
}
.video:hover .video-play{transform:translate(-50%,-50%) scale(1.08); filter:brightness(1.05);}
.video-meta{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
  padding:18px 20px; pointer-events:none;
}
.video-meta .t{
  font-family:var(--font-display); text-transform:uppercase; color:#fff;
  font-size:clamp(15px,1.5vw,21px); line-height:1.04; letter-spacing:0.01em;
  text-shadow:0 1px 12px rgba(0,0,0,.5);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.video.wide .video-meta .t{font-size:clamp(18px,2vw,28px);}
.video-meta .d{
  font-size:11px; color:rgba(255,255,255,.7); font-family:monospace;
  letter-spacing:0.12em; text-transform:uppercase; flex:none; white-space:nowrap;
}
.video iframe{position:absolute; inset:0; width:100%; height:100%; border:0; z-index:3;}
.video.playing .video-play,.video.playing .video-meta,.video.playing .video-thumb{display:none;}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px;
}
.gallery-grid picture{width:100%; height:100%; border:1px solid var(--line); display:block; overflow:hidden;}
.gallery-grid picture img{width:100%; height:100%; object-fit:cover; display:block;}
.g-tall{grid-row:span 2;}
.g-wide{grid-column:span 2;}
.g-big{grid-column:span 2; grid-row:span 2;}

/* ============================================================
   EXPERIENCE / CREDITS
   ============================================================ */
.exp{background:var(--ink); color:var(--bg);}
.exp .eyebrow{color:var(--accent);}
.exp .section-head h2{color:var(--bg);}
.exp .section-head .lead{color:color-mix(in srgb, var(--bg) 70%, transparent);}
.credits{border-top:1px solid color-mix(in srgb,var(--bg) 18%, transparent);}
.credit-row{
  display:grid; grid-template-columns:0.5fr 1.3fr 1fr; gap:24px; align-items:center;
  padding:26px 4px; border-bottom:1px solid color-mix(in srgb,var(--bg) 18%, transparent);
  transition:padding-left .25s, background .25s;
}
.credit-row:hover{padding-left:18px; background:color-mix(in srgb,var(--bg) 6%, transparent);}
.credit-row .yr{font-family:monospace; color:var(--accent); font-size:14px; letter-spacing:0.04em;}
.credit-row .ti{font-family:var(--font-display); text-transform:uppercase; font-size:clamp(20px,2vw,30px); line-height:1; letter-spacing:0.01em;}
.credit-row .ro{color:color-mix(in srgb,var(--bg) 72%, transparent); font-size:15px;}
.exp-tags{display:flex; flex-wrap:wrap; gap:10px; margin-top:40px;}
.exp-tags span{
  border:1px solid color-mix(in srgb,var(--bg) 30%, transparent); color:var(--bg);
  padding:9px 16px; border-radius:100px; font-size:13px; letter-spacing:0.03em;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:var(--paper); border-top:1px solid var(--line);}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,72px);}
.contact h2{font-size:clamp(44px,8vw,108px); margin-bottom:18px;}
.contact .lead{color:var(--ink-soft); font-size:19px; max-width:32ch; margin-bottom:32px;}
.contact-list{display:flex; flex-direction:column; gap:2px; margin-top:10px;}
.contact-list a{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0; border-top:1px solid var(--line); font-size:17px; transition:color .2s;
}
.contact-list a:last-child{border-bottom:1px solid var(--line);}
.contact-list a .k{font-weight:600; text-transform:uppercase; letter-spacing:0.08em; font-size:12px; color:var(--ink-soft);}
.contact-list a:hover{color:var(--accent);}
.contact-list a:hover .k{color:var(--accent);}

form.booking{display:flex; flex-direction:column; gap:16px;}
.field{display:flex; flex-direction:column; gap:7px;}
.field label{font-size:12px; text-transform:uppercase; letter-spacing:0.1em; font-weight:600; color:var(--ink-soft);}
.field input, .field select, .field textarea{
  font-family:inherit; font-size:16px; color:var(--ink);
  background:var(--bg); border:1px solid var(--line); border-radius:10px;
  padding:13px 15px; transition:border-color .2s, box-shadow .2s;
  width:100%;
  min-width:0;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%, transparent);
}
.field textarea{resize:vertical; min-height:96px;}
.field.row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.form-note{font-size:13px; color:var(--ink-soft);}
.form-ok{
  display:none; padding:16px 18px; border-radius:10px; background:color-mix(in srgb,var(--accent) 12%, var(--paper));
  border:1px solid var(--accent); color:var(--ink); font-size:15px;
}
.form-ok.show{display:block;}

/* ============================================================
   INSTAGRAM
   ============================================================ */
.ig{
  text-align:center;
  position:relative;
  background:#1a1240 url("assets/feed-bg.png") center/cover no-repeat;
  isolation:isolate;
}
/* soft dark wash so white type stays legible over the brighter cyan areas */
.ig::before{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:linear-gradient(to bottom, rgba(8,6,30,.30) 0%, rgba(8,6,30,.12) 40%, rgba(8,6,30,.45) 100%);
}
.ig .eyebrow{justify-content:center; display:flex; color:#fff;}
.ig .eyebrow::before{background:#fff;}
.ig h2{font-size:clamp(40px,7vw,96px); margin:18px 0 10px; color:#fff; text-shadow:0 2px 24px rgba(0,0,0,.30);}
.ig .handle{font-size:20px; color:rgba(255,255,255,.85); margin-bottom:36px;}
.ig .handle a{color:#fff; font-weight:600; text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:2px; text-decoration-color:rgba(255,255,255,.55);}
.ig .handle a:hover{text-decoration-color:#fff;}
.ig-strip{display:grid; grid-template-columns:repeat(6,1fr); gap:10px;}
.ig-strip a{display:block; overflow:hidden; border:1px solid rgba(255,255,255,.25); aspect-ratio:1; transition:border-color .2s, transform .2s;}
.ig-strip a:hover{border-color:var(--accent); transform:translateY(-3px);}
.ig-strip picture{display:block; width:100%; height:100%;}
.ig-strip img{width:100%; height:100%; object-fit:cover; display:block;}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--ink); color:var(--bg); padding:60px var(--gut) 40px;}
.foot-grid{max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap;}
.foot-brand{font-family:var(--font-display); text-transform:uppercase; font-size:clamp(40px,7vw,90px); line-height:0.9; letter-spacing:0.01em;}
.foot-brand .accent{color:var(--accent);}
.foot-meta{font-size:13px; color:color-mix(in srgb,var(--bg) 64%, transparent); line-height:1.8; text-align:right;}
.foot-meta a:hover{color:var(--accent);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* Form inputs never overflow their container */
.field input,
.field select,
.field textarea{
  width: 100%;
  min-width: 0;
}

/* Prevent horizontal overflow at container level.
   overflow-x:clip (not hidden) avoids the implicit overflow-y:auto side-effect
   that would create an unwanted internal scrollbar on the gallery section. */
.wrap,
.contact-grid{
  overflow-x: clip;
}

@media (max-width: 900px){
  /* ---- layout ---- */
  .hero{min-height:min(88vh, 720px);}
  .hero-sub{max-width:30ch;}
  .hero-badge{display:none;}
  .about-grid{grid-template-columns:1fr; gap:34px;}
  .about-photo{max-width:380px;}
  .videos-grid{grid-template-columns:1fr;}
  .video.wide{grid-column:span 1; aspect-ratio:16/9;}
  .gallery-grid{grid-template-columns:repeat(2,1fr); grid-auto-rows:160px;}
  .contact-grid{grid-template-columns:1fr;}
  .ig-strip{grid-template-columns:repeat(3,1fr);}

  /* ---- nav ---- */
  .top-right{gap:12px;}
  .nav{display:none;}
  .nav.open{
    display:flex; position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:var(--paper); border-bottom:1px solid var(--line); padding:8px var(--gut) 18px;
  }
  .nav.open a{padding:14px 0; border-bottom:1px solid var(--line); width:100%;}
  .nav.open .btn-book{margin-top:12px; text-align:center; justify-content:center;}
  .topbar .nav.open a{color:var(--ink);}
  .nav-toggle{display:flex; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px;}
  .nav-toggle span{width:26px; height:2px; display:block;}

  /* ---- form ---- */
  .field.row{ grid-template-columns: 1fr; }

  /* ---- 1) HERO TITLE — dominant, large, wraps naturally ---- */
  .hero h1{
    font-size: clamp(36px, 10vw, 72px);
    line-height: 1.05;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  /* ---- 2) SECTION TITLES — large, ~80% width ---- */
  .section-head h2{
    font-size: clamp(28px, 8vw, 48px);
    max-width: 80vw;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    line-height: 1;
  }

  /* ---- 3) TRAYECTORIA & FORMACIÓN — tighter spacing ---- */
  .section-pad{ padding: 48px 0; }
  .credits{ gap: 0; }
  .credit-row{
    grid-template-columns: 0.4fr 1.4fr;
    gap: 10px;
    padding: 10px 0;
  }
  .credit-row .ro{
    grid-column: 2;
    color: color-mix(in srgb,var(--bg) 60%, transparent);
    font-size: 13px;
  }
  .exp-tags{ margin-top: 24px; gap: 8px; }

  /* ---- 4) FOOTER — two columns side by side ---- */
  .foot-grid{
    flex-wrap: nowrap;
    align-items: flex-start;
  }
  .foot-brand{ font-size: clamp(32px, 8vw, 56px); flex: 1; }
  .foot-meta{ flex: 1; text-align: right; }
}
@media (max-width:560px){
  .gallery-grid{grid-template-columns:1fr 1fr; grid-auto-rows:130px;}
  .stats{gap:26px;}
}
