/* ============================================================================
   MORITZ GRUND — layout & sections (lean / mood-first)
   ========================================================================== */

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,72px)}
section{position:relative}
/* integer / nearest-neighbour upscaling — no bilinear blur on any image */
img,image-slot{image-rendering:pixelated}
image-slot::part(image){image-rendering:pixelated}
/* full-bleed photos drift behind the page (mg-parallax.js) — give headroom */
.plate image-slot[data-parallax],.duo image-slot[data-parallax]{top:-14%;height:128%;bottom:auto;will-change:transform}

/* ---------------------------------------------------------------------------
   HERO — no header. Huge condensed name vs Times italic. Tall image panel.
--------------------------------------------------------------------------- */
.hero{min-height:100svh;display:grid;grid-template-columns:1.32fr .68fr;align-items:stretch;border-bottom:1px solid var(--line)}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:clamp(56px,8vh,120px) clamp(20px,5vw,72px);position:relative}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;position:absolute;top:clamp(20px,3vh,34px);left:clamp(20px,5vw,72px);right:clamp(20px,5vw,72px)}
.hero-name{font-family:var(--serif);font-weight:400;text-transform:none;line-height:.9;letter-spacing:-.015em;font-size:clamp(58px,8.5vw,128px);color:var(--ink)}
.hero-name .hn-1{display:block}
.hero-name .hn-2{display:block;font-style:italic;margin-left:.04em}
.hero-name .amp{font-family:var(--serif);font-style:italic;font-weight:400;text-transform:none}
.hero-sub{margin-top:clamp(18px,3vh,40px);display:flex;flex-direction:column;gap:14px;max-width:34ch}
.hero-sub .lead-i{color:var(--ink-2)}
.hero-coords{position:absolute;left:clamp(20px,5vw,72px);bottom:clamp(20px,3vh,30px);display:flex;gap:22px;flex-wrap:wrap}
.hero-right{position:relative;border-left:1px solid var(--line);overflow:hidden;background:var(--paper-2);min-height:46vh}
.hero-right image-slot{position:absolute;inset:0;width:100%;height:100%}
.hero-right .rtag{position:absolute;z-index:3;left:16px;bottom:14px;background:var(--paper);color:var(--ink);padding:6px 10px}
@media (max-width:880px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{order:1;min-height:74svh;padding-top:clamp(86px,16vh,140px)}
  .hero-right{order:2;border-left:0;border-top:1px solid var(--line);min-height:62vh}
}

