/* main.css — Jan Holler Website */


/* ─── Page transition curtain ───────────────────────────────── */

.page-transition {
  position: fixed;
  inset: 0;
  background: var(--color-bg-primary);
  z-index: 9999;
  pointer-events: none;
  will-change: transform;
}


/* ─── Utilities ─────────────────────────────────────────────── */

.img-placeholder {
  display: block;
  width: 100%;
  background: linear-gradient(145deg, var(--color-bg-tertiary) 0%, var(--color-bg-secondary) 100%);
}


/* ─── Navigation ─────────────────────────────────────────────── */

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--nav-height);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: var(--space-4);
  padding: 0 var(--nav-padding-x);
  background-color: var(--color-bg-primary);
  border-bottom: 1.5px solid var(--color-border-primary);
}

.nav-logo {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(26px, 2.4vw, 38px);
  line-height: 1;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--color-text-primary);
  text-align: center;
  white-space: nowrap;
  position: relative;
  top: -2px;
}

.nav-logo-bold,
.nav-logo-italic {
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
}

.nav-logo--alt {
  font-family: var(--font-display-bold);
  font-weight: var(--font-weight-extrabold);
  font-style: normal;
  letter-spacing: var(--letter-spacing-tight);
}

.nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-6);
}

.nav-right {
  /* spacer for symmetry */
}

.nav-links a {
  font-family: var(--font-mono);
  font-size: 16px;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-text-primary);
}

@media (max-width: 600px) {
  .nav {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-3) var(--space-5);
    height: auto;
    gap: var(--space-3);
  }

  .nav-right {
    display: none;
  }

  .nav-links {
    order: 2;
    justify-content: center;
    gap: var(--space-2);
    flex-wrap: wrap;
  }

  .nav-links a {
    font-size: 11px;
  }

  .nav-logo {
    order: 1;
    font-size: clamp(22px, 6vw, 30px);
  }
}


/* ─── Section base ───────────────────────────────────────────── */

