/* ============================================================
   TEHERVONAT ZENEKAR — styles
   Brutal industrial. Matte black · steel · gunmetal · rust · deep red.
   ============================================================ */

:root{
  --black:#0c0c0d;
  --black-2:#101012;
  --steel:#3a3d42;
  --gunmetal:#5a5f66;
  --gun-2:#787d85;
  --rust:#bd6a1e;
  --rust-bright:#d77e2c;
  --red:#8a1c14;
  --red-bright:#b32a1f;
  --paper:#ecebe7;
  --paper-dim:#b7b4ad;
  --mute:#7d7a74;
  --line:rgba(236,235,231,.12);
  --line-strong:rgba(236,235,231,.22);

  --ff-display:"Anton", "Arial Narrow", sans-serif;
  --ff-sans:"Archivo", system-ui, sans-serif;
  --ff-mono:"Space Mono", ui-monospace, monospace;

  --pad: clamp(20px, 5vw, 96px);
  --maxw: 1400px;
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--black);
  color:var(--paper);
  font-family:var(--ff-sans);
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.no-scroll{ overflow:hidden; }
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--rust);color:#000}

/* lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

/* ---------- typographic helpers ---------- */
.mono{font-family:var(--ff-mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute)}
.kicker{font-family:var(--ff-mono);font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--rust)}
.display{font-family:var(--ff-display);font-weight:400;line-height:.86;letter-spacing:.01em;text-transform:uppercase}

/* ============================================================
   FIXED VIDEO STAGE (the "train")
   ============================================================ */
#stage{
  position:fixed; inset:0; z-index:0;
  overflow:hidden;
  background:#000;
}
/* atmospheric fallback scene — visible before/if the video loads.
   Foggy vanishing-point so the stage reads as a dark railway even
   with no footage. The <video> sits above it (z-index between). */
#stage::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(60% 50% at 50% 50%, rgba(60,61,66,.55) 0%, rgba(28,29,32,.4) 38%, transparent 70%),
    radial-gradient(120% 80% at 50% 120%, rgba(90,95,102,.18) 0%, transparent 55%),
    linear-gradient(to bottom, #141518 0%, #0e0f11 46%, #090909 100%);
}
/* converging rails toward the vanishing point */
#stage::after{
  content:""; position:absolute; left:50%; bottom:0; z-index:0;
  width:160vmax; height:70vh; transform:translateX(-50%);
  background:
    linear-gradient(to top, rgba(120,125,133,.16), transparent 60%);
  clip-path:polygon(48.5% 0, 51.5% 0, 64% 100%, 36% 100%);
  filter:blur(1px);
}
/* both image + video share the same cover layer */
#stage-img,
#stage-video{
  position:absolute; top:50%; left:50%;
  width:100%; height:100%;
  min-width:177.78vh; min-height:56.25vw;
  transform:translate(-50%,-50%) scale(1);
  object-fit:cover;
  will-change:transform,filter;
  filter:saturate(.78) contrast(1.07) brightness(.82);
}
#stage-img{ z-index:1; } /* always visible */
#stage-video{
  z-index:2; /* over image; hidden until buffered */
  opacity:0; transition:opacity 1.4s ease;
}
#stage-video.ready{ opacity:1; }
/* gradient + color grade overlays driven by JS via custom props */
#stage-grade{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 42%, transparent 0%, transparent 38%, rgba(10,10,11,.72) 100%),
    linear-gradient(to bottom, rgba(10,10,11,.55) 0%, transparent 22%, transparent 64%, rgba(8,8,9,.92) 100%);
  mix-blend-mode:multiply;
}
#stage-tint{
  position:absolute; inset:0; z-index:3; pointer-events:none;
  background:var(--rust);
  opacity:0;
  mix-blend-mode:overlay;
  transition:background .8s linear;
}
#stage-vignette{
  position:absolute; inset:0; z-index:4; pointer-events:none;
  box-shadow: inset 0 0 240px 60px rgba(0,0,0,.9), inset 0 0 80px 10px rgba(0,0,0,.6);
}
/* headlight bloom that grows as the train "approaches" */
#stage-bloom{
  position:absolute; left:50%; top:46%; z-index:1;
  width:40vmax; height:40vmax; transform:translate(-50%,-50%) scale(.2);
  background:radial-gradient(circle, rgba(215,126,44,.5) 0%, rgba(189,106,30,.18) 30%, transparent 65%);
  opacity:0; pointer-events:none; mix-blend-mode:screen;
  will-change:transform,opacity;
}

