/* ── Figma design tokens ─── */
:root {
  --background:   #fdfeff;
  --main-text:    #07062b;
  --green-text:   #4db1b4;
  --green-accent: #a7dee4;
  --pink-accent:  #e9cad7;
  --light-text:   #edf6ff;
  --logo:         #b9eff5;
  --nav-height:   104px;
  /* Pill CTA hover: smooth color blend (matches site motion) */
  --cta-hover-ease: cubic-bezier(0.33, 0.72, 0.42, 1);
  --cta-hover-duration: 0.4s;
}

*, *::before, *::after { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background-color: var(--background);
  color: var(--main-text);
  overflow-x: hidden;
}

html { min-height: 100%; }
body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Remove browser focus rings — the default blue outline reads as
   a stroke on rounded letters (o, a, c…) near the click point.   */
/* Font smoothing — prevents subpixel colour fringes around curved glyphs */
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

/* Hard-reset every browser-generated outline / focus ring / tap highlight */
*, *::before, *::after { outline: none !important; outline-offset: 0 !important; }
:focus, :focus-visible, :focus-within, :target, :active { outline: none !important; }
a, button {
  outline: none !important;
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  appearance: none;
}
a    { text-decoration: none; color: inherit; }
p, h1, h2, h3, h4 { margin: 0; padding: 0; font-weight: normal; }
img  { display: block; }
button { font: inherit; background: none; cursor: pointer; }

/* Green pill CTAs: pink hover overlay (desktop / tablet only — no hover layer on mobile). */
@media (min-width: 681px) {
  .case-dummy-button,
  .clario-pitch-button,
  .about-spotify-link-btn,
  .creative-more,
  .about-suggest-btn:not(:disabled),
  a.auto-20 {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    color: var(--main-text);
    transition: transform 0.2s var(--cta-hover-ease),
      box-shadow var(--cta-hover-duration) var(--cta-hover-ease);
  }

  .case-dummy-button::before,
  .clario-pitch-button::before,
  .about-spotify-link-btn::before,
  .creative-more::before,
  .about-suggest-btn:not(:disabled)::before,
  a.auto-20::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background-color: var(--pink-accent);
    opacity: 0;
    transition: opacity var(--cta-hover-duration) var(--cta-hover-ease);
    pointer-events: none;
  }

  .case-dummy-button:hover::before,
  .case-dummy-button:focus-visible::before,
  .clario-pitch-button:hover::before,
  .clario-pitch-button:focus-visible::before,
  .about-spotify-link-btn:hover::before,
  .about-spotify-link-btn:focus-visible::before,
  .creative-more:hover::before,
  .creative-more:focus-visible::before,
  .about-suggest-btn:not(:disabled):hover::before,
  .about-suggest-btn:not(:disabled):focus-visible::before,
  a.auto-20:hover::before,
  a.auto-20:focus-visible::before {
    opacity: 1;
  }

  .case-dummy-button > *,
  .clario-pitch-button > *,
  .about-spotify-link-btn > *,
  .creative-more > *,
  .about-suggest-btn:not(:disabled) > *,
  a.auto-20 > * {
    position: relative;
    z-index: 1;
  }
}

/*
  Logo font: Figma notation "Flatface_Haleys:Script" means
    family = "Flatface Haleys",  style = Script
*/
.f-script    { font-family: 'Flatface Haleys', cursive; font-style: italic; }
.f-higuen    { font-family: 'Higuen', serif; font-style: normal; }
.f-open-sans { font-family: 'Open Sans', sans-serif; font-weight: 300; }

/* ── Navbar (components/navbar.js) ─── */
body { padding-top: var(--nav-height); }

.site-nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-height);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 min(4.34vw, 75px);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  background-color: rgba(253,254,255,0.72);
  border-bottom: 1px solid rgba(7,6,43,0.06);
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.site-nav.scrolled {
  background-color: rgba(253,254,255,0.92);
  box-shadow: 0 2px 24px rgba(7,6,43,0.06);
}

.site-nav-logo {
  text-decoration: none; color: inherit;
  flex-shrink: 0;
  display: flex; align-items: center;
}

.site-nav-logo .logo-img {
  height: min(4.28vw, 74px);
  width: auto;
  display: block;
}

.site-nav-links {
  display: flex;
  gap: min(4.63vw, 80px);
  align-items: center;
  list-style: none;
  margin: 0; padding: 0;
}

.site-nav-links a {
  font-family: "Open Sans", sans-serif;
  font-weight: 300;
  font-size: min(1.39vw, 24px);
  letter-spacing: min(0.056vw, 0.96px);
  color: #07062b;
  text-decoration: none;
  white-space: nowrap;
  opacity: 0.85;
  transition: opacity 0.2s ease;
}

.site-nav-links a:hover { opacity: 1; }

.site-nav-toggle {
  display: none;
  width: min(8.33vw, 36px);
  height: min(8.33vw, 36px);
  padding: 0;
  border: 0;
  color: var(--main-text);
  position: relative;
  background: transparent;
}

.site-nav-toggle-line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(5.56vw, 24px);
  height: min(0.46vw, 2px);
  border-radius: 999px;
  background: currentColor;
  transform-origin: center;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.site-nav-toggle-line:nth-child(1) {
  transform: translate(-50%, calc(-50% - min(1.85vw, 8px)));
}

