/* ─── Brunee:Timber — design tokens ─── */
:root{
  --bg:        #0a0907;
  --bg-2:      #110e0a;
  --bg-3:      #19150f;
  --line:      rgba(240,229,210,.09);
  --line-2:    rgba(240,229,210,.16);
  --text:      #f0e5d2;
  --text-dim:  #b6ac9c;
  --muted:     #7a7264;
  --gold:      #d4a657;
  --gold-2:    #e8c489;
  --teal:      #4ea896;
  --accent:    var(--gold);

  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 18px;
  --r-xl: 28px;

  --shell-max: 1280px;
  --pad-x: clamp(20px, 4vw, 56px);

  --f-display: 'Michroma', ui-sans-serif, sans-serif;
  --f-body:    'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --f-mono:    'JetBrains Mono', ui-monospace, monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--gold);color:#1a1308}

/* ─── Layout helpers ─── */
.shell{
  width:100%;
  max-width:var(--shell-max);
  margin-inline:auto;
  padding-inline:var(--pad-x);
}
.section{
  position:relative;
  padding-block:clamp(80px,10vw,140px);
}
.section + .section{ border-top:1px solid var(--line) }

.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:""; width:24px; height:1px; background:var(--gold);
}
.h-display{
  font-family:var(--f-display);
  font-weight:400;
  letter-spacing:.04em;
  line-height:1.05;
  margin:0;
  color:var(--text);
}
.h1{ font-size:clamp(34px, 5.4vw, 72px) }
.h2{ font-size:clamp(28px, 4vw, 52px) }
.h3{ font-size:clamp(20px, 1.6vw, 24px) }
.lead{
  font-size:clamp(16px, 1.2vw, 19px);
  color:var(--text-dim);
  max-width:60ch;
  line-height:1.6;
}
.tagline{
  font-family:var(--f-mono);
  letter-spacing:.06em;
  color:var(--text-dim);
}

/* transparent PNG wordmark — no blend mode needed */
.wordmark-img{
  user-select:none;
  -webkit-user-drag:none;
}
.tree-img{
  mix-blend-mode:screen;
  filter: contrast(1.05);
}