/* ---------------------------------------------------------------------------
   HERO — HUD / "upload sequence" (V9-A) : dark frame, minimal centred name,
   framed halftone portrait on the right. Overrides the light split-hero above.
--------------------------------------------------------------------------- */
.hero-hud{
  --xtile: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'%3E%3Cpath d='M2.5 2.5l5 5M7.5 2.5l-5 5' stroke='%2307b8d8' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");
  background:#0a0905;color:var(--paper);border-bottom:1px solid #2a2719;
  grid-template-columns:1.05fr .95fr;position:relative;overflow:hidden;
}
/* whole-hero inner hairline frame */
.hero-hud .hud-frame{position:absolute;inset:clamp(16px,2.4vw,30px);z-index:2;pointer-events:none;
  --bc:#2a2719;--bl:26px;--bt:1.5px;
  background:
    linear-gradient(var(--bc),var(--bc)) 0 0/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 0/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 0/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 0/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 100%/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 100%/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 100%/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 100%/var(--bt) var(--bl) no-repeat;
  border:1px solid rgba(42,39,25,.55);
}
.hero-hud .hud-hex{position:absolute;right:clamp(34px,4vw,60px);top:clamp(30px,4vw,54px);z-index:5;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:#6c6650}
/* dash–diamond markers */
.hero-hud .hud-mk{position:absolute;z-index:5;display:flex;align-items:center;gap:5px;pointer-events:none}
.hero-hud .hud-mk i{display:block;height:1.5px;width:15px;background:var(--gold)}
.hero-hud .hud-mk b{display:block;width:6px;height:6px;background:var(--gold);transform:rotate(45deg)}
.hero-hud .hud-mk.cy i{background:var(--cyan)}
.hero-hud .hud-mk.cy b{background:var(--cyan)}
.hero-hud .hud-mk.tl{left:clamp(34px,4vw,56px);top:clamp(30px,4vw,46px)}
.hero-hud .hud-mk.br{right:clamp(34px,4vw,56px);bottom:clamp(30px,4vw,40px)}
/* mono micro-label */
.hero-hud .hud-ml{font-family:var(--mono);text-transform:uppercase;letter-spacing:.24em;font-size:12px;color:#7d7660}
.hero-hud .hud-ml.cy{color:var(--cyan)}

/* LEFT — minimal centred stack (study A) */
.hero-hud .hud-left{display:flex;flex-direction:column;justify-content:center;gap:clamp(20px,2.6vh,30px);
  padding:clamp(56px,8vh,120px) clamp(32px,5vw,80px);position:relative;z-index:3}
.hero-hud .hero-name{font-family:var(--serif);font-weight:400;text-transform:none;
  line-height:.86;letter-spacing:-.015em;font-size:clamp(56px,7vw,104px);color:var(--paper)}
.hero-hud .hero-name .hn-1{display:block;font-style:normal;margin:0}
.hero-hud .hero-name .hn-2{display:block;font-style:normal;margin:0;color:var(--gold)}
.hero-hud .hud-rule{position:relative;width:clamp(180px,18vw,240px);height:2px;background:var(--cyan)}
.hero-hud .hud-rule .node{position:absolute;top:-4px;left:40%;width:10px;height:10px;background:var(--gold)}

/* RIGHT — framed halftone portrait wrapping the image-slot */
.hero-hud .hud-right{position:relative;z-index:3;display:flex;align-items:stretch;justify-content:center;
  padding:clamp(30px,4vh,52px) clamp(40px,6vw,90px)}
.hero-hud .port-frame{position:relative;width:100%;height:auto;min-height:0;align-self:stretch;background:#070603;overflow:hidden}
.hero-hud .port-frame image-slot{position:absolute;inset:0;width:100%;height:100%;image-rendering:pixelated}
.hero-hud .port-frame image-slot::part(img),
.hero-hud .port-frame img{filter:grayscale(1) brightness(.82) contrast(1.12);image-rendering:pixelated}
.hero-hud .port-hatch{position:absolute;inset:0;background-image:var(--xtile);background-size:6px 6px;
  mix-blend-mode:screen;opacity:.32;pointer-events:none}
.hero-hud .port-scan{position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.32) 3px 4px)}
/* gold corner brackets hugging the portrait */
.hero-hud .hud-brk{position:absolute;inset:calc(clamp(30px,4vh,52px) - 8px) calc(clamp(40px,6vw,90px) - 8px);
  pointer-events:none;z-index:4;--bc:var(--gold);--bl:24px;--bt:1.5px;
  background:
    linear-gradient(var(--bc),var(--bc)) 0 0/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 0/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 0/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 0/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 100%/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 100%/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 100%/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 100%/var(--bt) var(--bl) no-repeat;}
.hero-hud .hud-vl{position:absolute;left:calc(clamp(40px,6vw,96px) - 30px);top:0;bottom:0;z-index:4;
  display:flex;align-items:center;writing-mode:vertical-rl;
  font-family:var(--mono);font-weight:700;letter-spacing:.34em;text-transform:uppercase;
  font-size:12px;color:var(--cyan)}
@media (max-width:880px){
  .hero-hud{grid-template-columns:1fr}
  .hero-hud .hud-left{order:1;text-align:left;align-items:flex-start;padding-top:clamp(80px,15vh,130px)}
  .hero-hud .hud-right{order:2;padding-top:0}
  .hero-hud .port-frame{height:54vh}
  .hero-hud .hud-vl{left:auto;right:6px}
}

/* --- HERO HUD on the LIGHT (v1) palette: bone ground, ink text. Keeps the
   framed-terminal layout; only the colour scheme flips. The portrait panel
   stays dark for contrast, with its gold brackets + cyan caption intact. --- */
.hero-hud{background:var(--paper);color:var(--ink);border-bottom:1px solid var(--line)}
.hero-hud .hud-frame{--bc:var(--line);border:1px solid var(--line)}
.hero-hud .hud-hex{color:var(--ink-3)}
.hero-hud .hud-ml{color:var(--ink-3)}
.hero-hud .hud-ml.cy{color:var(--cyan-deep)}
.hero-hud .hero-name{color:var(--ink)}
.hero-hud .hero-name .hn-2{color:var(--ink)}
.hero-hud .hud-rule{background:var(--cyan)}
.hero-hud .hud-rule .node{background:var(--gold)}
.hero-hud .hud-vl{color:var(--cyan-deep)}
/* drop the near-black portrait panel on the light hero — let it sit on bone */
.hero-hud .port-frame{background:transparent}

/* ---------------------------------------------------------------------------
   PLATE — full-bleed zoomed mood image with a big serif numeral
--------------------------------------------------------------------------- */
.plate{position:relative;height:clamp(440px,86vh,940px);overflow:hidden;background:var(--paper-2);border-bottom:1px solid var(--line)}
.plate image-slot{position:absolute;inset:0;width:100%;height:100%}
.plate .px-canvas{z-index:1}
/* cyan cross-hatch overlay — the same "dotted" filter used on the contact sheet */
.plate,.duo .cell{--xtile: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'%3E%3Cpath d='M2.5 2.5l5 5M7.5 2.5l-5 5' stroke='%2307b8d8' stroke-width='1.4' fill='none'/%3E%3C/svg%3E")}
.plate::after,.duo .cell::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:var(--xtile);background-size:6px 6px;mix-blend-mode:screen;opacity:.16}
.plate .pcap{position:absolute;z-index:3;display:flex;align-items:flex-end;gap:clamp(12px,1.5vw,22px)}
.plate .pcap.bl{left:clamp(20px,4vw,56px);bottom:clamp(22px,4vw,48px)}
.plate .pcap.tl{left:clamp(20px,4vw,56px);top:clamp(22px,4vw,48px);align-items:flex-start}
.plate .num{text-shadow:3px 3px 0 var(--gold)}
.plate .tag{background:var(--paper);color:var(--ink);padding:7px 11px;transform:translateY(-.4em)}

/* duo — two zoomed crops side by side */
.duo{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line)}
.duo .cell{position:relative;height:clamp(340px,58vh,680px);overflow:hidden;background:var(--paper-2)}
.duo .cell+.cell{border-left:1px solid var(--line)}
.duo image-slot{position:absolute;inset:0;width:100%;height:100%}
.duo .tag{position:absolute;z-index:3;left:14px;bottom:12px;background:var(--paper);color:var(--ink);padding:6px 10px}
@media (max-width:720px){.duo{grid-template-columns:1fr}.duo .cell+.cell{border-left:0;border-top:1px solid var(--line)}}

