/*
Theme Name: London85 One Page
Theme URI: https://london85.local
Author: SteinsITConsultancy
Author URI: https://steinsitconsultancy.com
Description: One-page presentation theme for the London85 event band.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: london85
*/

:root {
  --bg: #080808;
  --bg-soft: #111111;
  --panel: #141414;
  --text: #f3f0e8;
  --text-soft: #d8d3c6;
  --gold: #d1ad66;
  --gold-soft: #b9924f;
  --border: rgba(209, 173, 102, 0.45);
  --overlay: rgba(0, 0, 0, 0.58);
  --radius: 18px;
  --shadow: 0 24px 50px rgba(0, 0, 0, 0.45);
  --container: min(80vw, calc(100% - 3rem));

  /* Stage spotlight tuning controls */
  --l85-stage-width: min(15vw, 170px);
  --l85-stage-left-offset: -10%;
  --l85-stage-right-offset: -10%;
  --l85-stage-angle: 20deg;
  --l85-stage-opacity: 0.58;
  --l85-stage-blur: 1.4px ;
  --l85-stage-right-blur: 1.6px;
  --l85-stage-beam-core: 0.52;
  --l85-stage-beam-tail: 0.16;
  --l85-stage-floor-glow-opacity: 0.12;
  --l85-stage-haze-opacity: 0.05;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Montserrat", "Segoe UI", sans-serif;
  background: #000;
  color: var(--text);
  line-height: 1.6;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  display: block;
}

.site-shell {
  overflow: hidden;
}

.l85-site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(0, 0, 0, 0.76);
  backdrop-filter: blur(7px);
  border-bottom: 1px solid rgba(209, 173, 102, 0.18);
}

.l85-nav-wrap {
  width: min(100%, var(--container));
  margin-inline: auto;
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.l85-nav-brand {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--gold);
  font-weight: 700;
  letter-spacing: 0.03em;
}

.l85-nav-brand .custom-logo-link,
.l85-nav-brand a {
  display: inline-flex;
  align-items: center;
}

.l85-nav-brand .custom-logo {
  width: auto;
  max-height: 42px;
}

.l85-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: clamp(0.7rem, 1.5vw, 1.4rem);
}

.l85-nav-list a {
  color: var(--text-soft);
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: color 0.2s ease;
}

.l85-nav-list a:hover,
.l85-nav-list a:focus-visible {
  color: var(--gold);
}

.l85-page [id] {
  scroll-margin-top: 88px;
}

.site-shell .wp-block-group,
.site-shell .wp-block-cover {
  margin-block-start: 0;
  margin-block-end: 0;
}

.site-shell .wp-block-columns {
  gap: clamp(1.2rem, 2.2vw, 2rem);
}

.l85-page {
  background: #000;
}

.entry-title,
.page-title,
.wp-block-post-title {
  display: none;
}

.l85-section {
  width: var(--container);
  margin-inline: auto;
  padding: 5.5rem 0;
}

.l85-section .wp-block-image img {
  border-radius: 0;
  border: 0;
  outline: 0;
  box-shadow: none;
  width: 100%;
  transform: translateZ(0) scale(1.002);
  transform-origin: center;
}

.l85-section .wp-block-image,
.l85-section .wp-block-image figure {
  overflow: hidden;
  line-height: 0;
  margin-bottom: 0;
  background: #000;
}

.l85-section .wp-block-image.is-style-rounded img,
.l85-section .wp-block-image .is-style-rounded img {
  border-radius: 0;
}

.l85-section ul {
  color: var(--text-soft);
  font-size: clamp(1rem, 1.3vw, 1.2rem);
}

.l85-hero .wp-block-cover__inner-container {
  width: min(100%, var(--container));
}

.l85-hero h1 {
  color: var(--text);
  text-transform: none;
  letter-spacing: 0.01em;
  font-weight: 700;
}

.l85-hero .hero-subtitle {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--gold);
  font-size: clamp(1.7rem, 2.8vw, 3rem);
}

.l85-values {
  text-align: center;
}

.l85-values h2 {
  font-size: clamp(2rem, 5vw, 5rem);
  line-height: 1.05;
}

.l85-kicker {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--gold);
  letter-spacing: 0.04em;
  font-size: clamp(1.3rem, 2vw, 2.3rem);
}