/* ============================================================
   ATMOSPHERE: fog, smoke, embers, grain
   ============================================================ */
#atmos{ position:fixed; inset:0; z-index:5; pointer-events:none; overflow:hidden; }
.fog{
  position:absolute; inset:-20%;
  background-repeat:repeat;
  background-size:1100px 1100px;
  opacity:.0;
  will-change:transform,opacity;
  mix-blend-mode:screen;
}
.fog.f1{ animation:drift1 60s linear infinite; }
.fog.f2{ animation:drift2 90s linear infinite; opacity:0; }
@keyframes drift1{from{transform:translate3d(0,0,0)}to{transform:translate3d(-1100px,0,0)}}
@keyframes drift2{from{transform:translate3d(0,0,0)}to{transform:translate3d(1100px,-200px,0)}}

#embers{ position:absolute; inset:0; }
.ember{
  position:absolute; bottom:-10px; width:3px; height:3px; border-radius:50%;
  background:var(--rust-bright);
  box-shadow:0 0 6px 1px rgba(215,126,44,.8);
  opacity:0;
  will-change:transform,opacity;
}
#grain{
  position:fixed; inset:0; z-index:6; pointer-events:none; opacity:.06;
  mix-blend-mode:overlay;
  background-image:url("assets/grain.svg");
  background-size:240px 240px;
  animation:grain 0.6s steps(3) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}33%{transform:translate(-6px,4px)}66%{transform:translate(4px,-5px)}100%{transform:translate(0,0)}
}
/* scanline / interlace for industrial feel */
#scan{ position:fixed; inset:0; z-index:6; pointer-events:none; opacity:.05;
  background:repeating-linear-gradient(to bottom, rgba(0,0,0,0) 0 2px, rgba(0,0,0,.6) 2px 3px); }

/* ============================================================
   FOREGROUND CONTENT
   ============================================================ */
#content{ position:relative; z-index:10; }
.section{
  position:relative;
  min-height:100vh;
  padding:clamp(80px,12vh,160px) var(--pad);
  display:flex; flex-direction:column; justify-content:center;
}
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; }

/* fade scrim behind text on busy sections */
.scrim{
  position:absolute; inset:0; z-index:-1; pointer-events:none;
}

/* ---------- HEADER / RAILWAY NAV ---------- */
#topbar{
  position:fixed; top:0; left:0; right:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  mix-blend-mode:difference;
}
#topbar .brand{ font-family:var(--ff-display); font-size:22px; letter-spacing:.02em; color:#fff; }
#topbar .brand small{ color:var(--rust-bright); }
.nav-toggle{
  display:flex; align-items:center; gap:12px; cursor:pointer;
  font-family:var(--ff-mono); font-size:12px; letter-spacing:.3em; color:#fff;
  background:none;border:none;padding:0;
}
.nav-toggle .bars{ display:inline-flex; flex-direction:column; gap:4px; }
.nav-toggle .bars i{ width:26px; height:2px; background:#fff; display:block; transition:.3s; }
body.menu-open .nav-toggle .bars i:nth-child(1){ transform:translateY(6px) rotate(45deg); }
body.menu-open .nav-toggle .bars i:nth-child(2){ opacity:0; }
body.menu-open .nav-toggle .bars i:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* slide-out railway nav */
#railnav{
  position:fixed; inset:0; z-index:39;
  background:rgba(8,8,9,.94);
  backdrop-filter:blur(8px) saturate(.8);
  display:flex; align-items:center;
  padding:0 var(--pad);
  opacity:0; visibility:hidden; transition:opacity .5s, visibility .5s;
}
body.menu-open #railnav{ opacity:1; visibility:visible; }
.railnav-inner{ width:100%; max-width:var(--maxw); margin:0 auto; position:relative; }
.railnav-line{ position:absolute; left:0; right:0; top:50%; height:2px;
  background:repeating-linear-gradient(to right, var(--gunmetal) 0 18px, transparent 18px 30px); }
.railnav-items{ display:flex; flex-wrap:wrap; gap:8px 0; list-style:none; margin:0; padding:0;
  position:relative; }
.railnav-items li{ flex:1 1 22%; min-width:200px; padding:40px 0; }
.railnav-items a{ display:flex; flex-direction:column; gap:6px; align-items:flex-start;
  opacity:.55; transform:translateY(0); transition:.35s; }