/* ---------------------------------------------------------------------------
   LINKS — dark block, huge type, fine dots
--------------------------------------------------------------------------- */
.links{background:var(--ink);color:var(--paper);padding:clamp(60px,11vh,150px) 0;position:relative}
.links .tag{color:var(--paper)}
.links .lhead{display:flex;align-items:baseline;gap:18px;margin-bottom:clamp(30px,5vw,60px)}
.links .lhead .serif-i{font-size:clamp(20px,2.4vw,30px);color:var(--cyan)}
.plink{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:clamp(20px,3.2vw,42px) 0;border-top:1px solid #322f24;transition:padding-left .25s,color .25s;position:relative}
.plink:last-child{border-bottom:1px solid #322f24}
.plink .pn{font-family:var(--serif);font-weight:400;text-transform:none;font-size:clamp(38px,7vw,104px);line-height:.86;letter-spacing:-.015em}
.plink .pmeta{font-family:var(--serif);font-style:italic;font-size:clamp(15px,1.6vw,21px);color:#b9b29c}
.plink .go{font-family:var(--mono);font-size:clamp(20px,3vw,42px);color:var(--paper);transition:transform .25s,color .25s}
.plink:hover{padding-left:clamp(10px,1.6vw,26px)}
.plink:hover .pn{color:var(--cyan)}
.plink:hover .go{color:var(--cyan);transform:translateX(10px)}
.plink.gold:hover .pn,.plink.gold:hover .go{color:var(--gold)}
@media (max-width:620px){.plink .pmeta{display:none}}

/* ---------------------------------------------------------------------------
   DATES
--------------------------------------------------------------------------- */
.dates{padding:clamp(60px,11vh,150px) 0}
.dhead{display:flex;align-items:baseline;gap:18px;margin-bottom:clamp(26px,4vw,48px);flex-wrap:wrap}
.dhead h2{font-size:clamp(44px,9vw,120px)}
.dhead .serif-i{font-size:clamp(22px,3vw,40px);color:var(--cyan-deep)}
.gig-list{list-style:none;margin:0;padding:0;border-top:2px solid var(--ink)}
.gig{display:grid;grid-template-columns:minmax(92px,130px) minmax(150px,1fr) minmax(0,1.3fr) minmax(96px,auto);
  align-items:center;gap:clamp(14px,3vw,40px);padding:clamp(16px,2.3vw,28px) 2px;border-bottom:1px solid var(--line);transition:background .2s}
.gig:hover{background:var(--paper-2)}
.g-date{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--ink-3);display:flex;align-items:baseline;gap:7px;white-space:nowrap}
.g-date b{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(34px,4vw,58px);color:var(--ink);letter-spacing:-.01em}
.g-mo{color:var(--cyan-deep)}
.g-yr{color:var(--ink-3)}
.g-city{font-family:var(--cond);font-weight:800;text-transform:uppercase;font-size:clamp(24px,3vw,44px);line-height:.9;color:var(--ink)}
.g-venue{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);line-height:1.5}
.g-act{justify-self:end;text-align:right}
.g-tix{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--on-cyan);
  background:var(--cyan);padding:10px 15px;white-space:nowrap;display:inline-block;transition:background .2s,transform .2s}