.l85-ready h2,
.l85-ready p {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

.l85-contact {
  text-align: center;
}

.l85-contact p {
  color: var(--text);
}

.l85-spotlights,
.l85-spotlights-soft,
.l85-spotlights-strong,
.l85-spotlights-tight,
.l85-spotlights-stage {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  --l85-spot-inset: -22% auto -10% auto;
  --l85-spot-width: min(36vw, 430px);
  --l85-spot-left-offset: -8%;
  --l85-spot-right-offset: -10%;
  --l85-spot-left-rotate: -11deg;
  --l85-spot-right-rotate: 11deg;
  --l85-spot-left-opacity: 1;
  --l85-spot-right-opacity: 1;
  --l85-spot-left-blur: 3px;
  --l85-spot-right-blur: 4px;
}

.l85-spotlights::before,
.l85-spotlights::after,
.l85-spotlights-soft::before,
.l85-spotlights-soft::after,
.l85-spotlights-strong::before,
.l85-spotlights-strong::after,
.l85-spotlights-tight::before,
.l85-spotlights-tight::after,
.l85-spotlights-stage::before,
.l85-spotlights-stage::after {
  content: "";
  position: absolute;
  inset: var(--l85-spot-inset);
  width: var(--l85-spot-width);
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: screen;
}

.l85-spotlights::before,
.l85-spotlights-soft::before,
.l85-spotlights-strong::before,
.l85-spotlights-tight::before,
.l85-spotlights-stage::before {
  left: var(--l85-spot-left-offset);
  transform-origin: 0% 0%;
  background:
    radial-gradient(ellipse at 52% 88%, rgba(230, 217, 182, 0.32), rgba(230, 217, 182, 0.05) 52%, transparent 74%),
    linear-gradient(126deg, rgba(215, 188, 132, 0.44) 0%, rgba(215, 188, 132, 0.12) 42%, rgba(0, 0, 0, 0) 74%);
  opacity: var(--l85-spot-left-opacity);
  filter: blur(var(--l85-spot-left-blur));
  transform: rotate(var(--l85-spot-left-rotate));
}

.l85-spotlights::after,
.l85-spotlights-soft::after,
.l85-spotlights-strong::after,
.l85-spotlights-tight::after,
.l85-spotlights-stage::after {
  right: var(--l85-spot-right-offset);
  transform-origin: 100% 0%;
  background:
    radial-gradient(ellipse at 48% 88%, rgba(230, 217, 182, 0.24), rgba(230, 217, 182, 0.03) 52%, transparent 72%),
    linear-gradient(232deg, rgba(205, 178, 118, 0.4) 0%, rgba(205, 178, 118, 0.08) 42%, rgba(0, 0, 0, 0) 74%);
  opacity: var(--l85-spot-right-opacity);
  filter: blur(var(--l85-spot-right-blur));
  transform: rotate(var(--l85-spot-right-rotate));
}

.l85-spotlights-soft {
  --l85-spot-width: min(31vw, 360px);
  --l85-spot-left-opacity: 0.6;
  --l85-spot-right-opacity: 0.52;
  --l85-spot-left-blur: 5px;
  --l85-spot-right-blur: 6px;
}

.l85-spotlights-strong {
  --l85-spot-width: min(44vw, 520px);
  --l85-spot-left-opacity: 1;
  --l85-spot-right-opacity: 0.94;
  --l85-spot-left-blur: 2px;
  --l85-spot-right-blur: 3px;
}

.l85-spotlights-tight {
  --l85-spot-inset: -8% auto -4% auto;
  --l85-spot-width: min(19vw, 220px);
  --l85-spot-left-offset: -2%;
  --l85-spot-right-offset: -3%;
  --l85-spot-left-rotate: -5deg;
  --l85-spot-right-rotate: 5deg;
  --l85-spot-left-opacity: 0.9;
  --l85-spot-right-opacity: 0.84;
  --l85-spot-left-blur: 1px;
  --l85-spot-right-blur: 2px;
}

.l85-spotlights-stage {
  --l85-spot-inset: -6% auto -3% auto;
  --l85-spot-width: var(--l85-stage-width);
  --l85-spot-left-offset: var(--l85-stage-left-offset);
  --l85-spot-right-offset: var(--l85-stage-right-offset);
  --l85-spot-left-rotate: calc(var(--l85-stage-angle) * -1);
  --l85-spot-right-rotate: var(--l85-stage-angle);
  --l85-spot-left-opacity: var(--l85-stage-opacity);
  --l85-spot-right-opacity: calc(var(--l85-stage-opacity) * 0.92);
  --l85-spot-left-blur: var(--l85-stage-blur);
  --l85-spot-right-blur: var(--l85-stage-right-blur);
  background-image:
    radial-gradient(ellipse at 50% 102%, rgba(214, 184, 124, var(--l85-stage-floor-glow-opacity)) 0%, rgba(214, 184, 124, 0.04) 24%, transparent 56%),
    radial-gradient(ellipse at 50% 86%, rgba(255, 255, 255, var(--l85-stage-haze-opacity)) 0%, transparent 36%);
}

.l85-spotlights-stage::before,
.l85-spotlights-stage::after {
  mix-blend-mode: normal;
}

.l85-spotlights-stage::before {
  background:
    linear-gradient(132deg, rgba(227, 196, 137, var(--l85-stage-beam-core)) 0%, rgba(227, 196, 137, var(--l85-stage-beam-tail)) 34%, rgba(227, 196, 137, 0) 66%),
    radial-gradient(ellipse at 30% 0%, rgba(255, 235, 190, 0.24), transparent 58%);
}

.l85-spotlights-stage::after {
  background:
    linear-gradient(228deg, rgba(227, 196, 137, var(--l85-stage-beam-core)) 0%, rgba(227, 196, 137, var(--l85-stage-beam-tail)) 34%, rgba(227, 196, 137, 0) 66%),
    radial-gradient(ellipse at 70% 0%, rgba(255, 235, 190, 0.22), transparent 58%);
}

.l85-spotlights > *,
.l85-spotlights-soft > *,
.l85-spotlights-strong > *,
.l85-spotlights-tight > *,
.l85-spotlights-stage > * {
  position: relative;
  z-index: 2;
}

.wp-block-cover.l85-spotlights .wp-block-cover__background,
.wp-block-cover.l85-spotlights .wp-block-cover__image-background,
.wp-block-cover.l85-spotlights-soft .wp-block-cover__background,
.wp-block-cover.l85-spotlights-soft .wp-block-cover__image-background,
.wp-block-cover.l85-spotlights-strong .wp-block-cover__background,
.wp-block-cover.l85-spotlights-strong .wp-block-cover__image-background,
.wp-block-cover.l85-spotlights-tight .wp-block-cover__background,
.wp-block-cover.l85-spotlights-tight .wp-block-cover__image-background,
.wp-block-cover.l85-spotlights-stage .wp-block-cover__background,
.wp-block-cover.l85-spotlights-stage .wp-block-cover__image-background {
  z-index: 0;
}

.wp-block-cover.l85-spotlights .wp-block-cover__inner-container,
.wp-block-cover.l85-spotlights-soft .wp-block-cover__inner-container,
.wp-block-cover.l85-spotlights-strong .wp-block-cover__inner-container,
.wp-block-cover.l85-spotlights-tight .wp-block-cover__inner-container,
.wp-block-cover.l85-spotlights-stage .wp-block-cover__inner-container {
  position: relative;
  z-index: 2;
}

.is-style-l85-panel {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.7rem;
}

.is-style-l85-panel li {
  padding: 0.8rem 1rem;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.03);
}

