/* ============================================================================
   BREAKBONE — gig-review.html (DROP 01, Punk in the Park) feature layer
   Loaded AFTER styles.css. Adds only the editorial long-form pieces:
   the article masthead (black, parallax B&W hero + grain), the mono dateline,
   the flush-left black-on-white reading column, the kinetic pull-quotes
   (HN Black Condensed, line-mask reveal), the band-run section heads,
   and the 'up next' drop tail. Everything else (loader, nav, cursor, grain,
   marquee, footer, reveal, parallax JS) is inherited from the system.
   Built 15 Jun 2026 — render-checked, reduced-motion guarded, WCAG-AA.
   ============================================================================ */

/* ----------------------------------------------------------------------------
   ARTICLE MASTHEAD — black field, gig-night photo parallax behind a knockout
   title. Same machinery as the home hero (.hero__bg / __veil / __scan), so the
   shared parallax JS drives it; the title uses the .mask line-rise.
   ---------------------------------------------------------------------------- */
.feature{position:relative;min-height:var(--heroh,100svh);display:flex;flex-direction:column;
  justify-content:flex-end;padding:0 var(--gut) clamp(38px,6vh,72px);
  background:var(--black);overflow:hidden;isolation:isolate}
.feature__bg{position:absolute;inset:-14% 0 -14% 0;z-index:0;
  background:url('assets/photos/gig-night.jpg') 64% 22%/cover no-repeat;
  filter:grayscale(1) contrast(1.42) brightness(.58);will-change:transform}
.feature__veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,10,10,.66) 0%,rgba(10,10,10,.22) 30%,rgba(10,10,10,.5) 66%,rgba(10,10,10,.96) 100%)}
.feature__scan{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 1px,transparent 1px 4px)}
.feature__inner{position:relative;z-index:3;max-width:var(--mx);width:100%;margin:0 auto}