.g-tix:hover{background:var(--cyan-deep);transform:translateY(-2px)}
.g-flag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.g-flag.sold{color:var(--gold-deep)}
.g-flag.tba,.g-flag.past{color:var(--ink-3)}
.gig.past{opacity:.5}
.gig.past .g-city,.gig.past .g-date b{text-decoration:line-through;text-decoration-color:var(--gold-deep);color:var(--ink-3)}
.gigs-empty{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2vw,26px);color:var(--cyan-deep);margin-top:18px}
.gig-archive{margin-top:clamp(36px,6vw,72px)}
.gig-archive .tag{color:var(--ink-3);margin-bottom:12px}
@media (max-width:640px){
  .gig{grid-template-columns:60px 1fr;column-gap:14px;row-gap:3px;align-items:start;padding:16px 2px}
  .g-date{grid-column:1;grid-row:1/4;flex-direction:column;align-items:flex-start;gap:0}
  .g-date b{font-size:30px;line-height:1}
  .g-city{grid-column:2;font-size:clamp(24px,8vw,34px)}
  .g-venue{grid-column:2}
  .g-act{grid-column:2;justify-self:start;text-align:left;margin-top:8px}
}

/* ---------------------------------------------------------------------------
   CONTACT — cyan crop, deep overlay
--------------------------------------------------------------------------- */
.contact{position:relative;color:var(--paper);padding:clamp(80px,15vh,200px) 0;overflow:hidden;background:var(--ink)}
.contact::before{content:"";position:absolute;inset:0;background:url('img/contact.jpg') center/cover;z-index:0}
.contact::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(7,38,29,.9) 28%,rgba(7,38,29,.5))}
.contact>.wrap{position:relative;z-index:2}
.contact .tag{color:var(--paper)}
.contact .big{font-family:var(--serif);font-weight:400;text-transform:none;line-height:.86;letter-spacing:-.02em;font-size:clamp(52px,10vw,156px);margin:.1em 0 0}
.contact .big .amp{font-family:var(--serif);font-style:italic;font-weight:400;text-transform:none;color:var(--gold)}
.contact .cbtn{display:inline-flex;align-items:center;gap:.5em;background:var(--gold);color:var(--on-gold);
  font-family:var(--mono);font-weight:700;font-size:clamp(15px,1.6vw,18px);letter-spacing:.12em;text-transform:uppercase;
  padding:clamp(14px,1.8vw,20px) clamp(24px,3vw,40px);margin-top:clamp(28px,4vw,48px);transition:transform .2s,background .2s}