.section {
  padding: 5.5rem 0;
  position: relative;
}

.container {
  width: var(--container);
  margin: 0 auto;
}

.eyebrow {
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  font-size: 0.72rem;
  margin-bottom: 1rem;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: "Playfair Display", Georgia, serif;
  line-height: 1.12;
}

h1 {
  font-size: clamp(2rem, 4.5vw, 3.8rem);
  text-transform: none;
  letter-spacing: 0.01em;
  font-weight: 700;
}

h2 {
  font-size: clamp(2rem, 4vw, 3.4rem);
  color: var(--gold);
}

p {
  margin: 0;
  color: var(--text-soft);
  font-size: clamp(1rem, 1.4vw, 1.35rem);
}

.hero {
  min-height: 95vh;
  display: grid;
  align-items: center;
  background:
    linear-gradient(var(--overlay), rgba(0, 0, 0, 0.72)),
    radial-gradient(circle at 50% 0%, rgba(209, 173, 102, 0.28), transparent 35%),
    linear-gradient(125deg, #0d0d0d, #171717 40%, #050505 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.hero-grid {
  display: grid;
  gap: 2rem;
  text-align: center;
  justify-items: center;
}

.hero-badge {
  display: inline-flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  justify-content: center;
}

.hero-badge span {
  width: 2.1rem;
  height: 2.1rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  display: grid;
  place-items: center;
  font-size: 0.88rem;
  color: var(--gold);
}

.hero-subtitle {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--gold);
  font-size: clamp(1.7rem, 2.8vw, 3rem);
}