/* drop tag + dateline, mono, on the black masthead */
.feature__tag{font-family:var(--mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  color:#fff;display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.feature__tag .tick{color:var(--red)}
.feature__tag .ln{flex:1;height:1px;background:var(--rule-d);max-width:150px}
.feature__tag .drop{color:var(--red)}

/* the kinetic title — condensed, set big, each line in a rising clip-mask */
.feature__title{font-family:var(--cond);font-size:clamp(52px,11.5vw,176px);line-height:.83;
  letter-spacing:-.02em;text-transform:uppercase;color:#fff;margin:2px 0 6px}
.feature__title .red{color:var(--red)}

/* standfirst (sub-deck) — body, light on black */
.feature__stand{font-family:var(--body);font-size:clamp(16px,1.9vw,21px);line-height:1.5;
  color:#e6e6e6;max-width:620px;margin-top:18px}
.feature__stand em{font-family:var(--wm);font-style:italic;color:var(--red)}

/* byline strip — mono meta, the dateline lives here */
.feature__meta{margin-top:24px;display:flex;flex-wrap:wrap;gap:10px 26px;align-items:baseline;
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-d)}
.feature__meta b{color:#fff;font-weight:700}
.feature__meta .sep{color:var(--rule-d)}

.feature__mark{position:absolute;top:clamp(72px,10vh,108px);right:var(--gut);z-index:3;
  width:clamp(46px,6vw,82px);opacity:.95;will-change:transform}

/* ----------------------------------------------------------------------------
   READING COLUMN — black on white, flush-left, ~66ch measure.
   This is the long-form body; the home page never had one.
   ---------------------------------------------------------------------------- */
.read{background:var(--paper);color:var(--ink);padding:clamp(54px,9vh,104px) var(--gut) clamp(40px,7vh,80px)}
.read__col{max-width:none;margin:0;width:100%}
.read__wrap{max-width:var(--mx);margin:0 auto}

/* the inner measure sits flush-left under a thin top rule, Swiss-style */
.lede-para{max-width:40ch;font-family:var(--cond);font-size:clamp(23px,3vw,34px);line-height:1.08;
  text-transform:none;letter-spacing:-.01em;color:var(--ink);margin:0 0 38px}
.lede-para .red{color:var(--red)}

.prose{max-width:66ch}
.prose p{font-family:var(--body);font-size:clamp(17px,1.25vw,19px);line-height:1.68;color:#1a1a1a;
  margin:0 0 1.45em}
/* the first paragraph of each band run gets a drop-style lead-in via the run head */
.prose p:first-of-type{margin-top:0}
.prose em{font-style:italic}
.prose strong{font-weight:400;font-family:var(--cond);font-size:1.04em;letter-spacing:-.005em}

/* a hanging rule that marks the reading column open */
.read__rule{max-width:var(--mx);margin:0 auto clamp(34px,5vh,58px);height:2px;background:var(--ink);position:relative}
.read__rule::after{content:'';position:absolute;left:0;top:0;width:64px;height:2px;background:var(--red)}

/* ----------------------------------------------------------------------------
   BAND RUN — each act gets a flush-left run head: a mono set-time index +
   the band name in condensed, with a thin rule. Sections the piece by set.
   ---------------------------------------------------------------------------- */
.run{max-width:var(--mx);margin:clamp(40px,6vh,72px) auto 0;padding-top:clamp(26px,4vh,40px);
  border-top:1px solid var(--rule)}
.run:first-of-type{margin-top:clamp(20px,3vh,30px)}
.run__head{display:grid;grid-template-columns:auto 1fr;gap:clamp(14px,2.4vw,30px);align-items:end;margin-bottom:clamp(22px,3vh,32px)}
.run__idx{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  line-height:1.5;padding-bottom:6px;white-space:nowrap}
.run__idx b{display:block;color:var(--red);font-weight:700;font-size:13px;margin-top:2px}
.run__name{font-family:var(--cond);font-size:clamp(34px,6.4vw,90px);line-height:.86;text-transform:uppercase;
  letter-spacing:-.02em;color:var(--ink);margin:0}
.run__name .red{color:var(--red)}
/* a slim tag for the set, sits under the name on its own mono line */
.run__set{grid-column:2;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-top:10px}

/* ----------------------------------------------------------------------------
   PULL-QUOTES — kinetic, HN Black Condensed, oversized, flush-left, with a red
   tick rule. The quote line(s) sit in a clip-mask and rise on reveal (.in).
   These are the 2–3 brief beats the brief asks for.
   ---------------------------------------------------------------------------- */
.pull{max-width:var(--mx);margin:clamp(48px,7vh,90px) auto;padding-left:clamp(16px,3vw,40px);
  border-left:3px solid var(--red);position:relative}
.pull__q{font-family:var(--cond);font-size:clamp(34px,6.6vw,92px);line-height:.9;text-transform:uppercase;
  letter-spacing:-.02em;color:var(--ink);max-width:18ch}
.pull__q .red{color:var(--red)}
.pull__cite{display:block;margin-top:18px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted)}
/* each masked line rises when the pull enters; JS adds .in */
.pull .mask>span{transform:translateY(108%)}
.pull.in .mask>span{transform:translateY(0);transition:transform .9s var(--ease);transition-delay:var(--d,0s)}

/* a full-bleed black pull, for the single hardest beat (the one-cable line) */
.pull--black{max-width:none;margin:clamp(54px,8vh,104px) 0;padding:clamp(56px,9vh,104px) var(--gut);
  background:var(--black);color:#fff;border-left:0;position:relative}
.pull--black .pull__in{max-width:var(--mx);margin:0 auto}
.pull--black .pull__q{color:#fff;max-width:20ch;font-size:clamp(38px,7.6vw,116px)}
.pull--black .pull__q .red{color:var(--red)}
.pull--black .pull__cite{color:var(--muted-d)}

/* ----------------------------------------------------------------------------
   UP NEXT — the drop tail: this feature is DROP 01, point at DROP 02.
   Black band, mirrors the home drop-row hover language in miniature.
   ---------------------------------------------------------------------------- */
.upnext{background:var(--black);color:#fff;padding:clamp(54px,9vh,104px) var(--gut) clamp(48px,8vh,88px);
  border-top:2px solid var(--red)}
.upnext__in{max-width:var(--mx);margin:0 auto}
.upnext__ey{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted-d);margin-bottom:26px}
.upnext__row{display:grid;grid-template-columns:88px 1fr auto;align-items:center;gap:clamp(16px,3vw,40px);
  padding:clamp(20px,3vw,32px) 0;border-top:1px solid var(--rule-d);border-bottom:1px solid var(--rule-d);
  transition:padding-left .3s var(--ease),background .3s}
a.upnext__row:hover,a.upnext__row:focus-visible{padding-left:18px;background:linear-gradient(90deg,rgba(206,22,30,.1),transparent 60%)}
.upnext__num{font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--muted-d);line-height:1.4}
.upnext__num b{display:block;color:#fff;font-weight:700;font-size:15px}
.upnext__main{min-width:0}
.upnext__phase{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.upnext__title{font-family:var(--cond);font-size:clamp(30px,5vw,72px);line-height:.88;text-transform:uppercase;
  letter-spacing:-.02em;color:#fff;transition:transform .3s var(--ease),color .3s}
a.upnext__row:hover .upnext__title,a.upnext__row:focus-visible .upnext__title{color:var(--red);transform:translateX(4px)}
.upnext__status{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-align:right;white-space:nowrap}
.upnext__status .open{color:#fff}
.upnext__arrow{font-family:var(--disp);font-size:26px;color:var(--red);transition:transform .3s var(--ease)}
a.upnext__row:hover .upnext__arrow,a.upnext__row:focus-visible .upnext__arrow{transform:translate(6px,-6px)}
.upnext__back{margin-top:30px;display:inline-block}

/* ----------------------------------------------------------------------------
   RESPONSIVE
   ---------------------------------------------------------------------------- */
@media (max-width:880px){
  .run__head{grid-template-columns:1fr;gap:6px;align-items:start}
  .run__idx{padding-bottom:0}
  .run__set{grid-column:1}
  .upnext__row{grid-template-columns:60px 1fr;gap:16px}
  .upnext__status{grid-column:1/-1;justify-self:start;text-align:left;margin-top:6px}
}
@media (max-width:680px){
  .feature__mark{width:50px}
}

/* ----------------------------------------------------------------------------
   REDUCED MOTION — the system file already neutralises .mask/.reveal/parallax;
   this just makes sure the feature masks + parallax bg are inert too.
   ---------------------------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  .feature__bg{inset:0!important;transform:none!important}
  .feature__title .mask>span,.pull .mask>span{transform:none!important}
  .pull.in .mask>span{transition:none!important}
}