.site-nav-toggle-line:nth-child(2) {
  transform: translate(-50%, -50%);
}

.site-nav-toggle-line:nth-child(3) {
  transform: translate(-50%, calc(-50% + min(1.85vw, 8px)));
}

.site-nav.menu-open .site-nav-toggle-line:nth-child(1) {
  transform: translate(-50%, -50%) rotate(45deg);
}

.site-nav.menu-open .site-nav-toggle-line:nth-child(2) {
  opacity: 0;
}

.site-nav.menu-open .site-nav-toggle-line:nth-child(3) {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* ── Footer (components/footer.js) ─── */
.site-footer {
  width: 100%;
  background: linear-gradient(135deg, rgba(167,222,228,0.55) 0%, rgba(233,202,215,0.42) 52%, rgba(253,254,255,0.96) 100%);
  margin-top: auto;
}

.site-footer-inner {
  max-width: 1728px; margin: 0 auto;
  padding: min(8.10vw,140px) min(5.96vw,103px) min(3.88vw,67px);
}

.site-footer-row {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: min(2.08vw, 36px);
  row-gap: min(0.93vw, 16px);
  width: 100%;
}

.site-footer-taglines {
  grid-column: 1;
  grid-row: 1 / span 2;
  display: flex;
  flex-direction: column;
  gap: min(0.93vw, 16px);
}

.site-footer-heading {
  font-family: "Higuen", serif;
  font-style: normal; font-weight: normal;
  font-size: min(2.78vw,48px); letter-spacing: min(0.111vw,1.92px);
  color: var(--main-text,#07062b); line-height: 1.1; white-space: nowrap;
  margin: 0;
}

.site-footer-tagline {
  font-family: "Open Sans", sans-serif;
  font-weight: 300;
  font-size: min(1.56vw,28px);
  color: var(--green-text,#4db1b4); line-height: normal; white-space: nowrap;
  margin: 0;
}

.site-footer-icons {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  align-items: center;
  gap: min(2.08vw, 36px);
  justify-content: flex-end;
  flex-shrink: 0;
  align-self: start;
}

.site-footer-social-link {
  font-family: "Open Sans", sans-serif;
  font-weight: 300;
  font-size: min(1.04vw, 18px); letter-spacing: min(0.056vw, 0.96px);
  color: var(--main-text,#07062b);
  text-transform: uppercase;
  line-height: 1.1;
  white-space: nowrap;
  transition: opacity 0.2s ease, transform 0.2s ease;
  opacity: 0.85;
}

.site-footer-social-link:hover { opacity: 1; transform: translateY(-1px); }

@media (max-width: 980px) {
  :root {
    --nav-height: 96px;
  }

  .site-nav {
    padding: 0 min(5.13vw, 20px);
  }

  .site-nav-logo .logo-img {
    height: min(12.31vw, 48px);
  }

  .site-nav-toggle {
    display: inline-flex;
  }

  .site-nav-links {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    display: none;
    flex-direction: column;
    align-items: flex-start;
    gap: min(3.08vw, 12px);
    margin: 0;
    padding: min(4.1vw, 16px) min(5.13vw, 20px) min(5.13vw, 20px);
    background: rgba(253,254,255,0.98);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(7,6,43,0.08);
    box-shadow: 0 12px 28px rgba(7,6,43,0.08);
    z-index: 1001;
  }

  .site-nav.menu-open .site-nav-links {
    display: flex;
  }

  .site-nav.menu-open {
    border-bottom-color: transparent;
  }

  .site-nav-links a {
    font-size: clamp(16px, 4.1vw, 22px);
    letter-spacing: min(0.056vw, 0.96px);
    opacity: 1;
  }

  .site-footer-row {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }

  .site-footer-taglines {
    grid-column: 1;
    grid-row: 1 / span 2;
  }

  .site-footer-icons {
    grid-column: 1;
    grid-row: 3;
    justify-content: flex-start;
  }

  .site-footer-tagline,
  .site-footer-heading {
    white-space: normal;
  }
}

@media (max-width: 680px) {
  .site-footer-inner {
    padding: min(15.38vw, 60px) min(6.15vw, 24px) min(11.28vw, 44px);
  }

  .site-footer-row {
    row-gap: min(3.08vw, 12px);
  }

  .site-footer-taglines {
    gap: min(2.56vw, 10px);
  }

  .site-footer-heading {
    font-size: clamp(24px, 6.15vw, 32px);
    letter-spacing: min(0.16vw, 0.64px);
    line-height: 1.08;
  }

  .site-footer-tagline {
    font-size: clamp(12px, 3.33vw, 16px);
    letter-spacing: min(0.1vw, 0.4px);
    line-height: 1.25;
  }

  .site-footer-icons {
    gap: min(4.1vw, 16px);
    flex-wrap: wrap;
    align-items: center;
    margin-top: min(3.08vw, 12px);
  }

  .site-footer-social-link {
    font-size: clamp(13px, 3.33vw, 16px);
    letter-spacing: min(0.09vw, 0.36px);
    line-height: 1.2;
    padding: min(1.54vw, 6px) 0;
    opacity: 1;
  }
}