.tagline {
  font-size: 0.9rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #c0b9ab;
}

.two-col {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.5rem, 3vw, 3.5rem);
  align-items: center;
}

.card {
  background: linear-gradient(150deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01));
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius);
  padding: clamp(1.4rem, 3vw, 2.6rem);
  box-shadow: var(--shadow);
}

.solid-panel {
  background: linear-gradient(145deg, rgba(18, 18, 18, 0.95), rgba(9, 9, 9, 0.95));
  border: 1px solid var(--border);
}

.instrument-list {
  list-style: none;
  margin: 1.25rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.7rem;
}

.instrument-list li {
  padding: 0.7rem 0.9rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  color: #e8e3d6;
  background: rgba(255, 255, 255, 0.02);
}

.repertoire ul {
  margin: 1.2rem 0 0;
  padding-left: 1.2rem;
}

.repertoire li {
  color: var(--text);
  margin: 0.45rem 0;
  font-size: clamp(1rem, 1.25vw, 1.3rem);
}

.pillars {
  display: grid;
  gap: 1rem;
  margin-top: 1.2rem;
}

.pillars li {
  list-style: none;
  padding: 0.9rem 1rem;
  border-left: 3px solid var(--gold);
  background: rgba(255, 255, 255, 0.03);
  border-radius: 8px;
}

.members {
  background: linear-gradient(180deg, rgba(18, 18, 18, 0.5), rgba(8, 8, 8, 0.9));
}

.member-grid {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.member-card {
  background: linear-gradient(160deg, rgba(28, 28, 28, 0.9), rgba(10, 10, 10, 0.95));
  border: 1px solid rgba(209, 173, 102, 0.28);
  border-radius: 14px;
  padding: 1.15rem;
  min-height: 130px;
}

.member-card h3 {
  font-size: 1.1rem;
  color: var(--text);
}

.member-card h4 {
  margin: 0;
  font-size: 1.1rem;
  color: var(--text);
}

.member-card p {
  font-size: 0.95rem;
  margin-top: 0.25rem;
  color: var(--gold);
}

.member-card span {
  display: block;
  margin-top: 0.45rem;
  font-size: 0.88rem;
  color: #b8b2a5;
}

.cta {
  text-align: center;
  padding-top: 2rem;
}

.cta a {
  display: inline-block;
  margin-top: 1.2rem;
  background: linear-gradient(135deg, var(--gold), var(--gold-soft));
  color: #121212;
  font-weight: 700;
  padding: 0.9rem 1.5rem;
  border-radius: 999px;
}

.site-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.09);
  text-align: center;
  padding: 2rem 1rem;
  color: #a59f91;
  font-size: 0.9rem;
}

@media (max-width: 1024px) {
  .member-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .l85-nav-wrap {
    min-height: 56px;
    width: min(100%, calc(100% - 1.8rem));
  }

  .l85-nav-brand {
    font-size: 1rem;
  }

  .l85-nav-list {
    gap: 0.65rem;
  }

  .l85-nav-list a {
    font-size: 0.78rem;
  }

  .two-col {
    grid-template-columns: 1fr;
  }

  .l85-section {
    padding: 4.2rem 0;
  }

  .member-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .section {
    padding: 4.2rem 0;
  }
}

@media (max-width: 540px) {
  .l85-nav-wrap {
    flex-wrap: wrap;
    justify-content: center;
    padding: 0.45rem 0;
  }

  .hero {
    min-height: 78vh;
  }

  .member-grid {
    grid-template-columns: 1fr;
  }

  .container {
    width: min(1140px, calc(100% - 1.6rem));
  }

  .l85-section {
    width: min(1140px, calc(100% - 1.6rem));
  }
}