.contact .cbtn:hover{background:var(--paper);transform:translateY(-3px)}

/* ---------------------------------------------------------------------------
   FOOTER + LEGAL
--------------------------------------------------------------------------- */
.foot{background:var(--ink);color:var(--paper);padding:clamp(48px,8vh,90px) 0 clamp(40px,7vh,72px);border-top:1px solid #322f24}
.foot-grid{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:30px}
.foot .wm{font-family:var(--serif);font-weight:400;text-transform:none;font-size:clamp(38px,8vw,118px);line-height:.84;letter-spacing:-.015em}
.foot.hud-sec .wm .g{color:var(--gold)}
.foot .wm .amp{font-family:var(--serif);font-style:italic;font-weight:400;text-transform:none;color:var(--cyan)}
.foot-right{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.foot-right a{font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:#bbb49e;transition:color .2s}
.foot-right a:hover{color:var(--paper)}
.legal-links{margin-top:30px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.legal-link{background:none;border:0;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#928c78;cursor:pointer;padding:0;transition:color .2s}
.legal-link:hover{color:var(--paper)}
.legal-sep{color:#54513f}
.foot-fine{margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:#6f6a57}

.legal-modal{position:fixed;inset:0;z-index:900;display:none}
.legal-modal.open{display:block}
.legal-backdrop{position:absolute;inset:0;background:rgba(23,22,15,.6);backdrop-filter:blur(3px)}
.legal-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(720px,92vw);max-height:86vh;overflow-y:auto;
  background:var(--paper);box-shadow:0 40px 100px -24px rgba(23,22,15,.5);padding:clamp(26px,5vw,52px)}
.legal-close{position:sticky;top:0;float:right;margin:-6px -6px 0 0;background:var(--paper);border:1px solid var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);padding:8px 13px;cursor:pointer;transition:border-color .2s,color .2s}
.legal-close:hover{border-color:var(--gold-deep);color:var(--gold-deep)}
.legal-doc{color:var(--ink-2)}
.legal-doc+.legal-doc{margin-top:44px;padding-top:36px;border-top:1px solid var(--line)}
.legal-doc h2{font-size:clamp(28px,4.5vw,42px);color:var(--ink);margin:0 0 16px}
.legal-doc h3{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan-deep);margin:24px 0 8px}
.legal-doc p{font-family:var(--sans);font-size:14px;line-height:1.7;color:var(--ink-2);margin:0 0 6px}
.legal-doc strong{color:var(--ink)}
.legal-doc a{color:var(--cyan-deep)}
.legal-doc .legal-note{font-family:var(--mono);font-size:11px;letter-spacing:.02em;line-height:1.6;color:var(--ink-3);margin-bottom:14px}

/* ===========================================================================
   HUD SECTIONS — carry the hero's framed-terminal language into the
   lower sections: flat ink ground, hairline corner frame, mono "//" labels,
   cyan rule + gold node, scattered hex codes & diamond marks.
   =========================================================================== */
.hud-sec{--xtile: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'%3E%3Cpath d='M2.5 2.5l5 5M7.5 2.5l-5 5' stroke='%2307b8d8' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");
  background:#0a0905;color:var(--paper);position:relative;border-top:1px solid #2a2719}
.hud-sec>.wrap{position:relative;z-index:3}
/* hairline corner-bracket frame */
.sec-frame{position:absolute;inset:clamp(14px,2vw,26px);z-index:1;pointer-events:none;
  border:1px solid rgba(42,39,25,.5);--bc:#3a3422;--bl:24px;--bt:1.5px;
  background:
    linear-gradient(var(--bc),var(--bc)) 0 0/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 0/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 0/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 0/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 100%/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 0 100%/var(--bt) var(--bl) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 100%/var(--bl) var(--bt) no-repeat,
    linear-gradient(var(--bc),var(--bc)) 100% 100%/var(--bt) var(--bl) no-repeat;}
.sec-hex{position:absolute;right:clamp(30px,4.5vw,58px);top:clamp(24px,3.4vw,44px);z-index:4;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:#6c6650}
.sec-mk{position:absolute;z-index:4;display:flex;align-items:center;gap:5px;pointer-events:none}
.sec-mk i{display:block;height:1.5px;width:15px;background:var(--gold)}
.sec-mk b{display:block;width:6px;height:6px;background:var(--gold);transform:rotate(45deg)}
.sec-mk.cy i{background:var(--cyan)}
.sec-mk.cy b{background:var(--cyan)}
/* kicker idiom — // mono label + serif title + cyan rule/gold node */
.hud-kick{display:flex;flex-direction:column;gap:clamp(12px,1.6vw,18px);margin-bottom:clamp(28px,4.5vw,56px)}
.hud-kick .k-ml{font-family:var(--mono);text-transform:uppercase;letter-spacing:.24em;font-size:12px;color:var(--cyan)}
.hud-kick .k-big{font-family:var(--serif);font-weight:400;line-height:.9;letter-spacing:-.015em;
  font-size:clamp(44px,7vw,96px);color:var(--paper);margin:0}
.hud-kick .k-big em{font-style:italic;color:var(--gold)}
.hud-rule2{position:relative;width:clamp(180px,18vw,240px);height:2px;background:var(--cyan)}
.hud-rule2 .node{position:absolute;top:-4px;left:40%;width:10px;height:10px;background:var(--gold)}

/* --- LISTEN on the HUD ground --- */
.links.hud-sec{background:#0a0905}
.links.hud-sec .plink{border-top-color:#2a2719}
.links.hud-sec .plink:last-child{border-bottom-color:#2a2719}

/* --- DATES inverted onto the HUD ground --- */
.dates.hud-sec{background:#0a0905;color:var(--paper)}
.dates.hud-sec .gig-list{border-top:2px solid #3a3422}
.dates.hud-sec .gig{border-bottom-color:#2a2719}
.dates.hud-sec .gig:hover{background:#14110a}
.dates.hud-sec .g-date{color:#8c8670}
.dates.hud-sec .g-date b{color:var(--paper)}
.dates.hud-sec .g-mo{color:var(--cyan)}
.dates.hud-sec .g-yr{color:#6c6650}
.dates.hud-sec .g-city{color:var(--paper)}
.dates.hud-sec .g-venue{color:#8c8670}
.dates.hud-sec .gigs-empty{color:var(--cyan)}
.dates.hud-sec .gig.past{opacity:.45}
.dates.hud-sec .gig.past .g-city,.dates.hud-sec .gig.past .g-date b{color:#6c6650;text-decoration-color:var(--gold-deep)}
.dates.hud-sec .gig-archive .tag{color:#6c6650}

/* --- BOOKING: drop the photo, go flat HUD --- */
.contact.hud-sec{background:#0a0905}
.contact.hud-sec::before,.contact.hud-sec::after{display:none}
.contact.hud-sec .big .amp{color:var(--gold)}
.contact.hud-sec .hud-kick{margin-bottom:0}

/* --- FOOTER --- */
.foot.hud-sec{background:#0a0905;border-top:1px solid #2a2719}
.foot.hud-sec .foot-lead{font-family:var(--mono);text-transform:uppercase;letter-spacing:.24em;
  font-size:12px;color:var(--cyan);display:block;margin-bottom:clamp(26px,4vw,44px)}
.foot.hud-sec .wm .amp{color:var(--gold)}

/* vertical machine caption shared by booking */
.sec-vl{position:absolute;top:0;bottom:0;z-index:4;display:flex;align-items:center;writing-mode:vertical-rl;
  font-family:var(--mono);font-weight:700;letter-spacing:.34em;text-transform:uppercase;font-size:12px;color:var(--cyan)}

/* ===========================================================================
   COLLAGE — a "contact sheet" between Listen & Dates. Plate-style numeral
   energy, but an asymmetric multi-crop grid, all on the HUD ground.
   =========================================================================== */
.collage{background:#0a0905;color:var(--paper);position:relative;
  padding:clamp(44px,8vh,104px) 0;border-top:1px solid #2a2719;border-bottom:1px solid #2a2719}
.collage .chead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding:0 clamp(20px,5vw,72px);max-width:var(--maxw);margin:0 auto clamp(22px,3.4vw,40px)}
.collage .chead .c-left{display:flex;flex-direction:column;gap:12px}
.collage .chead .k-ml{font-family:var(--mono);text-transform:uppercase;letter-spacing:.24em;font-size:12px;color:var(--cyan)}
.collage .chead .c-title{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(26px,3.4vw,46px);
  line-height:1;color:var(--paper)}
.collage .chead .c-mail{display:inline-flex;align-items:center;gap:.6em;align-self:flex-end;
  background:var(--gold);color:var(--on-gold);font-family:var(--mono);font-weight:700;
  font-size:clamp(12px,1.1vw,14px);letter-spacing:.14em;text-transform:uppercase;
  padding:12px 18px;white-space:nowrap;transition:transform .2s,background .2s}
.collage .chead .c-mail .go{transition:transform .2s}
.collage .chead .c-mail:hover{background:var(--cyan);color:var(--on-cyan);transform:translateY(-2px)}
.collage .chead .c-mail:hover .go{transform:translateX(4px)}
.collage .chead .c-num{font-family:var(--serif);font-style:italic;font-size:clamp(46px,7vw,104px);line-height:.8;
  color:var(--paper);letter-spacing:-.02em;text-shadow:3px 3px 0 var(--gold)}
.collage-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(52px,7vw,94px);
  gap:0;padding:0 clamp(20px,5vw,72px);max-width:var(--maxw);margin:0 auto}
.col-tile{position:relative;overflow:hidden;background:#070603}
.col-tile image-slot{position:absolute;inset:0;width:100%;height:100%;image-rendering:pixelated}
.col-tile .px-canvas{z-index:1}
.col-tile .hatch{position:absolute;inset:0;background-image:var(--xtile,none);background-size:6px 6px;
  mix-blend-mode:screen;opacity:.12;pointer-events:none;z-index:2}
.col-tile .t-cap{position:absolute;left:8px;bottom:6px;z-index:3;font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;color:#cfc7b4;background:rgba(7,6,3,.55);padding:3px 6px}
.collage{--xtile: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'%3E%3Cpath d='M2.5 2.5l5 5M7.5 2.5l-5 5' stroke='%2307b8d8' stroke-width='1.4' fill='none'/%3E%3C/svg%3E")}
.col-a{grid-column:1/5;grid-row:1/4}
.col-b{grid-column:5/8;grid-row:1/3}
.col-c{grid-column:8/13;grid-row:1/3}
.col-d{grid-column:8/11;grid-row:3/4}
.col-e{grid-column:11/13;grid-row:3/4}
.col-f{grid-column:5/8;grid-row:3/6}
.col-g{grid-column:8/13;grid-row:4/6}
.col-h{grid-column:1/5;grid-row:4/6}
@media (max-width:720px){
  .collage-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:clamp(60px,18vw,110px);gap:0}
  .col-a{grid-column:1/4;grid-row:1/3}
  .col-b{grid-column:4/7;grid-row:1/2}
  .col-c{grid-column:4/7;grid-row:2/3}
  .col-d{grid-column:1/3;grid-row:3/4}
  .col-e{grid-column:3/5;grid-row:3/4}
  .col-f{grid-column:5/7;grid-row:3/4}
  .col-g{grid-column:1/4;grid-row:4/5}
  .col-h{grid-column:4/7;grid-row:4/5}
}
@media (max-width:720px){.sec-vl,.sec-mk{display:none}}