.section {
  padding: clamp(var(--space-9), 12vw, var(--space-11)) clamp(var(--space-5), 5vw, var(--space-10));
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.section-head {
  margin-bottom: var(--space-8);
  text-align: center;
}

.section-eyebrow {
  display: block;
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(20px, 3vw, 36px);
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}

.section-title {
  font-family: var(--font-display-bold);
  font-weight: var(--font-weight-extrabold);
  font-size: clamp(40px, 8vw, 96px);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  text-transform: uppercase;
  color: var(--color-text-primary);
}


/* ─── Hero / About ───────────────────────────────────────────── */

.section-hero {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: calc(60vh - var(--nav-height));
  padding-top: clamp(var(--space-4), 3vw, var(--space-6));
  padding-bottom: clamp(var(--space-4), 3vw, var(--space-6));
  text-align: center;
}

.hero-top {
  margin-bottom: 0;
}

.hero-eyebrow {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(var(--font-size-lg), 2.5vw, var(--font-size-2xl));
  color: var(--color-text-secondary);
  margin-bottom: var(--space-5);
  letter-spacing: 0;
}

.hero-name {
  display: grid;
  justify-items: center;
  line-height: var(--line-height-tight);
  margin-bottom: var(--space-5);
}

.hero-name-bold {
  position: relative;
  display: block;
  width: fit-content;
  font-family: var(--font-display-bold);
  font-weight: var(--font-weight-extrabold);
  font-size: var(--font-size-4xl);
  letter-spacing: var(--letter-spacing-tight);
  text-transform: uppercase;
  color: var(--color-text-primary);
}

.hero-name-link {
  display: block;
  width: fit-content;
  margin: 0 auto;
  text-decoration: none;
  clip-path: polygon(
    var(--name-clip-l, 0%) 0%,
    var(--name-clip-r, 100%) 0%,
    var(--name-clip-r, 100%) var(--name-clip-split, 100%),
    100% var(--name-clip-split, 100%),
    100% 100%,
    0% 100%,
    0% var(--name-clip-split, 100%),
    var(--name-clip-l, 0%) var(--name-clip-split, 100%)
  );
}

.hero-name-bold,
.hero-name-italic {
  transition: color var(--duration-fast) var(--easing-default);
}

.hero-name-link .hero-name-bold {
  -webkit-text-stroke: 1.5px var(--color-text-primary);
}

.hero-name-link .hero-name-italic {
  -webkit-text-stroke: 1.5px var(--color-text-accent);
}

.hero-name-link:hover .hero-name-bold,
.hero-name-link:hover .hero-name-italic {
  color: transparent;
}

.hero-name-italic {
  display: block;
  width: fit-content;
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: var(--font-size-5xl);
  color: var(--color-text-accent);
  text-transform: uppercase;
  letter-spacing: -0.01em;
}

.hero-sub {
  font-family: var(--font-mono);
  font-size: clamp(13px, calc(5vw - 2.5px), 20px);
  letter-spacing: var(--letter-spacing-wide);
  color: var(--color-text-secondary);
  text-wrap: balance;
}

/* About area (below name) */

.section-about {
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
  padding-left: clamp(var(--space-9), 10vw, var(--space-11));
}

.hero-about {
  /* Sequential: text top-left, photo bottom-right */
}

.hero-about-text {
  max-width: 75%;
  font-family: var(--font-display-italic);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(24px, 2.6vw, 38px);
  line-height: 1.5;
  color: var(--color-text-primary);
  margin-bottom: clamp(var(--space-8), 8vw, var(--space-10));
}

.hero-about-link {
  color: var(--color-text-primary);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1.5px;
  text-decoration-color: var(--color-text-secondary);
  transition: text-decoration-color var(--duration-fast) var(--easing-default);
}

.hero-about-link:hover {
  text-decoration-color: var(--color-text-primary);
}

.hero-photo-wrap {
  margin-left: 50%;
  margin-top: clamp(var(--space-9), 12vw, var(--space-11));
  width: 28%;
}

.hero-photo {
  aspect-ratio: 3 / 4;
  width: 100%;
  display: block;
  object-fit: cover;
  object-position: center top;
}

@media (max-width: 768px) {
  .section-about {
    padding-left: clamp(var(--space-5), 5vw, var(--space-10));
  }

  .hero-about-text {
    max-width: 100%;
    text-align: center;
  }

  .hero-about-cta {
    display: block;
  }

  .hero-photo-wrap {
    width: 65%;
    margin-left: auto;
    margin-right: auto;
  }
}


/* ─── Portfolio / Arbeit ─────────────────────────────────────── */

.section--portfolio {
  max-width: var(--max-width-page);
}

.portfolio-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

.portfolio-item {
  display: flex;
  flex-direction: column;
  gap: 0;
  cursor: pointer;
}


.portfolio-item--disabled {
  cursor: default;
}

.portfolio-item--disabled .portfolio-thumb-wrap {
  opacity: 0.6;
}

.portfolio-thumb-wrap {
  width: 100%;
  overflow: hidden;
  margin-bottom: var(--space-4);
}

.portfolio-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.portfolio-body {
  flex: none;
}

.portfolio-title {
  font-family: var(--font-display-bold);
  font-weight: var(--font-weight-extrabold);
  font-size: clamp(24px, 2.8vw, 40px);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  text-transform: uppercase;
  color: var(--color-text-primary);
}

.portfolio-meta {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--color-text-accent);
  margin-top: var(--space-1);
}

@media (max-width: 768px) {
  .portfolio-list {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
  }
}

@media (max-width: 480px) {
  .portfolio-list {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}


/* ─── Section bands (alternating backgrounds) ───────────────── */

.section-band {
  width: 100%;
}

.section-band--light {
  background-color: #ffffff;
  --color-bg-primary:     #ffffff;
  --color-bg-secondary:   #ffffff;
  --color-bg-tertiary:    #ffffff;
  --color-text-primary:   #000000;
  --color-text-secondary: #000000;
  --color-text-tertiary:  #000000;
  --color-text-accent:    #000000;
  --color-border-primary: #000000;
}


/* ─── Video Overlay ──────────────────────────────────────────── */

.overlay {
  position: fixed;
  inset: 0;
  z-index: var(--overlay-z);
  background: var(--color-bg-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-normal) var(--easing-default);
}

.overlay.is-open {
  opacity: 1;
  pointer-events: all;
}

.overlay-close {
  position: absolute;
  top: var(--space-6);
  right: var(--space-6);
  font-family: var(--font-mono);
  font-size: var(--font-size-md);
  color: var(--color-text-secondary);
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--duration-fast) var(--easing-default);
}