.railnav-items a:hover{ opacity:1; }
.railnav-items .stop{ width:14px; height:14px; border-radius:50%; border:2px solid var(--gun-2);
  background:var(--black); margin-bottom:14px; transition:.3s; }
.railnav-items a:hover .stop{ background:var(--rust); border-color:var(--rust-bright); box-shadow:0 0 16px var(--rust); }
.railnav-items .nlabel{ font-family:var(--ff-display); font-size:clamp(28px,4vw,52px); line-height:.9; }
.railnav-items .nidx{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.3em; color:var(--rust); }

/* ---------- LOCOMOTIVE PROGRESS ---------- */
#progress{
  position:fixed; left:0; right:0; bottom:0; z-index:35; height:54px;
  display:flex; align-items:center;
  padding:0 var(--pad);
  pointer-events:none;
}
#progress .track{ position:relative; flex:1; height:2px; background:rgba(236,235,231,.14); }
#progress .fill{ position:absolute; left:0; top:0; height:100%; width:0%; background:var(--rust); }
#progress .loco{ position:absolute; top:50%; left:0; transform:translate(-50%,-50%);
  display:flex; align-items:center; gap:0; }
.loco-svg{ width:44px; height:24px; filter:drop-shadow(0 0 8px rgba(0,0,0,.6)); }
#progress .pct{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.25em; color:var(--paper-dim);
  margin-left:18px; min-width:120px; }
@media(max-width:640px){ #progress .pct{ display:none } }

/* ============================================================
   HERO
   ============================================================ */
#hero{ justify-content:flex-end; padding-bottom:clamp(90px,16vh,180px); }
#hero .est{ margin-bottom:24px; }
#hero h1{ margin:0; }
.hero-title{ font-family:var(--ff-display); line-height:.82;
  font-size:clamp(64px, 16vw, 280px); letter-spacing:-.01em; }
.hero-title .l2{ display:block; color:transparent; -webkit-text-stroke:2px var(--paper-dim);
  text-stroke:2px var(--paper-dim); }
.hero-tag{ margin-top:28px; max-width:640px; font-size:clamp(16px,2vw,22px);
  color:var(--paper-dim); font-weight:500; }
.hero-scroll{ position:absolute; left:var(--pad); bottom:78px; display:flex; align-items:center; gap:14px;
  font-family:var(--ff-mono); font-size:11px; letter-spacing:.3em; color:var(--mute); }
.hero-scroll .ln{ width:60px; height:1px; background:var(--mute); position:relative; overflow:hidden; }
.hero-scroll .ln::after{ content:""; position:absolute; left:-30%; top:0; width:30%; height:100%;
  background:var(--rust); animation:scrollln 2s linear infinite; }
@keyframes scrollln{to{left:130%}}

/* ============================================================
   ZENEKAR (about)
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,5vw,90px); align-items:start; }
.about-lead{ font-family:var(--ff-display); font-size:clamp(34px,5vw,80px); line-height:.92; margin:18px 0 0; }
.about-body p{ font-size:clamp(15px,1.4vw,19px); color:var(--paper-dim); margin:0 0 18px; max-width:46ch; }
.about-stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); margin-top:30px; }
.about-stats .stat{ background:var(--black); padding:26px 22px; }
.about-stats .n{ font-family:var(--ff-display); font-size:clamp(40px,5vw,68px); line-height:.9; color:var(--rust-bright); }
.about-stats .l{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.25em; color:var(--mute); margin-top:8px; }
@media(max-width:860px){ .about-grid{ grid-template-columns:1fr; } }

/* ============================================================
   TAGOK (members)
   ============================================================ */
.members{ display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); margin-top:48px; }
.member{ background:linear-gradient(to bottom, rgba(20,20,22,.4), rgba(8,8,9,.85));
  padding:0; position:relative; overflow:hidden; min-height:440px; display:flex; flex-direction:column; justify-content:flex-end; }
.member .ph{ position:absolute; inset:0; z-index:0; }
.member .meta{ position:relative; z-index:2; padding:24px 22px 28px;
  background:linear-gradient(to top, rgba(8,8,9,.95), transparent); }
.member .num{ position:absolute; top:18px; left:22px; z-index:2; font-family:var(--ff-mono);
  font-size:12px; letter-spacing:.3em; color:var(--rust); }
