/*
Theme Name: Peder Tee Music
Theme URI: https://pederteemusic.de
Author: Peder Tee Music
Description: Custom WordPress theme for Peder Tee Music.
Version: 1.3.0
Text Domain: peder-tee-music
*/

:root {
  --cream: #f0efe7;
  --cream-dark: #e4e0d3;
  --ink: #1a1a1a;
  --ink-soft: #292824;
  --gold: #c8a165;
  --gold-light: #ead4a9;
  --white: #fffdf7;
  --line: rgba(200, 161, 101, .35);
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, Helvetica, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream); color: var(--ink); font-family: var(--sans); line-height: 1.65; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.wrap { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.eyebrow { margin: 0 0 12px; color: var(--gold); font-size: .76rem; font-weight: 800; letter-spacing: .19em; text-transform: uppercase; }
h1, h2, h3 { font-family: var(--sans); font-weight: 750; line-height: 1.03; }
h1 { margin: 0; font-size: clamp(4rem, 10vw, 8.5rem); letter-spacing: -.07em; }
h2 { margin: 0; font-size: clamp(2.7rem, 5vw, 5rem); letter-spacing: -.055em; }
h3 { margin: 0; font-size: 1.75rem; }
p { margin: 0; }

.site-header { position: absolute; z-index: 5; top: 0; width: 100%; color: var(--white); }
.header-row { display: flex; align-items: center; justify-content: space-between; min-height: 92px; border-bottom: 1px solid rgba(255,255,255,.16); }
.brand { display: flex; align-items: center; gap: 12px; font-size: .82rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.brand img { width: 54px; height: 54px; filter: invert(1); }
.nav { display: flex; align-items: center; gap: 28px; font-size: .78rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.nav a:hover { color: var(--gold-light); }
.nav .nav-cta { padding: 11px 16px; border: 1px solid var(--gold); color: var(--gold-light); }

.hero { position: relative; min-height: 820px; overflow: hidden; background: #141414; color: var(--white); }
.hero::before, .hero::after { position: absolute; content: ""; border-radius: 50%; }
.hero::before { right: -140px; top: 125px; width: 650px; height: 650px; border: 1px solid rgba(200,161,101,.44); }
.hero::after { right: 0; top: 265px; width: 360px; height: 360px; border: 1px solid rgba(200,161,101,.2); }
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; align-items: center; min-height: 820px; padding-top: 110px; }
.hero-copy { position: relative; z-index: 2; padding: 70px 0 80px; }
.hero h1 span { display: block; color: var(--gold); font-style: italic; }
.hero-text { max-width: 640px; margin: 28px 0 36px; color: rgba(255,255,255,.78); font-size: 1.12rem; }
.button-row { display: flex; flex-wrap: wrap; gap: 13px; }
.button { display: inline-flex; align-items: center; min-height: 51px; padding: 0 21px; border: 1px solid var(--gold); background: var(--gold); color: #151515; font-size: .76rem; font-weight: 900; letter-spacing: .13em; text-transform: uppercase; transition: .2s ease; }
.button:hover { transform: translateY(-2px); background: var(--gold-light); }
.button.ghost { background: transparent; color: var(--gold-light); }
.hero-art { position: relative; z-index: 1; display: grid; place-items: center; }
.hero-art img { width: min(520px, 72vw); filter: invert(1); opacity: .93; }
.hero-note { position: absolute; right: 0; bottom: 45px; color: rgba(255,255,255,.48); font-size: .69rem; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; writing-mode: vertical-rl; }

.intro { padding: 118px 0 95px; background: var(--cream); }
.intro-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 70px; align-items: start; }
.intro-copy { max-width: 690px; padding-top: 8px; font-size: 1.16rem; }
.intro-copy p + p { margin-top: 16px; }
.signature { margin-top: 28px; color: #86704e; font-family: var(--sans); font-size: 1.32rem; font-style: italic; }

.music { padding: 105px 0 115px; background: var(--ink); color: var(--white); }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 40px; margin-bottom: 42px; }
.section-head p { max-width: 480px; color: rgba(255,255,255,.62); }
.cover-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.cover { position: relative; overflow: hidden; aspect-ratio: 1; background: #242321; }
.cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.cover:hover img { transform: scale(1.045); }
.cover-info { position: absolute; inset: auto 0 0; padding: 28px 20px 18px; background: linear-gradient(transparent, rgba(0,0,0,.88)); }
.cover-info span { display: block; color: var(--gold-light); font-size: .66rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.cover-info strong { display: block; margin-top: 4px; font-family: var(--sans); font-size: 1.22rem; font-weight: 750; }
.listen-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }

.worlds { padding: 112px 0; background: var(--cream-dark); }
.world-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; margin-top: 40px; background: rgba(26,26,26,.16); }
.world { min-height: 270px; padding: 31px; background: var(--cream); }
.number { color: var(--gold); font-family: var(--sans); font-size: 1.9rem; font-style: italic; font-weight: 750; }
.world h3 { margin: 38px 0 12px; }
.world p { color: #615c52; }

.merch { padding: 112px 0; background: #181818; color: var(--white); }
.merch-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: 64px; align-items: center; }
.merch p:not(.eyebrow) { max-width: 680px; margin-top: 20px; color: rgba(255,255,255,.7); font-size: 1.06rem; }
.merch-card { display: grid; place-items: center; min-height: 390px; border: 1px solid rgba(200,161,101,.48); background: radial-gradient(circle, rgba(200,161,101,.2), transparent 64%); }
.merch-card img { width: min(300px, 70%); filter: invert(1); opacity: .94; }
.custom-song { padding: 120px 0; background: #23221f; color: var(--white); }
.custom-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 70px; align-items: center; }
.custom-song p { max-width: 690px; margin-top: 22px; color: rgba(255,255,255,.68); font-size: 1.08rem; }
.steps { border-top: 1px solid var(--line); }
.step { display: grid; grid-template-columns: 52px 1fr; gap: 12px; padding: 17px 0; border-bottom: 1px solid var(--line); }
.step b { color: var(--gold); font-family: var(--sans); font-size: 1.5rem; font-style: italic; font-weight: 750; }
.step span { align-self: center; color: rgba(255,255,255,.75); }

.contact { padding: 112px 0; background: var(--cream); }
.contact-grid { display: grid; grid-template-columns: .82fr 1.18fr; gap: 65px; }
.contact-copy p:not(.eyebrow) { max-width: 390px; margin-top: 22px; color: #625d53; }
.form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form label { display: grid; gap: 6px; color: #706857; font-size: .7rem; font-weight: 900; letter-spacing: .13em; text-transform: uppercase; }
.form label.full, .form .full { grid-column: 1 / -1; }
.form input, .form textarea { width: 100%; border: 1px solid rgba(26,26,26,.22); background: rgba(255,255,255,.46); padding: 14px; color: var(--ink); font: inherit; }
.form textarea { min-height: 135px; resize: vertical; }
.form .check { display: flex; grid-column: 1 / -1; gap: 9px; align-items: start; color: #625d53; font-size: .82rem; font-weight: 400; letter-spacing: 0; text-transform: none; }
.form .check input { width: auto; margin-top: 5px; }
.form .hp { position: absolute; left: -9999px; }
.notice { margin-bottom: 25px; padding: 15px 17px; border-left: 3px solid var(--gold); background: #e5dece; }

.site-footer { padding: 38px 0; background: #161616; color: rgba(255,255,255,.65); }
.footer-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 18px; font-size: .75rem; letter-spacing: .08em; text-transform: uppercase; }
.footer-links { display: flex; flex-wrap: wrap; gap: 20px; }
.footer-links a:hover { color: var(--gold-light); }

.page-main { min-height: 75vh; padding: 145px 0 95px; background: var(--cream); }
.page-main .content { max-width: 820px; }
.page-main h1 { font-size: clamp(3rem, 8vw, 6.5rem); }
.page-main .entry-content { margin-top: 30px; }
.page-main .entry-content h2 { margin-top: 32px; font-size: 2rem; }
.page-main .entry-content p { margin-top: 14px; }
.page-header { position: static; background: #161616; }

.project-hero { padding: 150px 0 88px; background: #181818; color: var(--white); }
.project-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 58px; align-items: center; }
.project-hero h1 { font-size: clamp(3.7rem, 8vw, 7rem); }
.project-hero-copy > p:not(.eyebrow) { max-width: 650px; margin-top: 23px; color: rgba(255,255,255,.72); font-size: 1.08rem; }
.project-cover { overflow: hidden; border: 1px solid rgba(200,161,101,.45); }
.project-cover img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.project-body { padding: 95px 0; background: var(--cream); }
.project-body-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 70px; align-items: start; }
.project-body p + p { margin-top: 14px; }
.project-facts { padding: 25px; border: 1px solid rgba(26,26,26,.17); background: rgba(255,255,255,.34); }
.project-facts h3 { margin-bottom: 14px; }
.audio-box { margin-top: 24px; padding: 22px; background: #252421; color: var(--white); }
.audio-box p { margin-bottom: 14px; color: rgba(255,255,255,.68); font-size: .92rem; }
.audio-box audio { width: 100%; }
.projects-list { padding: 100px 0; background: var(--cream); }
.project-card { display: grid; grid-template-columns: minmax(230px, .75fr) 1.25fr; gap: 36px; align-items: center; margin-top: 35px; padding: 24px; border: 1px solid rgba(26,26,26,.15); background: rgba(255,255,255,.35); }
.project-card img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.project-card p { margin: 13px 0 20px; color: #625d53; }
.about-hero { padding: 150px 0 95px; background: #181818; color: var(--white); }
.about-hero-grid, .about-story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 58px; align-items: center; }
.about-hero h1 { font-size: clamp(4rem, 9vw, 7.5rem); }
.about-hero p:not(.eyebrow) { max-width: 610px; margin-top: 22px; color: rgba(255,255,255,.72); font-size: 1.1rem; }
.about-photo { overflow: hidden; border: 1px solid rgba(200,161,101,.45); }
.about-photo img { width: 100%; height: 100%; object-fit: cover; }
.about-photo.hero-photo { aspect-ratio: 1.38; }
.about-story { padding: 100px 0; background: var(--cream); }
.about-story p + p { margin-top: 14px; }
.about-story .portrait { aspect-ratio: .78; }
.about-quote { margin-top: 30px; padding: 20px 0; border-top: 1px solid rgba(200,161,101,.7); border-bottom: 1px solid rgba(200,161,101,.7); color: #80663f; font-family: var(--sans); font-size: 1.38rem; font-style: italic; }
.about-path { padding: 95px 0; background: #23221f; color: var(--white); }
.about-path-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; margin-top: 34px; background: rgba(200,161,101,.38); }
.about-path article { padding: 28px; background: #23221f; }
.about-path h3 { margin: 18px 0 10px; }
.about-path p { color: rgba(255,255,255,.64); }

@media (max-width: 1050px) {
  .nav a:not(.nav-cta) { display: none; }
  .hero, .hero-grid { min-height: 730px; }
  .hero-grid { display: block; padding-top: 145px; }
  .hero-copy { padding-bottom: 0; }
  .hero-art { opacity: .2; position: absolute; right: -90px; bottom: 20px; }
  .hero-note { display: none; }
  .intro-grid, .merch-grid, .custom-grid, .contact-grid, .project-hero-grid, .project-body-grid, .about-hero-grid, .about-story-grid { grid-template-columns: 1fr; gap: 28px; }
  .cover-grid, .world-grid { grid-template-columns: 1fr 1fr; }
  .section-head { display: block; }
  .section-head p { margin-top: 14px; }
}

@media (max-width: 520px) {
  .wrap { width: min(100% - 26px, 1180px); }
  .brand { font-size: .7rem; }
  .brand img { width: 47px; height: 47px; }
  h1 { font-size: 4rem; }
  .cover-grid, .world-grid, .form { grid-template-columns: 1fr; }
  .project-card { grid-template-columns: 1fr; padding: 14px; }
  .about-path-grid { grid-template-columns: 1fr; }
}