/* ─── Nav ─── */
.nav{
  position:fixed; inset:0 0 auto 0;
  z-index:50;
  padding-block:18px;
  transition:background .25s ease, border-color .25s ease, padding .25s ease;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(10,9,7,.72);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom-color:var(--line);
  padding-block:12px;
}
.nav-row{ display:flex; align-items:center; justify-content:space-between; gap:24px }
.nav-brand{ display:flex; align-items:center; gap:12px }
.nav-brand .tree{
  width:26px; height:26px;
  background:url(assets/tree-mark.jpg) center/contain no-repeat;
  mix-blend-mode:screen; filter:contrast(1.1);
}
.nav-brand .wmk{ height:14px }
.nav-links{ display:flex; gap:28px; align-items:center }
.nav-links a{
  font-family:var(--f-mono); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-dim);
  padding:6px 0; position:relative; transition:color .2s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0;
  height:1px; background:var(--gold); transition:right .25s ease;
}
.nav-links a:hover{ color:var(--text) }
.nav-links a:hover::after{ right:0 }
.nav-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px; border:1px solid var(--gold);
  color:var(--gold); font-family:var(--f-mono); font-size:12px;
  letter-spacing:.16em; text-transform:uppercase; border-radius:999px;
  transition:background .2s, color .2s, transform .15s;
}
.nav-cta:hover{ background:var(--gold); color:#1a1308 }
.nav-cta:active{ transform:translateY(1px) }
@media (max-width:780px){
  .nav-links{ display:none }
}

/* burger for mobile */
.nav-burger{ display:none; width:36px; height:36px; place-items:center; border:1px solid var(--line-2); border-radius:8px }
.nav-burger span{ width:16px; height:1px; background:var(--text); display:block; position:relative }
.nav-burger span::before,.nav-burger span::after{
  content:""; position:absolute; left:0; width:16px; height:1px; background:var(--text);
}
.nav-burger span::before{ top:-5px } .nav-burger span::after{ top:5px }
@media (max-width:780px){
  .nav-burger{ display:grid }
  .nav-cta.mobile-hide{ display:none }
}

.mobile-menu{
  position:fixed; inset:0; z-index:60;
  background:rgba(10,9,7,.96);
  backdrop-filter:blur(20px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:28px; opacity:0; pointer-events:none; transition:opacity .25s;
}
.mobile-menu.open{ opacity:1; pointer-events:auto }
.mobile-menu a{
  font-family:var(--f-mono); font-size:14px; letter-spacing:.2em; text-transform:uppercase;
}
.mobile-menu .close{
  position:absolute; top:18px; right:18px; width:40px; height:40px; display:grid; place-items:center;
  border:1px solid var(--line-2); border-radius:50%;
}

/* ─── Hero ─── */
.hero{
  position:relative;
  min-height:100vh;
  padding-top:120px;
  display:flex; align-items:center;
  overflow:hidden;
  isolation:isolate;
}
.hero .shell{ position:relative; z-index:2 }
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 60% 40% at 20% 30%, rgba(78,168,150,.18), transparent 70%),
    radial-gradient(ellipse 60% 40% at 80% 70%, rgba(212,166,87,.18), transparent 70%),
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(10,9,7,1), transparent 70%);
}
.hero-badge{
  position:absolute; inset:0; z-index:1;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none;
  opacity:.22;
}
.hero-badge img{
  width:min(900px, 90vw); height:auto;
  filter:saturate(.85) contrast(1.05);
}
.hero-grid{
  display:grid; grid-template-columns: 1fr; gap:48px;
  align-items:center;
}
.hero-eyebrow-row{
  display:flex; gap:18px; align-items:center; flex-wrap:wrap; margin-bottom:24px;
}
.hero-dot{
  width:8px; height:8px; border-radius:50%; background:var(--gold);
  box-shadow:0 0 0 4px rgba(212,166,87,.18);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(212,166,87,.18) }
  50%{ box-shadow:0 0 0 10px rgba(212,166,87,0) }
}
.hero-wordmark{
  margin: 6px 0 22px;
  max-width: min(820px, 90vw);
}
.hero-wordmark img{ width:100% }
.hero-pre{ font-family:var(--f-mono); letter-spacing:.32em; color:var(--gold); font-size:13px; text-transform:uppercase }

.hero-tag{
  font-family:var(--f-mono);
  font-size:clamp(15px, 1.4vw, 18px);
  letter-spacing:.06em;
  color:var(--text-dim);
  max-width:64ch;
}
.hero-actions{
  margin-top:36px;
  display:flex; gap:14px; flex-wrap:wrap;
}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 24px; border-radius:999px;
  font-family:var(--f-mono); font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  transition:transform .15s, background .2s, color .2s, border-color .2s, box-shadow .2s;
  border:1px solid transparent;
}
.btn-primary{ background:var(--gold); color:#1a1308 }
.btn-primary:hover{ background:var(--gold-2); box-shadow:0 8px 30px -8px rgba(212,166,87,.6) }
.btn-primary:active{ transform:translateY(1px) }
.btn-ghost{ border-color:var(--line-2); color:var(--text) }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold) }
.btn .arrow{ transition:transform .2s }
.btn:hover .arrow{ transform:translateX(3px) }

.hero-meta{
  margin-top:64px;
  display:flex; gap:48px; flex-wrap:wrap;
  font-family:var(--f-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}
.hero-meta strong{ color:var(--text); font-weight:500 }
.hero-meta .sep{ width:1px; background:var(--line-2); align-self:stretch }

.hero-scroll{
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.3em;
  text-transform:uppercase; color:var(--muted);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  z-index:2;
}
.hero-scroll .line{ width:1px; height:32px; background:linear-gradient(180deg, var(--muted), transparent); animation:drop 1.8s ease-in-out infinite }
@keyframes drop{
  0%{ transform:translateY(-6px); opacity:0 }
  40%{ opacity:1 }
  100%{ transform:translateY(6px); opacity:0 }
}

/* ─── Section header ─── */
.sec-head{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:48px;
  align-items:end; margin-bottom:64px;
}
@media (max-width:820px){ .sec-head{ grid-template-columns:1fr; gap:24px } }
.sec-num{
  font-family:var(--f-mono); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted); margin-bottom:18px;
}