.member .role{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.3em; color:var(--rust-bright); }
.member .mname{ font-family:var(--ff-display); font-size:26px; line-height:.95; margin:8px 0 0; }
.member .mnote{ font-size:13px; color:var(--mute); margin-top:10px; max-width:24ch;
  max-height:0; opacity:0; overflow:hidden; transition:.4s; }
.member:hover .mnote{ max-height:80px; opacity:1; }
/* image-slot fills the card background */
.member image-slot{ display:block; position:absolute; inset:0; z-index:0; }
@media(max-width:1100px){ .members{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:700px){ .members{ grid-template-columns:repeat(2,1fr); } .member{ min-height:300px; } }

/* ============================================================
   ZENE (albums as wagons)
   ============================================================ */
#zene{ }
.wagons-rail{ position:relative; margin-top:60px; }
.wagons-rail .rail{ position:absolute; left:0; right:0; bottom:-2px; height:3px;
  background:repeating-linear-gradient(to right, var(--steel) 0 22px, transparent 22px 40px); }
.wagons{ display:flex; gap:26px; overflow-x:auto; padding:0 0 40px; scroll-snap-type:x mandatory;
  -ms-overflow-style:none; scrollbar-width:none; }
.wagons::-webkit-scrollbar{ display:none; }
.wagon{ scroll-snap-align:start; flex:0 0 clamp(280px,32vw,420px); position:relative;
  background:linear-gradient(155deg, #16161a, #0c0c0d); border:1px solid var(--line-strong);
  padding:30px 28px 34px; min-height:320px; display:flex; flex-direction:column; justify-content:space-between; }
.wagon::before{ content:""; position:absolute; left:50%; bottom:-22px; transform:translateX(-50%);
  width:70%; height:2px; background:var(--steel); } /* coupling shadow */
.wagon .wheels{ position:absolute; bottom:-20px; left:0; right:0; display:flex; justify-content:space-between; padding:0 28px; }
.wagon .wheels span{ width:22px; height:22px; border-radius:50%; background:#0a0a0b;
  border:3px solid var(--gunmetal); }
.wagon .wtag{ display:inline-block; align-self:flex-start; font-family:var(--ff-mono); font-size:10px;
  letter-spacing:.25em; padding:5px 10px; border:1px solid var(--line-strong); color:var(--paper-dim); }
.wagon .wyear{ font-family:var(--ff-mono); font-size:13px; letter-spacing:.2em; color:var(--rust); }
.wagon .wtitle{ font-family:var(--ff-display); font-size:clamp(30px,3.4vw,46px); line-height:.92; margin:14px 0 0; }
.wagon .wnote{ color:var(--mute); font-size:14px; margin-top:12px; }
.wagon .wfoot{ display:flex; justify-content:space-between; align-items:flex-end; margin-top:24px; }
.wagon .wfoot .tr{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.2em; color:var(--paper-dim); }
.wagon .play{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line-strong);
  display:grid; place-items:center; transition:.3s; }
.wagon .play svg{ width:14px; height:14px; fill:var(--paper); margin-left:2px; }
.wagon:hover .play{ background:var(--rust); border-color:var(--rust); }
.wagon:hover .play svg{ fill:#000; }
.wagon .colorbar{ position:absolute; top:0; left:0; width:100%; height:4px; }

/* ============================================================
   VIDEÓK
   ============================================================ */
.videos{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; }
.vid{ position:relative; aspect-ratio:16/9; overflow:hidden; border:1px solid var(--line);
  background:#0a0a0b; display:flex; align-items:flex-end; }
.vid .ph{ position:absolute; inset:0; z-index:0; }
.vid .vmeta{ position:relative; z-index:2; padding:20px; width:100%;
  background:linear-gradient(to top, rgba(8,8,9,.92), transparent); }
.vid .vtitle{ font-family:var(--ff-display); font-size:24px; line-height:.95; }
.vid .vsub{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.2em; color:var(--mute); margin-top:6px; }
.vid .vlen{ position:absolute; top:16px; right:16px; z-index:2; font-family:var(--ff-mono);
  font-size:11px; letter-spacing:.1em; color:var(--paper); background:rgba(0,0,0,.5); padding:3px 8px; }
.vid .vplay{ position:absolute; inset:0; z-index:3; display:grid; place-items:center; }
.vid .vplay span{ width:64px; height:64px; border-radius:50%; border:2px solid rgba(236,235,231,.7);
  display:grid; place-items:center; transition:.3s; }
.vid .vplay span svg{ width:18px; height:18px; fill:var(--paper); margin-left:3px; }
.vid:hover .vplay span{ background:var(--rust); border-color:var(--rust); transform:scale(1.08); }
.vid:hover .vplay span svg{ fill:#000; }
@media(max-width:860px){ .videos{ grid-template-columns:1fr; } }

/* ============================================================
   KONCERTEK (stations)
   ============================================================ */
#koncertek{ }
.stations{ position:relative; margin-top:56px; padding-left:46px; }
.stations .line{ position:absolute; left:13px; top:6px; bottom:6px; width:2px;
  background:linear-gradient(to bottom, var(--rust) 0%, var(--steel) 100%); }
.station{ position:relative; display:grid; grid-template-columns:140px 1fr auto; gap:24px; align-items:center;
  padding:26px 0; border-bottom:1px solid var(--line); cursor:pointer; transition:.3s; }
.station:last-child{ border-bottom:none; }
.station .dot{ position:absolute; left:-39px; top:50%; transform:translateY(-50%);
  width:18px; height:18px; border-radius:50%; background:var(--black); border:2px solid var(--gun-2); transition:.3s; }
.station:hover .dot{ background:var(--rust); border-color:var(--rust-bright); box-shadow:0 0 18px var(--rust); }
.station .sdate{ font-family:var(--ff-mono); font-size:14px; letter-spacing:.12em; color:var(--paper-dim); }
.station .scity{ font-family:var(--ff-display); font-size:clamp(28px,3.4vw,46px); line-height:.9; }
.station .svenue{ font-size:13px; color:var(--mute); margin-top:4px; font-family:var(--ff-mono); letter-spacing:.1em; }
.station .sright{ display:flex; align-items:center; gap:18px; }
.station .sstatus{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.2em; padding:6px 12px;
  border:1px solid var(--line-strong); color:var(--paper-dim); white-space:nowrap; }
.station .sstatus.sold{ color:var(--red-bright); border-color:rgba(179,42,31,.5); }
.station .sstatus.last{ color:var(--rust-bright); border-color:rgba(215,126,44,.5); }
.station .arrow{ width:34px; height:34px; display:grid; place-items:center; border:1px solid var(--line);
  transition:.3s; }
.station .arrow svg{ width:14px; height:14px; stroke:var(--paper); fill:none; }
.station:hover{ padding-left:14px; }
.station:hover .arrow{ background:var(--rust); border-color:var(--rust); }
.station:hover .arrow svg{ stroke:#000; }
.saddress{ font-size:12px; color:var(--mute); font-family:var(--ff-mono); letter-spacing:.1em; margin-top:2px; }
.btn-ott{ font-family:var(--ff-display); font-size:22px; letter-spacing:.06em; padding:14px 32px;
  background:var(--rust); color:#000; border:none; cursor:pointer; transition:.3s;
  text-transform:uppercase; white-space:nowrap; }
.btn-ott:hover{ background:var(--rust-bright); transform:translateX(4px); }
@media(max-width:760px){
  .station{ grid-template-columns:1fr; gap:6px; padding:22px 0; }
  .station .sright{ margin-top:10px; }
}

/* ============================================================
   ZENE — info text (no albums)
   ============================================================ */
.zene-title{ font-family:var(--ff-display); font-size:clamp(40px,8vw,130px); line-height:.84; margin:12px 0 0; }
.zene-desc{ font-size:clamp(17px,1.8vw,24px); color:var(--paper-dim); max-width:56ch; margin:24px 0 0; line-height:1.6; }
.zene-booking{ display:flex; align-items:baseline; gap:18px; margin-top:32px; flex-wrap:wrap; }
.booking-label{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.3em; color:var(--rust); }
.booking-phone{ font-family:var(--ff-display); font-size:clamp(32px,5vw,72px); color:var(--paper); line-height:.9;
  border-bottom:3px solid var(--rust); padding-bottom:4px; transition:.3s; }
.booking-phone:hover{ color:var(--rust-bright); }

/* ============================================================
   GALÉRIA
   ============================================================ */
.gal{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:200px; gap:8px; margin-top:48px; }
.gal .cell{ position:relative; overflow:hidden; border:1px solid var(--line); }
.gal .cell .ph{ position:absolute; inset:0; transition:transform .6s; }
.gal .cell:hover .ph{ transform:scale(1.06); }
.gal .cell .lab{ position:absolute; left:0; bottom:0; z-index:2; font-family:var(--ff-mono);
  font-size:10px; letter-spacing:.2em; color:var(--paper-dim); padding:10px 12px; }
.gal .cell:nth-child(1){ grid-column:span 3; grid-row:span 2; }
.gal .cell:nth-child(2){ grid-column:span 3; }
.gal .cell:nth-child(3){ grid-column:span 2; }
.gal .cell:nth-child(4){ grid-column:span 1; }
.gal .cell:nth-child(5){ grid-column:span 2; grid-row:span 1; }
.gal .cell:nth-child(6){ grid-column:span 4; }
@media(max-width:760px){ .gal{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gal .cell{ grid-column:span 1 !important; grid-row:span 1 !important; } }

/* ============================================================
   KAPCSOLAT
   ============================================================ */
#kapcsolat{ min-height:auto; padding-bottom:120px; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); align-items:end; }
.contact-big{ font-family:var(--ff-display); font-size:clamp(48px,9vw,160px); line-height:.84; }
.contact-big .stroke{ color:transparent; -webkit-text-stroke:2px var(--rust); }
.contact-info{ display:flex; flex-direction:column; gap:22px; }
.contact-info .row{ border-top:1px solid var(--line); padding-top:14px; }
.contact-info .row .ck{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.3em; color:var(--mute); }
.contact-info .row .cv{ font-size:clamp(18px,2vw,26px); margin-top:6px; }
.socials{ display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }
.socials a{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.2em; padding:9px 14px;
  border:1px solid var(--line-strong); transition:.3s; }
.socials a:hover{ background:var(--rust); color:#000; border-color:var(--rust); }
.fb-big{ font-family:var(--ff-display); font-size:clamp(20px,2.4vw,34px); line-height:1.2;
  color:var(--rust-bright); border-bottom:2px solid var(--rust); padding-bottom:4px;
  display:inline-block; margin-top:12px; transition:.3s; }
.fb-big:hover{ color:var(--paper); border-color:var(--paper); }
@media(max-width:760px){ .contact-grid{ grid-template-columns:1fr; align-items:start; } }

/* footer */
#colophon{ position:relative; z-index:10; padding:30px var(--pad) 90px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; }
#colophon .mono{ color:var(--mute); }

/* ---------- section header block ---------- */
.shead{ display:flex; align-items:baseline; gap:20px; flex-wrap:wrap; }
.shead .stitle{ font-family:var(--ff-display); font-size:clamp(40px,7vw,120px); line-height:.84; }
.shead .sidx{ font-family:var(--ff-mono); font-size:12px; letter-spacing:.3em; color:var(--rust); }
.sintro{ max-width:52ch; color:var(--paper-dim); margin-top:18px; font-size:clamp(15px,1.5vw,19px); }

/* ============================================================
   REVEAL ANIMATIONS (driven by .in class)
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  [data-reveal]{ opacity:0; transform:translateY(38px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
  [data-reveal].in{ opacity:1; transform:none; }
  [data-reveal="left"]{ transform:translateX(-46px); }
  [data-reveal="left"].in{ transform:none; }
  [data-reveal-stagger] > *{ opacity:0; transform:translateY(32px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
  [data-reveal-stagger].in > *{ opacity:1; transform:none; }
}

/* placeholder imagery */
.ph{ background-color:#0e0e10;
  background-image:repeating-linear-gradient(135deg, rgba(120,125,133,.08) 0 14px, rgba(120,125,133,0) 14px 28px);
  display:grid; place-items:center; }
.ph .phlab{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.2em; color:rgba(180,177,170,.5);
  border:1px dashed rgba(180,177,170,.25); padding:6px 10px; }

/* intro loader */
#loader{ position:fixed; inset:0; z-index:100; background:var(--black); display:flex;
  align-items:center; justify-content:center; flex-direction:column; gap:24px; transition:opacity .8s, visibility .8s; }
#loader.gone{ opacity:0; visibility:hidden; }
#loader .lmark{ font-family:var(--ff-display); font-size:clamp(40px,9vw,120px); line-height:.84; text-align:center; }
#loader .lbar{ width:min(360px,70vw); height:2px; background:rgba(236,235,231,.14); position:relative; overflow:hidden; }
#loader .lbar i{ position:absolute; left:0; top:0; height:100%; width:0%; background:var(--rust); }
#loader .lpct{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.3em; color:var(--mute); }

@media(max-width:600px){
  .section{ padding:clamp(70px,12vh,120px) var(--pad); }
  .videos{ gap:12px; }
}
