/* =====================
   CSS VARIABLES
   ===================== */
:root {
  /* Colors */
  --color-cream:          #F7F4EE;
  --color-warm-gray:      #F2EFE8;
  --color-dark:           #1A1A18;
  --color-separator:      #D8D3C8;
  --color-text-secondary: #6B6560;
  --color-text-muted:     #9A9488;
  --color-text-faint:     #C0BAB0;
  --color-input-bg:       #242420;
  --color-input-border:   #5A5550;
  --color-card-border:    #E0DBD2;
  --color-card-divider:   #E8E3DA;
  --color-tag-text:       #7A7268;

  /* Buttons */
  --btn-primary-bg:   var(--color-dark);
  --btn-primary-text: var(--color-cream);
  --btn-submit-bg:    var(--color-cream);
  --btn-submit-text:  var(--color-dark);

  /* Fonts */
  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'DM Sans', sans-serif;
  --font-mono:    'DM Mono', monospace;

  /* Section spacing */
  --padding-section-x: 64px;
  --padding-section-y: 72px;
  --padding-nav-x:     64px;

  /* Content centering — keeps content ≤ 1440px wide on any viewport
     while backgrounds always stretch full width.
     half-offset = (1440px / 2) - padding-section-x = 656px
     Usage: padding-left/right: max(var(--padding-section-x), calc(50% - var(--half-offset))) */
  --content-max:  1440px;
  --half-offset:  calc(var(--content-max) / 2 - var(--padding-section-x));

  /* Gaps */
  --gap-hero-content:  20px;
  --gap-hero-cta:      24px;
  --gap-nav-links:     32px;
  --gap-pillars-grid:  1px; /* hairline border effect between pillar cards */
  --gap-cards-grid:    16px;
  --gap-contact:       80px;
  --gap-contact-info:  24px;
  --gap-form-fields:   20px;
  --gap-form-name-row: 16px;
  --gap-social-links:  24px;
  --gap-ticker:        28px;

  /* Component padding */
  --padding-pillar-card: 32px;
  --padding-card-body:   20px;
  --padding-btn-primary: 13px 28px;
  --padding-btn-submit:  14px 28px;
  --padding-input:       10px 12px;
  --padding-chip:        3px 8px;
}

/* =====================
   BASE RESET
   ===================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  background-color: var(--color-cream);
  color: var(--color-dark);
  line-height: 1.5;
}

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

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

button {
  cursor: pointer;
  border: none;
  font-family: var(--font-body);
}

/* =====================
   NAV
   ===================== */
.nav {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--padding-nav-x);
  background-color: var(--color-cream);
  z-index: 10;
}

.nav__logo {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 6px;
  color: var(--color-dark);
}

.nav__links {
  display: flex;
  gap: var(--gap-nav-links);
}

.nav__links a {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 300;
  letter-spacing: 1px;
  color: var(--color-text-muted);
}

/* =====================
   HERO
   ===================== */
#hero {
  position: relative;
  display: flex;
  height: 720px;
  overflow: hidden;
  background-color: var(--color-cream);
  max-width: 1440px;
  margin: 0 auto;
}

/* Left column — text content */
.hero__left {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 var(--padding-section-x);
  gap: var(--gap-hero-content);
  background-color: var(--color-cream); /* solid background so portrait gradient doesn't bleed through */
  position: relative;
  z-index: 1;
}

/* Right column — portrait photo with gradient vignettes
   flex: 1 gives it exactly half the hero width.
   background-size: cover fills that fixed area — Adam always stays in frame. */
