/* ===========================
   Calendar / Booking Page
   Aaron Seckman Audio
   =========================== */

:root {
  --cal-bg: #000000;
  --cal-fg: #eae8f5;
  --cal-muted: #cfcbe0;
  --cal-accent: #f0b392;
  --cal-cyan: #65fff9;
  --cal-panel: #0b0b0f;
  --cal-border: rgba(255, 255, 255, 0.18);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  background:
    radial-gradient(circle at 50% 18%, rgba(68, 255, 243, 0.12), transparent 30%),
    radial-gradient(circle at 70% 70%, rgba(255, 181, 143, 0.08), transparent 28%),
    var(--cal-bg);
  color: var(--cal-fg);
}

#calendar {
  min-height: 100vh;
  width: min(94vw, 980px);
  margin: 0 auto;
  padding: clamp(28px, 6vw, 64px) 16px 22px;
  color: var(--cal-fg);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

#calendar h1,
#calendar h2,
#calendar h3,
#calendar a {
  font-family: 'donovanregular', Helvetica, Arial, sans-serif;
}

#calendar p {
  font-family: 'AwakeRegular', Helvetica, Arial, sans-serif;
}

#calendar .booking-card {
  width: 100%;
  max-width: 850px;
  margin: 0 auto;
  padding: clamp(28px, 5vw, 48px) clamp(20px, 5vw, 56px);
  text-align: center;
  color: var(--cal-fg);
  background: rgba(11, 11, 15, 0.96);
  border: 1px solid #ffffff;
  outline: 1px solid var(--cal-border);
  outline-offset: -6px;
  border-radius: 12px;
  box-shadow:
    0 0 28px rgba(68, 255, 243, 0.20),
    0 2px 10px rgba(0, 0, 0, 0.4);
}

#calendar .eyebrow {
  display: block;
  width: 100%;
  margin: 0 auto 14px;
  color: var(--cal-accent);
  font-family: 'AwakeRegular', Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: center;
}

#calendar h1 {
  margin: 0 0 22px;
  color: #fff;
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.05;
  font-weight: normal;
}

#calendar .lede {
  max-width: 760px;
  margin: 0 auto 18px;
  color: var(--cal-muted);
  font-size: clamp(19px, 2.3vw, 24px);
  line-height: 1.45;
}

#calendar .plain {
  max-width: 660px;
  margin: 0 auto;
  color: var(--cal-fg);
  font-size: clamp(16px, 1.8vw, 18px);
  line-height: 1.55;
}

#calendar .small {
  max-width: 680px;
  margin: 20px auto 0;
  color: var(--cal-fg);
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 1.5;
}

#calendar a {
  color: #fff;
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 153, 85, 0.65);
}

#calendar a:hover {
  color: #ddd;
}

#calendar .booking-cta {
  margin: 28px auto 0;
  min-height: 48px;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Google scheduling button target */
#calendar .booking-cta button,
#calendar .booking-cta a,
#calendar .booking-cta [role="button"] {
  font-family: 'donovanregular', Helvetica, Arial, sans-serif !important;
  font-size: 18px !important;
  color: #000 !important;
  background-color: transparent !important;
  background-image: linear-gradient(90deg, #0ff, #ff9955, #0ff) !important;
  background-size: 200% 100% !important;
  background-repeat: no-repeat !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 12px 24px !important;
  text-decoration: none !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35) !important;
  animation: buttonGradientShift 3s ease infinite;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#calendar .booking-cta button:hover,
#calendar .booking-cta a:hover,
#calendar .booking-cta [role="button"]:hover {
  transform: scale(1.05);
  box-shadow: 0 0 15px #0ff, 0 0 25px #ff9955 !important;
}

@keyframes buttonGradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

#calendar .footer {
  width: 100%;
  max-width: 980px;
  margin: 28px auto 0;
  padding-top: 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  font-size: 12px;
  font-family: 'AwakeRegular', Helvetica, Arial, sans-serif;
  font-weight: normal;
  color: #cfcbe0;
  text-align: center;
  line-height: 1.5;
}

#calendar .footer p {
  margin: 0;
}

#calendar .footer a {
  font-size: inherit;
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 153, 85, 0.65);
}

#calendar .footer a:hover {
  text-decoration: underline;
}

@media (max-width: 600px) {
  #calendar {
    width: min(96vw, 980px);
    padding: 24px 12px 18px;
  }

  #calendar .booking-card {
    padding: 28px 18px;
  }

  #calendar .booking-cta button,
  #calendar .booking-cta a,
  #calendar .booking-cta [role="button"] {
    width: 100%;
    max-width: 260px;
  }
}

@media (prefers-reduced-motion: reduce) {
  #calendar .booking-cta button,
  #calendar .booking-cta a,
  #calendar .booking-cta [role="button"] {
    animation: none;
    transition: none;
  }

  #calendar .booking-cta button:hover,
  #calendar .booking-cta a:hover,
  #calendar .booking-cta [role="button"]:hover {
    transform: none;
    box-shadow: none !important;
  }
}