.overlay-close:hover {
  color: var(--color-text-primary);
}

.overlay-close:focus-visible {
  outline: 2px solid var(--color-border-focus);
  border-radius: var(--border-radius-sm);
}

.overlay-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  width: min(90vw, 1200px);
  max-height: 90vh;
  overflow-y: auto;
}

.overlay-content {
  width: 100%;
  aspect-ratio: 16 / 9;
  position: relative;
  flex-shrink: 0;
}

.overlay-media {
  width: 100%;
  height: 100%;
}

.overlay-media iframe {
  width: 100%;
  height: 100%;
}

.overlay-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-secondary);
}

.overlay-placeholder p {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  color: var(--color-text-tertiary);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
}

.overlay-credits {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  text-align: center;
  flex-shrink: 0;
}

.overlay-credits:empty {
  display: none;
}

.overlay-credits p {
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}

.overlay-credits p strong {
  font-weight: var(--font-weight-medium, 500);
  color: var(--color-text-secondary);
}


/* ─── Playlist / Ticker ──────────────────────────────────────── */

.section-playlist {
  max-width: none;
  padding-left: 0;
  padding-right: 0;
  overflow: hidden;
}

.playlist-header {
  padding: 0 clamp(var(--space-5), 5vw, var(--space-10));
  margin-bottom: var(--space-7);
  text-align: center;
}

@media (max-width: 600px) {
  .playlist-header {
    margin-bottom: var(--space-4);
  }
}

.playlist-eyebrow {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(20px, 3vw, 36px);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}

.playlist-title {
  font-family: var(--font-display-bold);
  font-weight: var(--font-weight-extrabold);
  font-size: clamp(40px, 8vw, 96px);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  text-transform: uppercase;
  color: var(--color-text-primary);
}

/* Ticker */

.ticker-wrap {
  overflow: hidden;
  position: relative;
  padding: var(--space-3) 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ticker-track {
  display: flex;
  align-items: center;
  gap: 0;
  width: max-content;
  will-change: transform;
}

.ticker-item {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: var(--ticker-font-size);
  color: var(--color-text-primary);
  white-space: nowrap;
  padding: 0 var(--space-7);
  line-height: 1.1;
  text-decoration: none;
  letter-spacing: 0;
  opacity: 1;
  transition: opacity var(--duration-fast) var(--easing-default);
}

.ticker-sep {
  font-family: var(--font-display-italic);
  font-size: var(--ticker-font-size);
  color: var(--color-text-primary);
  flex-shrink: 0;
  line-height: 1;
  opacity: 1;
  transition: opacity var(--duration-fast) var(--easing-default);
}

/* While hovering one item, fade everything else across all rows.
   Restricted to real pointer/hover devices — on touch, ticker links open
   in a new tab and the faded state would otherwise stay "stuck" on return. */
@media (hover: hover) and (pointer: fine) {
  .ticker-wrap:has(.ticker-item:hover) .ticker-item:not(:hover),
  .ticker-wrap:has(.ticker-item:hover) .ticker-sep {
    opacity: 0.35;
  }
}



/* ─── Statement ──────────────────────────────────────────────── */

.section-statement {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 40vh;
}

.statement-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}

.statement-link {
  text-decoration: none;
  cursor: pointer;
}

.statement-italic {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(20px, 3vw, 36px);
  color: var(--color-text-accent);
  letter-spacing: 0;
}

.statement-bold {
  font-family: var(--font-display-bold);
  font-weight: var(--font-weight-extrabold);
  font-size: clamp(40px, 8vw, 96px);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  text-transform: uppercase;
  color: var(--color-text-primary);
}

/* Hover-reveal effect: lines part to reveal CTA */
.statement-line {
  transition: transform 0.45s cubic-bezier(0.65, 0, 0.35, 1);
}