.hero__right {
  flex: 1;
  overflow: hidden;
  background-color: var(--color-cream);
  background-image:
    /* left vignette — fades portrait into the content column (dominant, 91%) */
    linear-gradient(to right,  #F7F4EE 0%, #F7F4EECC 8%,  #F7F4EE80 15%, #F7F4EE00 91%),
    /* top vignette */
    linear-gradient(to bottom, #F7F4EE 0%, #F7F4EEB3 8%,  #F7F4EE80 15%, #F7F4EE00 30%),
    /* bottom vignette */
    linear-gradient(to top,    #F7F4EE 0%, #F7F4EEB3 10%, #F7F4EE80 20%, #F7F4EE00 35%),
    /* right vignette */
    linear-gradient(to left,   #F7F4EE 0%, #F7F4EECC 8%,  #F7F4EE88 15%, #F7F4EE44 25%, #F7F4EE11 35%, #F7F4EE00 50%),
    /* portrait photo */
    url('images/portrait.png');
  background-size: 100% 100%, 100% 100%, 100% 100%, 100% 100%, cover;
  background-position: center top;
  background-repeat: no-repeat;
}

.hero__eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 3px;
  color: var(--color-text-muted);
}

.hero__heading {
  font-family: var(--font-display);
  font-size: 96px;
  font-weight: 300;
  line-height: 0.93;
  max-width: 443px;
  color: var(--color-dark);
}

.hero__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 520px;
}

.hero__body p {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 300;
  line-height: 1.7;
  color: var(--color-text-secondary);
}

.hero__cta {
  display: flex;
  align-items: center;
  gap: var(--gap-hero-cta);
}

.btn-primary {
  display: inline-block;
  background-color: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  padding: var(--padding-btn-primary);
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 2px;
}

.hero__spotify-link {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 300;
  letter-spacing: 0.5px;
  color: #4b4b4b; /* intentional one-off from design — not a token */
  position: relative;
  transition: color 0.2s ease;
}

.hero__spotify-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.hero__spotify-link:hover {
  color: var(--color-dark);
}

.hero__spotify-link:hover::after {
  transform: scaleX(1);
}

/* =====================
   TRUST TICKER
   ===================== */
#ticker {
  background-color: var(--color-dark);
  height: 52px;
  overflow: hidden;
}

.ticker__track {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding: 0 max(var(--padding-nav-x), calc(50% - var(--half-offset)));
  gap: var(--gap-ticker);
}

.ticker__item {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  flex-shrink: 0;
}

.ticker__primary {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 2px;
  color: var(--color-text-faint);
}

.ticker__secondary {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 2px;
  color: #7A7268; /* intentional one-off from design — not a token */
}

.ticker__divider {
  width: 1px;
  height: 10px;
  background-color: rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
}

.ticker__set-2 {
  display: none;
}

/* =====================
   SHARED: SECTION LABEL
   ===================== */
.section-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 3px;
  color: var(--color-text-muted);
}

/* =====================
   WHAT I OFFER
   ===================== */
#what-i-offer {
  background-color: var(--color-cream);
  padding: var(--padding-section-y) max(var(--padding-section-x), calc(50% - var(--half-offset)));
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.pillars {
  display: flex;
  background-color: var(--color-separator);
  gap: var(--gap-pillars-grid); /* hairline border effect */
}

.pillar {
  flex: 1;
  background-color: var(--color-cream);
  padding: var(--padding-pillar-card);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.pillar:first-child { padding-left: 0; }
.pillar:last-child  { padding-right: 0; }

.pillar__number {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 1px;
  color: var(--color-text-faint);
}

.pillar__title {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 400;
  color: var(--color-dark);
}

.pillar__body {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 300;
  line-height: 1.7;
  color: var(--color-text-muted);
}

/* =====================
   FEATURED PERFORMANCES
   ===================== */
#performances {
  background-color: var(--color-warm-gray);
  padding: var(--padding-section-y) max(var(--padding-section-x), calc(50% - var(--half-offset)));
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.performances__heading {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 300;
  color: var(--color-dark);
}

.cards {
  display: flex;
  gap: var(--gap-cards-grid);
}

.card {
  flex: 1;
  border: 1px solid var(--color-card-border);
  background-color: var(--color-cream);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.card__image {
  height: 180px;
  background-size: cover;
  background-position: center;
}

.card__divider {
  border: none;
  border-top: 1px solid var(--color-card-divider);
}

.card__body {
  padding: var(--padding-card-body);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.card__platform {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--color-text-muted);
}

.card__title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 300;
  color: var(--color-dark);
  line-height: 1.3;
}

.card:hover .card__title {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.chip {
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 400;
  letter-spacing: 1px;
  color: var(--color-tag-text);
  border: 1px solid var(--color-card-border);
  padding: var(--padding-chip);
}

.card__status {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 400;
  letter-spacing: 1.5px;
  color: var(--color-text-muted);
}

/* =====================
   CONTACT
   ===================== */
#contact {
  background-color: var(--color-dark);
  padding: 88px max(var(--padding-section-x), calc(50% - var(--half-offset)));
  display: flex;
  gap: var(--gap-contact);
  align-items: flex-start;
}

.contact__info {
  width: 480px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: var(--gap-contact-info);
}

.contact__label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 3px;
  color: #ffffff; /* intentional one-off from design — not a token */
}

.contact__heading {
  font-family: var(--font-display);
  font-size: 52px;
  font-weight: 300;
  line-height: 1.05;
  color: #E0DBD0; /* intentional one-off from design — not a token */
}

.contact__details {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.contact__detail {
  font-family: var(--font-mono);
  font-size: 24px;
  font-weight: 300;
  color: var(--color-text-faint);
}

.contact__body {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.7;
  color: var(--color-tag-text);
  max-width: 400px;
}

.contact__socials {
  display: flex;
  gap: var(--gap-social-links);
}

.social-link {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--color-tag-text);
  position: relative;
}