/* ─── Sound cards ─── */
.sound-grid{
  display:grid; grid-template-columns:repeat(12,1fr); gap:16px;
}
.sound-card{
  position:relative;
  grid-column:span 4;
  padding:28px 28px 24px;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  background:linear-gradient(180deg, var(--bg-2), var(--bg));
  transition:transform .3s ease, border-color .3s, background .3s;
  overflow:hidden;
  min-height:220px;
  display:flex; flex-direction:column; justify-content:space-between;
}
.sound-card::after{
  content:""; position:absolute; inset:auto -20% -50% auto; width:300px; height:300px;
  background:radial-gradient(circle, var(--card-glow,rgba(212,166,87,.16)), transparent 60%);
  opacity:0; transition:opacity .35s ease;
}
.sound-card:hover{ transform:translateY(-3px); border-color:var(--line-2) }
.sound-card:hover::after{ opacity:1 }
.sound-card .num{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.2em;
  color:var(--muted); text-transform:uppercase;
}
.sound-card h3{
  font-family:var(--f-display); font-weight:400; font-size:22px;
  letter-spacing:.04em; margin:18px 0 12px; color:var(--text);
}
.sound-card p{ color:var(--text-dim); font-size:14px; line-height:1.55; margin:0 }
.sound-card .bpm{
  margin-top:18px; display:inline-flex; gap:6px; align-items:center;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.15em; color:var(--gold); text-transform:uppercase;
}
@media (max-width:980px){ .sound-card{ grid-column:span 6 } }
@media (max-width:620px){ .sound-card{ grid-column:span 12 } }

/* ─── Events ─── */
.events-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:16px;
}
@media (max-width:820px){ .events-grid{ grid-template-columns:1fr } }
.event-card{
  position:relative; padding:36px; border:1px solid var(--line); border-radius:var(--r-lg);
  background:var(--bg-2);
  display:grid; grid-template-columns:80px 1fr auto; gap:24px; align-items:center;
  transition:border-color .25s, background .25s;
}
.event-card:hover{ border-color:var(--gold); background:var(--bg-3) }
.event-icon{
  width:64px; height:64px; border-radius:14px;
  border:1px solid var(--line-2);
  display:grid; place-items:center; color:var(--gold);
  background:radial-gradient(circle at 30% 30%, rgba(212,166,87,.12), transparent 70%);
}
.event-card h3{
  font-family:var(--f-display); font-weight:400; font-size:20px; letter-spacing:.04em;
  color:var(--text); margin:0 0 6px;
}
.event-card p{ color:var(--text-dim); margin:0; font-size:14px }
.event-arrow{
  width:44px; height:44px; border:1px solid var(--line-2); border-radius:50%;
  display:grid; place-items:center; color:var(--text-dim);
  transition:transform .25s, color .25s, border-color .25s, background .25s;
}
.event-card:hover .event-arrow{
  color:#1a1308; background:var(--gold); border-color:var(--gold); transform:rotate(-45deg);
}

