/* ============================================================
   DRIFTCREST — Guitarist site
   Design tokens, base, layout, components
   ============================================================ */

/* ---------- Fonts (loaded via <link> in HTML head for faster, non-blocking load) ---------- */

/* ---------- Tokens ---------- */
:root {
  /* surfaces */
  --bg:        #0a0a0b;
  --bg-1:      #0e0e10;
  --bg-2:      #141417;
  --bg-3:      #1b1b1f;
  --line:      rgba(255,255,255,0.08);
  --line-2:    rgba(255,255,255,0.14);

  /* text */
  --ink:       #f4f1ea;
  --ink-soft:  #c2beb4;
  --ink-mute:  #948f86;
  --ink-faint: #6d695f;

  /* accent — switchable via [data-accent] */
  --accent:    #d9a441;
  --accent-ink:#0a0a0b;
  --accent-glow: rgba(217,164,65,0.18);

  /* type */
  --display: 'Bricolage Grotesque', system-ui, sans-serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;

  /* rhythm */
  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 80px);
  --section-y: clamp(80px, 12vw, 180px);

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* Accent themes (switcher) */
[data-accent="ember"]  { --accent:#d9a441; --accent-glow:rgba(217,164,65,0.18); }
[data-accent="coral"]  { --accent:#e8643c; --accent-glow:rgba(232,100,60,0.18); }
[data-accent="teal"]   { --accent:#3fb6a3; --accent-glow:rgba(63,182,163,0.18); }
[data-accent="bone"]   { --accent:#e7e2d6; --accent-glow:rgba(231,226,214,0.14); --accent-ink:#0a0a0b; }

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; margin:0; padding:0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Film-grain overlay for the whole page */
body::after {
  content:"";
  position: fixed; inset:0;
  pointer-events:none; z-index: 9000;
  opacity:.05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img { display:block; max-width:100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border:none; background:none; color:inherit; }
::selection { background: var(--accent); color: var(--accent-ink); }

/* Skip link (keyboard / screen-reader) */
.skip-link {
  position: fixed; top: 10px; left: 10px; z-index: 10000;
  background: var(--accent); color: var(--accent-ink);
  padding: 12px 20px; border-radius: 10px; font-weight: 600; font-size: 15px;
  transform: translateY(-150%); transition: transform .25s var(--ease);
}
.skip-link:focus { transform: none; outline: none; }

/* Visible focus ring for keyboard users everywhere */
a:focus-visible, button:focus-visible, [tabindex]:focus-visible,
input:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px;
}
:focus:not(:focus-visible) { outline: none; }

/* ---------- Utilities ---------- */
.wrap { width:100%; max-width: var(--maxw); margin-inline:auto; padding-inline: var(--pad); }
.eyebrow {
  font-size: 12px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--ink-mute); font-weight: 600;
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before { content:""; width:28px; height:1px; background: var(--accent); display:inline-block; }
.section-y { padding-block: var(--section-y); }
section[id], header[id] { scroll-margin-top: 76px; }

/* scroll reveal */
.reveal { opacity:0; transform: translateY(28px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; } }

/* ---------- Buttons ---------- */
.btn {
  position: relative; overflow: hidden;
  display:inline-flex; align-items:center; gap:.6em;
  padding: 15px 26px; border-radius: 100px;
  font-weight: 600; font-size: 15px; letter-spacing:.01em;
  transition: transform .4s var(--ease), background .3s, color .3s, border-color .3s;
  will-change: transform;
}
.btn svg { width:17px; height:17px; }
.btn--primary { background: var(--accent); color: var(--accent-ink); }
.btn--primary:hover { transform: translateY(-2px); }
.btn--ghost { border:1px solid var(--line-2); color: var(--ink); }
.btn--ghost:hover { border-color: var(--ink); transform: translateY(-2px); background: rgba(255,255,255,.03); }
/* ripple */
.btn .ripple { position:absolute; border-radius:50%; transform: scale(0); background: rgba(255,255,255,.35); pointer-events:none; animation: ripple .6s var(--ease); }
.btn--primary .ripple { background: rgba(0,0,0,.18); }
@keyframes ripple { to { transform: scale(2.6); opacity:0; } }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top:0; left:0; right:0; z-index: 1000;
  display:flex; align-items:center; justify-content:space-between;
  padding: 22px var(--pad);
  transition: padding .4s var(--ease), background .4s, backdrop-filter .4s, border-color .4s;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  padding-block: 14px;
  background: rgba(10,10,11,.72);
  backdrop-filter: blur(18px) saturate(1.2);
  border-bottom: 1px solid var(--line);
}
.nav__brand { font-family: var(--display); font-weight: 700; font-size: 19px; letter-spacing:-.02em; }
.nav__brand .dot { color: var(--accent); }
.nav__links { display:flex; align-items:center; gap: 38px; }
.nav__links a:not(.btn) {
  font-size: 14px; color: var(--ink-soft); font-weight:500; position:relative; padding-block:4px;
}
.nav__links a:not(.btn)::after {
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background: var(--accent);
  transition: width .4s var(--ease);
}
.nav__links a:not(.btn):hover { color: var(--ink); }
.nav__links a:not(.btn):hover::after { width:100%; }
.nav__burger { display:none; flex-direction:column; gap:5px; padding:8px; }
.nav__burger span { width:24px; height:2px; background: var(--ink); transition: .3s var(--ease); }

@media (max-width: 860px){
  .nav__links { position: fixed; inset:0; flex-direction:column; justify-content:center; gap:30px;
    background: rgba(8,8,9,.97); backdrop-filter: blur(10px);
    transform: translateY(-100%); transition: transform .5s var(--ease); }
  .nav__links.open { transform:none; }
  .nav__links a:not(.btn){ font-size: 26px; font-family: var(--display); }
  .nav__burger { display:flex; z-index: 1100; }
  .nav__burger.open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
  .nav__burger.open span:nth-child(2){ opacity:0; }
  .nav__burger.open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }
}

/* ============================================================
   HERO  (3 directions via [data-hero])
   ============================================================ */
.hero { position: relative; min-height: 100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__bg { position:absolute; inset:0; z-index:0; }

/* photo layer — image set per [data-hero] direction below */
.hero__photo {
  position:absolute; inset:0;
  background: linear-gradient(160deg, #17171a, #0b0b0d 70%);
  background-size: cover; background-position: center 42%;
}
.hero__scrim {
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(10,10,11,.74) 0%, rgba(10,10,11,.5) 32%, rgba(10,10,11,.42) 52%, rgba(10,10,11,.86) 82%, var(--bg) 100%),
    linear-gradient(75deg, rgba(10,10,11,.66) 0%, rgba(10,10,11,.14) 44%, transparent 66%);
}

.hero__inner { position: relative; z-index:2; width:100%; padding-bottom: clamp(60px, 10vh, 130px); }
.hero__tag { margin-bottom: 26px; text-shadow: 0 1px 16px rgba(0,0,0,.55); }
.hero__tag::before { box-shadow: 0 0 10px var(--accent); }
.hero__name {
  font-family: var(--display);
  font-weight: 700; letter-spacing: -.04em; line-height: .9;
  font-size: clamp(64px, 15vw, 230px);
  text-transform: uppercase;
  text-shadow: 0 4px 60px rgba(0,0,0,.7), 0 2px 14px rgba(0,0,0,.55);
}
.hero__name .ln { display:block; overflow:hidden; }
.hero__name-lg { font-size: clamp(80px, 19vw, 290px); line-height: .82; }
.hero__name .ln > span { display:block; animation: rise 1s var(--ease) both; }
.hero__name .ln:nth-child(2) > span { animation-delay:.1s; }
@keyframes rise { from { transform: translateY(110%); } to { transform: none; } }
@media (prefers-reduced-motion: reduce){ .hero__name .ln > span { animation: none; } }
.hero__sub {
  margin-top: 30px; max-width: 540px;
  color: var(--ink-soft); font-size: clamp(16px, 2vw, 21px); font-weight: 400;
  text-shadow: 0 1px 20px rgba(0,0,0,.6);
}
.hero__sub b { color: var(--ink); font-weight:600; }
.hero__cta { margin-top: 40px; display:flex; gap:16px; flex-wrap:wrap; }

/* prominent social icons in hero */
.hero__social { margin-top: 30px; display:flex; gap:13px; flex-wrap:wrap; }
.hsoc {
  width:52px; height:52px; border-radius:50%;
  display:grid; place-items:center;
  color: var(--ink); background: rgba(255,255,255,.06);
  border:1px solid var(--line-2); backdrop-filter: blur(8px);
  transition:.32s var(--ease);
}
.hsoc svg { width:22px; height:22px; }
.hsoc:hover {
  color: var(--accent-ink); background: var(--accent); border-color: var(--accent);
  transform: translateY(-4px); box-shadow: 0 14px 34px var(--accent-glow);
}
[data-hero="cinematic"] .hero__social { justify-content:center; }
@media (max-width:520px){ .hsoc { width:48px; height:48px; } .hsoc svg { width:20px; height:20px; } }
.hero__scroll {
  position:absolute; right: var(--pad); bottom: 40px; z-index:3;
  display:flex; align-items:center; gap:12px; color: var(--ink-mute); font-size:12px;
  letter-spacing:.22em; text-transform:uppercase; writing-mode: vertical-rl;
}
.hero__scroll .line { width:1px; height:54px; background: linear-gradient(var(--accent), transparent); animation: scrolldown 2.2s var(--ease) infinite; transform-origin: top; }
@keyframes scrolldown { 0%{transform:scaleY(0)} 40%{transform:scaleY(1)} 100%{transform:scaleY(0); transform-origin:bottom} }
@media (max-width:860px){ .hero__scroll{ display:none; } }

/* direction: portrait — courtyard, name bottom-left */
[data-hero="portrait"] .hero { align-items:flex-end; text-align:left; }
[data-hero="portrait"] .hero__photo { background-image: url('../images/luis6.jpg'); background-position: center 38%; }

/* direction: cinematic — sunset pier, centered, slow zoom */
[data-hero="cinematic"] .hero { align-items:flex-end; text-align:center; }
[data-hero="cinematic"] .hero__tag,
[data-hero="cinematic"] .hero__cta { justify-content:center; }
[data-hero="cinematic"] .hero__sub { margin-inline:auto; }
[data-hero="cinematic"] .hero__photo { background-image: url('../images/luis15.jpg'); background-position: center 45%; animation: kenburns 26s ease-in-out infinite alternate; }
@keyframes kenburns { from{ transform: scale(1.04); } to{ transform: scale(1.16) translate(-1.5%, -1.5%); } }

/* direction: mono — black & white street portrait */
[data-hero="mono"] .hero { align-items:flex-end; text-align:left; }
[data-hero="mono"] .hero__photo {
  background-image: url('../images/luis35.jpg');
  background-image: image-set(url('../images/luis35.webp') type('image/webp'), url('../images/luis35.jpg') type('image/jpeg'));
  background-position: center 30%; filter: grayscale(1) contrast(1.04) brightness(.72);
}

/* ============================================================
   ABOUT
   ============================================================ */
.about { position:relative; }
.about__grid { display:grid; grid-template-columns: 0.85fr 1fr; gap: clamp(36px, 6vw, 90px); align-items:center; }
.about__photo {
  position:relative; aspect-ratio: 4/5; border-radius: 6px; overflow:hidden;
  border:1px solid var(--line);
  background-size: cover; background-position: center;
  background-color: #0d0d0f;
  background-image:
    radial-gradient(90% 70% at 30% 20%, rgba(217,164,65,.12), transparent 60%),
    linear-gradient(155deg,#1a1a1e,#0d0d0f);
}
.ph-tag {
  position:absolute; left:14px; bottom:14px; z-index:2;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-mute);
  background: rgba(0,0,0,.4); padding:6px 10px; border-radius:100px; border:1px solid var(--line);
  backdrop-filter: blur(4px);
}
.about__photo .frame-glow { position:absolute; inset:0; box-shadow: inset 0 0 120px rgba(0,0,0,.7); }
.about__h {
  font-family: var(--display); font-weight: 600; letter-spacing:-.03em; line-height:1.02;
  font-size: clamp(34px, 5vw, 62px); margin: 22px 0 28px;
}
.about__h em { font-style: normal; color: var(--accent); }
.about__body p { color: var(--ink-soft); margin-bottom: 18px; max-width: 52ch; }
.about__body p b { color: var(--ink); font-weight:600; }
.socials { display:flex; gap:14px; margin-top: 34px; flex-wrap:wrap; }
.social {
  display:inline-flex; align-items:center; gap:10px;
  padding: 11px 18px; border-radius:100px; border:1px solid var(--line-2);
  font-size:14px; font-weight:500; color: var(--ink-soft);
  transition: .35s var(--ease);
}
.social svg { width:17px; height:17px; }
.social:hover { color: var(--ink); border-color: var(--accent); background: var(--accent-glow); transform: translateY(-2px); }

/* stat strip */
.stats { display:grid; grid-template-columns: repeat(3,1fr); gap: 1px; margin-top: 70px; background: var(--line); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.stat { background: var(--bg-1); padding: 30px clamp(18px,3vw,38px); }
.stat__n { font-family: var(--display); font-size: clamp(30px,4vw,46px); font-weight:700; letter-spacing:-.03em; }
.stat__l { color: var(--ink-mute); font-size: 13px; margin-top:4px; letter-spacing:.04em; }

@media (max-width: 820px){
  .about__grid { grid-template-columns:1fr; }
  .about__photo { max-width: 420px; }
  .stats { grid-template-columns:1fr; }
}

/* ============================================================
   MUSIC + STORE
   ============================================================ */
.music__head { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom: 52px; flex-wrap:wrap; }
.section-title {
  font-family: var(--display); font-weight: 600; letter-spacing:-.03em; line-height:1;
  font-size: clamp(40px, 7vw, 96px); text-transform:uppercase;
}
.music__head p { color: var(--ink-mute); max-width: 34ch; }

/* now-playing player */
.player {
  display:grid; grid-template-columns: auto 1fr; gap: clamp(20px,3vw,38px); align-items:center;
  background: linear-gradient(150deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--line); border-radius: 16px; padding: clamp(20px,3vw,34px);
  margin-bottom: 18px;
}
.player__art {
  width: clamp(96px, 14vw, 168px); aspect-ratio:1; border-radius:10px; flex:none; position:relative; overflow:hidden;
  background: #101013 center/cover;
  background-image: url('../images/cover.jpg');
  background-image: image-set(url('../images/cover.webp') type('image/webp'), url('../images/cover.jpg') type('image/jpeg'));
  border:1px solid var(--line-2);
}
.player__art::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.55)); }
.player__art .eq { position:absolute; z-index:2; left:50%; bottom:16px; transform:translateX(-50%); display:flex; gap:4px; align-items:flex-end; height:26px; opacity:.95; }
.player__art .eq i { width:4px; background: var(--accent); border-radius:2px; height:8px; }
.player.playing .eq i { animation: eq .9s ease-in-out infinite; }
.player.playing .eq i:nth-child(2){ animation-delay:.15s } .player.playing .eq i:nth-child(3){ animation-delay:.3s }
.player.playing .eq i:nth-child(4){ animation-delay:.45s } .player.playing .eq i:nth-child(5){ animation-delay:.6s }
@keyframes eq { 0%,100%{height:8px} 50%{height:28px} }
.player__main { min-width:0; }
.player__meta { display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; }
.player__title { font-family: var(--display); font-size: clamp(22px,3vw,32px); font-weight:600; letter-spacing:-.02em; }
.player__album { color: var(--ink-mute); font-size:14px; }
.player__controls { display:flex; align-items:center; gap:18px; margin-top: 22px; }
.pbtn { width:54px; height:54px; border-radius:50%; background: var(--accent); color: var(--accent-ink); display:grid; place-items:center; flex:none; transition: transform .3s var(--ease); }
.pbtn:hover { transform: scale(1.06); }
.pbtn svg { width:20px; height:20px; }
.player__bar { flex:1; min-width:0; }
.player__time { display:flex; justify-content:space-between; font-size:12px; color: var(--ink-mute); margin-bottom:8px; font-variant-numeric: tabular-nums; }
.track-rail { height:5px; background: var(--bg-3); border-radius:100px; position:relative; cursor:pointer; }
.track-rail__fill { position:absolute; left:0; top:0; bottom:0; width:0; background: var(--accent); border-radius:100px; }
.track-rail__knob { position:absolute; top:50%; left:0; width:13px; height:13px; border-radius:50%; background:#fff; transform: translate(-50%,-50%); opacity:0; transition:opacity .2s; }
.track-rail:hover .track-rail__knob { opacity:1; }

/* track list */
.tracklist { border-top:1px solid var(--line); margin-top: 26px; }
.track {
  display:grid; grid-template-columns: 40px 1fr auto auto; align-items:center; gap: clamp(12px,2vw,28px);
  padding: 20px 6px; border-bottom:1px solid var(--line);
  transition: background .3s, padding .3s var(--ease);
}
.track:hover { background: rgba(255,255,255,.02); padding-inline: 16px; }
.track.active { background: var(--accent-glow); padding-inline:16px; }
.track__play { width:40px; height:40px; border-radius:50%; border:1px solid var(--line-2); display:grid; place-items:center; transition:.3s var(--ease); }
.track__play svg { width:15px; height:15px; }
.track:hover .track__play, .track.active .track__play { border-color: var(--accent); color: var(--accent); }
.track__info { min-width:0; }
.track__name { font-weight:600; font-size: 17px; letter-spacing:-.01em; }
.track__sub { color: var(--ink-mute); font-size:13px; margin-top:2px; }
.track__dur { color: var(--ink-mute); font-size:14px; font-variant-numeric:tabular-nums; }
.track__buy {
  display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600;
  padding: 9px 16px; border-radius:100px; border:1px solid var(--line-2); color: var(--ink-soft);
  transition:.3s var(--ease); white-space:nowrap;
}
.track__buy:hover { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.track__buy svg { width:14px; height:14px; }
@media (max-width: 720px){
  .player { grid-template-columns:1fr; }
  .track { grid-template-columns: 36px 1fr auto; }
  .track__dur { display:none; }
  .track__buy span { display:none; }
}

/* store callout */
.store {
  margin-top: 56px; display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 18px;
}

/* Bandcamp album players */
.bc-grid { display:flex; flex-wrap:wrap; gap:24px; justify-content:center; margin-top: 8px; }
.bc-album {
  width:100%; max-width:380px; border:1px solid var(--line); border-radius:14px; overflow:hidden;
  background: var(--bg-1); box-shadow: 0 24px 60px rgba(0,0,0,.4);
  transition: transform .4s var(--ease), border-color .4s;
}
.bc-album:hover { transform: translateY(-4px); border-color: var(--line-2); }
.bc-album iframe { display:block; width:100%; height:470px; border:0; }
.music__more { text-align:center; margin-top: 52px; display:flex; flex-direction:column; align-items:center; gap:20px; }
.music__more p { color: var(--ink-mute); max-width: 48ch; }
.store__card {
  border:1px solid var(--line); border-radius:14px; padding: 30px; background: var(--bg-1);
  transition:.4s var(--ease); position:relative; overflow:hidden;
}
.store__card:hover { border-color: var(--line-2); transform: translateY(-4px); }
.store__card h4 { font-family: var(--display); font-size: 22px; font-weight:600; letter-spacing:-.02em; margin-bottom:8px; }
.store__card p { color: var(--ink-mute); font-size:14px; margin-bottom: 22px; }
.store__price { font-family: var(--display); font-size: 30px; font-weight:700; margin-bottom:18px; }
.store__price span { font-size:14px; color: var(--ink-mute); font-family: var(--body); font-weight:400; }
.store__buy { display:inline-flex; align-items:center; gap:8px; color: var(--accent); font-weight:600; font-size:15px; }
.store__buy svg{ width:16px; height:16px; transition: transform .3s var(--ease); }
.store__card:hover .store__buy svg { transform: translateX(4px); }

/* ============================================================
   GALLERY (bento + lightbox)
   ============================================================ */
.gallery__head { margin-bottom: 48px; }
.bento { display:grid; grid-template-columns: repeat(4,1fr); grid-auto-rows: 200px; gap: 14px; }
.cell { position:relative; overflow:hidden; border-radius:10px; border:1px solid var(--line); cursor:pointer; background:#121214; }
.cell:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.cell__img {
  position:absolute; inset:0; transition: transform .9s var(--ease), filter .5s, opacity .6s var(--ease);
  background-size:cover; background-position:center; filter: grayscale(.2) brightness(.92);
  opacity: 0;
}
.cell__img.loaded { opacity: 1; }
.cell:hover .cell__img { transform: scale(1.07); filter: grayscale(0) brightness(1); }
.cell::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 50%, rgba(8,8,9,.7)); opacity:.7; transition:.4s; }
.cell:hover::after { opacity:.4; }
.cell__cap { position:absolute; left:16px; bottom:14px; z-index:2; font-size:13px; color: var(--ink-soft); font-weight:500; letter-spacing:.02em;
  transform: translateY(6px); opacity:0; transition:.4s var(--ease); }
.cell:hover .cell__cap { transform:none; opacity:1; }
.cell__plus { position:absolute; top:14px; right:14px; z-index:2; width:30px;height:30px;border-radius:50%; display:grid;place-items:center; background:rgba(0,0,0,.4); border:1px solid var(--line); opacity:0; transition:.4s; }
.cell:hover .cell__plus { opacity:1; }
.cell__plus svg{ width:13px;height:13px; }
/* spans */
.cell.big { grid-column: span 2; grid-row: span 2; }
.cell.wide { grid-column: span 2; }
.cell.tall { grid-row: span 2; }
@media (max-width: 820px){
  .bento { grid-template-columns: repeat(2,1fr); grid-auto-rows: 150px; }
  .cell.big { grid-column: span 2; }
}

/* lightbox */
.lightbox { position:fixed; inset:0; z-index: 5000; display:none; place-items:center; padding: 4vw;
  background: rgba(6,6,7,.92); backdrop-filter: blur(12px); opacity:0; transition: opacity .4s; }
.lightbox.open { display:grid; opacity:1; }
.lightbox__img { max-width: min(1100px, 92vw); max-height: 82vh; width:100%; aspect-ratio:16/10; border-radius: 10px; border:1px solid var(--line-2);
  background-size:cover; background-position:center; box-shadow: 0 40px 120px rgba(0,0,0,.6); }
.lightbox__cap { position:absolute; bottom: 5vh; left:50%; transform: translateX(-50%); color: var(--ink-soft); font-size:14px; letter-spacing:.04em; }
.lightbox__close { position:absolute; top: 4vh; right: 4vw; width:48px;height:48px;border-radius:50%; border:1px solid var(--line-2); display:grid;place-items:center; transition:.3s; }
.lightbox__close:hover { background: var(--ink); color: var(--bg); }
.lightbox__nav { position:absolute; top:50%; transform: translateY(-50%); width:52px;height:52px;border-radius:50%; border:1px solid var(--line-2); display:grid;place-items:center; transition:.3s; }
.lightbox__nav:hover { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.lightbox__nav.prev{ left: 3vw; } .lightbox__nav.next{ right: 3vw; }
@media (max-width:720px){ .lightbox__nav{ display:none; } }

/* ============================================================
   CONTACT + FOOTER
   ============================================================ */
.contact__grid { display:grid; grid-template-columns: 1.1fr 1fr; gap: clamp(40px, 7vw, 110px); align-items:start; }
.contact__lead {
  font-family: var(--display); font-weight: 500; letter-spacing:-.02em; line-height:1.05;
  font-size: clamp(30px, 4.4vw, 58px);
}
.contact__lead em { font-style:normal; color: var(--accent); }
.contact__sub { color: var(--ink-soft); margin-top: 24px; max-width: 42ch; }
.contact__mail { display:inline-flex; align-items:center; gap:12px; margin-top: 30px; font-family: var(--display); font-size: clamp(18px,2.4vw,26px); font-weight:500; border-bottom:1px solid var(--line-2); padding-bottom:6px; transition:.3s; }
.contact__mail:hover { border-color: var(--accent); color: var(--accent); }
.contact__addr { font-style: normal; display: block; }

.form { display:grid; gap: 18px; }
.field { display:grid; gap: 8px; }
.field label { font-size: 12px; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-mute); font-weight:600; }
.field input, .field textarea {
  background: var(--bg-1); border:1px solid var(--line); border-radius: 10px;
  padding: 15px 16px; color: var(--ink); font-family: var(--body); font-size: 16px; width:100%;
  transition:.3s var(--ease); resize: vertical;
}
.field input:focus, .field textarea:focus { outline:none; border-color: var(--accent); background: var(--bg-2); box-shadow: 0 0 0 4px var(--accent-glow); }
.field input::placeholder, .field textarea::placeholder { color: var(--ink-faint); }
.field.err input, .field.err textarea { border-color: #e8643c; }
.field__msg { font-size:12px; color:#e8643c; min-height: 0; display:none; }
.field.err .field__msg { display:block; }
.form__submit { justify-self:start; margin-top: 6px; }
.form__ok { display:none; align-items:center; gap:10px; color: var(--accent); font-weight:600; margin-top:6px; }
.form__ok.show { display:flex; }
@media (max-width: 820px){ .contact__grid { grid-template-columns:1fr; } }

footer { border-top:1px solid var(--line); margin-top: var(--section-y); padding-block: 50px 60px; }
.foot {
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.foot__brand { font-family: var(--display); font-size: 22px; font-weight:700; letter-spacing:-.02em; }
.foot__brand .dot { color: var(--accent); }
.foot__links { display:flex; gap: 26px; flex-wrap:wrap; }
.foot__links a { font-size:14px; color: var(--ink-mute); transition:.3s; }
.foot__links a:hover { color: var(--ink); }
.foot__copy { color: var(--ink-faint); font-size:13px; width:100%; margin-top: 30px; padding-top: 24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* ============================================================
   DIRECTION SWITCHER (optional UI — safe to delete for production)
   ============================================================ */
.switcher {
  position: fixed; z-index: 4000; right: 18px; bottom: 18px;
  display:flex; flex-direction:column; gap:14px; align-items:flex-end;
}
.switcher__toggle {
  width:50px; height:50px; border-radius:50%; background: var(--bg-2); border:1px solid var(--line-2);
  display:grid; place-items:center; box-shadow: 0 10px 40px rgba(0,0,0,.5); transition:.3s var(--ease);
}
.switcher__toggle:hover { border-color: var(--accent); transform: rotate(45deg); }
.switcher__toggle svg { width:20px; height:20px; color: var(--accent); }
.switcher__panel {
  background: rgba(16,16,18,.92); backdrop-filter: blur(20px);
  border:1px solid var(--line-2); border-radius: 16px; padding: 18px; width: 248px;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  transform-origin: bottom right; transform: scale(.9) translateY(8px); opacity:0; pointer-events:none;
  transition: .35s var(--ease);
}
.switcher.open .switcher__panel { transform:none; opacity:1; pointer-events:auto; }
.switcher__panel h5 { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color: var(--ink-mute); margin: 4px 0 12px; font-weight:600; }
.switcher__panel h5:not(:first-child){ margin-top:20px; }
.opt-row { display:flex; gap:8px; flex-wrap:wrap; }
.opt {
  padding: 9px 13px; border-radius:100px; border:1px solid var(--line); font-size:13px; color: var(--ink-soft);
  transition:.25s var(--ease); font-weight:500;
}
.opt:hover { border-color: var(--line-2); color: var(--ink); }
.opt.active { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.sw-color { display:flex; gap:10px; }
.sw-color .opt { width:30px; height:30px; padding:0; border-radius:50%; position:relative; }
.sw-color .opt.active { box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px currentColor; }
.sw-color .c-ember{ background:#d9a441; } .sw-color .c-coral{ background:#e8643c; }
.sw-color .c-teal{ background:#3fb6a3; } .sw-color .c-bone{ background:#e7e2d6; }