.social-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.social-link:hover::after {
  transform: scaleX(1);
}

.social-link i,
.social-link svg {
  width: 14px;
  height: 14px;
  color: var(--color-tag-text);
}

.social-link span {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 1px;
}

/* Form */
.contact__form {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--gap-form-fields);
}

.form__name-row {
  display: flex;
  gap: var(--gap-form-name-row);
}

.form__name-row .form__field {
  flex: 1;
}

.form__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form__field label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-faint);
}

.form__field input,
.form__field textarea {
  background-color: var(--color-input-bg);
  border: 1px solid var(--color-input-border);
  border-radius: 6px;
  padding: var(--padding-input);
  color: var(--color-text-faint);
  font-family: var(--font-body);
  font-size: 13px;
  width: 100%;
  outline: none;
}

.form__field input::placeholder,
.form__field textarea::placeholder {
  color: var(--color-input-border);
}

.form__field textarea {
  height: 120px;
  resize: vertical;
  padding: 8px 12px;
}

.form__botcheck {
  display: none;
}

.btn-submit {
  width: 100%;
  background-color: var(--btn-submit-bg);
  color: var(--btn-submit-text);
  padding: var(--padding-btn-submit);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 2px;
}

.btn-submit:disabled {
  cursor: wait;
  opacity: 0.72;
}

.form__status {
  min-height: 20px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--color-text-faint);
}

.form__status[data-state="success"] {
  color: #DDE8D2;
}

.form__status[data-state="error"] {
  color: #F1C7C7;
}

/* =====================
   FOOTER
   ===================== */
#footer {
  background-color: var(--color-dark);
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 max(var(--padding-nav-x), calc(50% - var(--half-offset)));
}

.footer__logo {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 5px;
  color: #5A5550; /* intentional one-off from design — not a token */
}

.footer__copy {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 300;
  letter-spacing: 1px;
  color: #4A4540; /* intentional one-off from design — not a token */
}

/* =====================
   RESPONSIVE — ≤ 1024px (tablet + mobile)
   ===================== */
@media (max-width: 1024px) {

  /* Hide portrait — hero__left fills full width naturally */
  .hero__right {
    display: none;
  }

  /* Ticker — seamless CSS marquee */
  .ticker__set-2 {
    display: contents; /* invisible wrapper — children join the flex track directly */
  }

  .ticker__track {
    display: flex;
    justify-content: flex-start;
    padding: 0;
    width: max-content;
    animation: ticker-scroll 20s linear infinite;
  }

  .ticker__item {
    padding: 0 var(--gap-ticker);
  }

  @keyframes ticker-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
  }

  /* Contact — stack and fill on tablet, keep desktop horizontal padding */
  #contact {
    flex-direction: column;
    align-items: stretch;
    padding-top: 48px;
    padding-bottom: 48px;
    gap: 40px;
  }

  .contact__info {
    width: 100%;
  }

  .contact__form {
    width: 100%;
  }

  /* Footer — keep side by side on tablet, just adjust height */
  #footer {
    height: auto;
    padding-top: 20px;
    padding-bottom: 20px;
  }

}

/* =====================
   RESPONSIVE — ≤ 768px (mobile only)
   ===================== */
@media (max-width: 768px) {

  /* Nav */
  .nav {
    flex-direction: column;
    justify-content: center;
    gap: 12px;
    height: auto;
    padding: 16px;
    position: relative;
  }

  .nav__logo {
    font-size: 11px;
  }

  .nav__links {
    gap: 20px;
  }

  /* Hero — stack vertically, left column goes full width */
  #hero {
    flex-direction: column;
    height: auto;
    padding-bottom: 48px;
  }

  .hero__left {
    padding: 80px 24px 0;
    justify-content: flex-start;
  }

  .hero__heading {
    font-size: 48px;
  }

  /* What I Offer */
  #what-i-offer {
    padding: 48px 24px;
  }

  .pillars {
    flex-direction: column;
    background-color: transparent;
    gap: 0;
  }

  .pillar {
    border-bottom: 1px solid var(--color-separator);
  }

  .pillar:first-child { padding-left: var(--padding-pillar-card); }
  .pillar:last-child  { padding-right: var(--padding-pillar-card); border-bottom: none; }

  /* Performances */
  #performances {
    padding: 48px 24px;
  }

  .cards {
    flex-direction: column;
  }

  /* Contact */
  #contact {
    padding: 48px 24px;
  }

  .contact__detail {
    font-size: 18px;
  }

  /* Footer — switch to mobile padding */
  #footer {
    padding: 32px 24px;
  }

}