/* ─── Mixes ─── */
.mix-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px }
@media (max-width:980px){ .mix-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:640px){ .mix-grid{ grid-template-columns:1fr } }
.mix-card{
  position:relative; overflow:hidden;
  border:1px solid var(--line); border-radius:var(--r-lg);
  background:var(--bg-2);
  transition:transform .3s, border-color .3s;
}
.mix-card:hover{ transform:translateY(-4px); border-color:var(--gold) }
.mix-art{
  position:relative; aspect-ratio:1/1; overflow:hidden;
  background:linear-gradient(135deg, #1a1208, #0a0907);
}
.mix-art .wave{
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(90deg, var(--art-c1,#d4a657) 0 2px, transparent 2px 6px);
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  opacity:.4;
}
.mix-art .glow{
  position:absolute; inset:-20%;
  background:radial-gradient(circle at center, var(--art-c2,rgba(212,166,87,.5)), transparent 50%);
  filter:blur(40px);
}
.mix-art .play{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:64px; height:64px; border-radius:50%;
  background:rgba(240,229,210,.92); color:#0a0907;
  display:grid; place-items:center;
  transition:transform .25s, background .25s;
  box-shadow:0 12px 40px rgba(0,0,0,.4);
}
.mix-card:hover .play{ transform:translate(-50%,-50%) scale(1.08); background:var(--gold) }
.mix-info{ padding:20px 22px }
.mix-info .tag{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.2em; color:var(--gold);
  text-transform:uppercase;
}
.mix-info h3{
  font-family:var(--f-display); font-weight:400; font-size:18px; letter-spacing:.03em;
  color:var(--text); margin:8px 0 4px;
}
.mix-info .meta{
  display:flex; gap:14px; color:var(--muted); font-family:var(--f-mono); font-size:11px;
  letter-spacing:.1em; text-transform:uppercase;
}

/* ─── Gallery ─── */
.gallery{
  display:grid; grid-template-columns:repeat(12,1fr); gap:14px;
}
.gal-tile{
  position:relative; overflow:hidden;
  border-radius:var(--r-md);
  background:linear-gradient(135deg, #1a1208, #0a0907);
  border:1px solid var(--line);
  min-height:160px;
  display:grid; place-items:center;
}
.gal-tile .placeholder-label{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; color:var(--muted); text-transform:uppercase;
}
.gal-tile::before{
  content:""; position:absolute; inset:0;
  background:
    repeating-linear-gradient(135deg, rgba(240,229,210,.04) 0 1px, transparent 1px 14px);
}
.gal-tile.a{ grid-column:span 7; aspect-ratio: 16/9 }
.gal-tile.b{ grid-column:span 5; aspect-ratio: 4/4 }
.gal-tile.c{ grid-column:span 4; aspect-ratio: 4/5 }
.gal-tile.d{ grid-column:span 4; aspect-ratio: 4/5 }
.gal-tile.e{ grid-column:span 4; aspect-ratio: 4/5 }
@media (max-width:820px){
  .gal-tile{ grid-column:span 12 !important; aspect-ratio:16/10 !important }
}

/* ─── Contact ─── */
.contact-wrap{
  display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:start;
}
@media (max-width:980px){ .contact-wrap{ grid-template-columns:1fr; gap:40px } }
.contact-info{ display:flex; flex-direction:column; gap:32px }
.contact-card{
  border:1px solid var(--line); border-radius:var(--r-lg); padding:24px;
  background:linear-gradient(180deg, var(--bg-2), transparent);
}
.contact-card .label{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.2em; color:var(--muted); text-transform:uppercase; margin-bottom:8px;
}
.contact-card .value{
  font-family:var(--f-display); font-size:18px; letter-spacing:.03em; color:var(--text);
}
.contact-card .value a:hover{ color:var(--gold) }
.contact-rows{ display:grid; grid-template-columns:1fr 1fr; gap:14px }
@media (max-width:560px){ .contact-rows{ grid-template-columns:1fr } }

.form{
  border:1px solid var(--line); border-radius:var(--r-lg);
  padding:32px; background:var(--bg-2);
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr } }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px }
.field label{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; color:var(--text-dim);
  text-transform:uppercase;
}
.field label .req{ color:var(--gold); margin-left:4px }
.field input, .field textarea, .field select{
  background:var(--bg);
  border:1px solid var(--line-2);
  border-radius:var(--r-md);
  color:var(--text);
  padding:14px 16px;
  font-family:var(--f-body); font-size:15px;
  outline:none; transition:border-color .2s, background .2s;
  width:100%;
}
.field textarea{ resize:vertical; min-height:120px; font-family:var(--f-body) }
.field input:focus, .field textarea:focus, .field select:focus{
  border-color:var(--gold);
  background:var(--bg-3);
}
.field.has-err input, .field.has-err textarea, .field.has-err select{
  border-color:#c87455;
}
.err-msg{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.08em; color:#c87455;
}
.form .checkbox-row{
  display:flex; gap:10px; align-items:flex-start; margin:6px 0 18px;
}
.form .checkbox-row input{ margin-top:4px; accent-color:var(--gold) }
.form .checkbox-row label{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.06em; color:var(--text-dim);
  text-transform:none; line-height:1.6;
}
.form-submit{ width:100%; justify-content:center }
.form-status{
  margin-top:14px;
  font-family:var(--f-mono); font-size:12px; letter-spacing:.06em;
}
.form-status.ok{ color:var(--teal) }
.form-status.warn{ color:#c87455 }
.form-success{
  text-align:center; padding:48px 24px;
}
.form-success h3{
  font-family:var(--f-display); font-size:24px; letter-spacing:.04em; color:var(--gold); margin:18px 0 10px;
}
.form-success p{ color:var(--text-dim); font-family:var(--f-mono); font-size:13px; letter-spacing:.05em }
.checkmark{
  width:64px; height:64px; border-radius:50%; border:1.5px solid var(--gold);
  display:grid; place-items:center; margin:0 auto;
  color:var(--gold);
}

/* ─── FAQ ─── */
.faq{ display:flex; flex-direction:column }
.faq-item{
  border-top:1px solid var(--line);
  padding:22px 0;
}
.faq-item:last-child{ border-bottom:1px solid var(--line) }
.faq-q{
  display:flex; justify-content:space-between; align-items:center; gap:24px;
  cursor:pointer; user-select:none;
}
.faq-q h3{
  font-family:var(--f-display); font-weight:400; font-size:18px; letter-spacing:.03em;
  color:var(--text); margin:0;
}
.faq-toggle{
  width:34px; height:34px; border-radius:50%; border:1px solid var(--line-2);
  display:grid; place-items:center; color:var(--text-dim);
  transition:transform .3s, color .3s, border-color .3s;
  flex-shrink:0;
}
.faq-item.open .faq-toggle{ transform:rotate(45deg); color:var(--gold); border-color:var(--gold) }
.faq-a{
  max-height:0; overflow:hidden;
  transition:max-height .35s ease, margin .25s ease;
  color:var(--text-dim);
  font-size:15px; line-height:1.6;
}
.faq-item.open .faq-a{ max-height:240px; margin-top:14px }

/* ─── Footer ─── */
.footer{
  border-top:1px solid var(--line);
  padding-block:64px 36px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.4));
}
.foot-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:48px;
  align-items:start; padding-bottom:48px;
  border-bottom:1px solid var(--line);
}
@media (max-width:820px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:32px } }
@media (max-width:520px){ .foot-grid{ grid-template-columns:1fr } }
.foot-brand .wmk{ height:18px; margin-bottom:14px }
.foot-brand p{ color:var(--text-dim); font-size:14px; max-width:38ch; margin:0 0 18px }
.foot-col h4{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.2em;
  color:var(--gold); text-transform:uppercase; margin:6px 0 14px;
}
.foot-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px }
.foot-col a{ color:var(--text-dim); font-size:14px; transition:color .2s }
.foot-col a:hover{ color:var(--text) }
.foot-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px;
  padding-top:24px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; color:var(--muted);
  text-transform:uppercase;
}
.foot-social{ display:flex; gap:10px }
.foot-social a{
  width:38px; height:38px; border:1px solid var(--line-2); border-radius:50%;
  display:grid; place-items:center; color:var(--text-dim);
  transition:color .2s, border-color .2s, background .2s;
}
.foot-social a:hover{ color:var(--gold); border-color:var(--gold) }

/* utility */
.fade-up{ opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease }
.fade-up.in{ opacity:1; transform:none }