.statement-link:hover .statement-line--up {
  transform: translateY(clamp(-32px, -3vw, -16px));
}

.statement-link:hover .statement-line--down {
  transform: translateY(clamp(16px, 3vw, 32px));
}

.statement-cta {
  height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  white-space: nowrap;
  font-family: var(--font-mono);
  font-size: clamp(14px, 1.4vw, 18px);
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-text-secondary);
  opacity: 0;
  transition: opacity 0.3s ease 0.1s;
  pointer-events: none;
}

.statement-link:hover .statement-cta {
  opacity: 1;
}


/* ─── Journal ────────────────────────────────────────────────── */

.section-title--script {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(88px, 20vw, 240px);
  line-height: 0.88;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  text-transform: none;
}

.section-subtext {
  max-width: 640px;
  margin: var(--space-6) auto 0;
  font-family: var(--font-mono);
  font-size: clamp(11px, calc(4.3vw - 2.2px), 22px);
  line-height: var(--line-height-relaxed);
  letter-spacing: var(--letter-spacing-wide);
  color: var(--color-text-secondary);
}

.section-subtext-line {
  display: block;
  text-wrap: balance;
}

.journal-grid {
  columns: 3;
  column-gap: var(--space-3);
}

.journal-item {
  break-inside: avoid;
  margin-bottom: var(--space-3);
  overflow: hidden;
}

.journal-item .img-placeholder {
  display: block;
  width: 100%;
}

.journal-photo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.journal-quote {
  background-color: var(--color-bg-secondary);
  padding: var(--space-7) var(--space-6);
  min-height: 200px;
  display: flex;
  align-items: center;
}

.journal-quote p {
  font-family: var(--font-display-italic);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(var(--font-size-lg), 2.5vw, var(--font-size-2xl));
  line-height: var(--line-height-snug);
  color: var(--color-text-accent);
}

@media (max-width: 768px) {
  .journal-grid {
    columns: 2;
  }
}

@media (max-width: 480px) {
  .journal-grid {
    columns: 1;
  }
}


/* ─── Footer / Kontakt ───────────────────────────────────────── */

.footer {
  border-top: 1.5px solid var(--color-border-primary);
  padding: var(--space-8) clamp(var(--space-5), 5vw, var(--space-10));
}

.footer-inner {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.footer-links {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}

@media (max-width: 600px) {
  .footer-links {
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
  }
}

.footer-links a {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-text-primary);
}

.footer-links .footer-email {
  font-family: var(--font-display-bold);
  font-style: normal;
  font-weight: var(--font-weight-extrabold);
  font-size: clamp(var(--font-size-lg), 1.8vw, 26px);
  letter-spacing: -0.01em;
  text-transform: uppercase;
}

/* ─── Kontakt page ───────────────────────────────────────────── */

.kontakt-body {
  margin-top: var(--space-8);
  text-align: center;
}

.kontakt-email {
  display: block;
  font-family: var(--font-mono);
  font-weight: var(--font-weight-normal);
  font-style: normal;
  font-size: clamp(16px, 2vw, 22px);
  letter-spacing: 0;
  text-transform: none;
  color: var(--color-text-primary);
  text-decoration: none;
  margin-bottom: var(--space-2);
}

.kontakt-phone {
  font-family: var(--font-mono);
  font-weight: var(--font-weight-normal);
  font-size: clamp(16px, 2vw, 22px);
  letter-spacing: 0;
  color: var(--color-text-secondary);
}



/* ─── Legal pages (Impressum / Datenschutz) ─────────────────── */

.section-legal {
  max-width: var(--max-width-text);
}

.legal-content h2 {
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin: var(--space-7) 0 var(--space-2);
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content p {
  font-family: var(--font-mono);
  font-weight: var(--font-weight-normal);
  font-style: normal;
  font-size: var(--font-size-md);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}

.legal-content a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.legal-divider {
  width: 40px;
  height: 1px;
  background: var(--color-border-primary);
  margin: var(--space-7) 0;
  opacity: 0.3;
}


/* ─── Reduced motion ─────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .overlay {
    transition: none;
  }

  * {
    transition-duration: 0ms !important;
  }
}
