 /* ---- Page rhythm ---- */
.main-content { padding: var(--space-6) 0; }
@media (min-width: 64rem){ .main-content { padding: var(--space-7) 0; } }

/* ---- Welcome / hero text ---- */
.welcome-section { text-align: center; margin-bottom: var(--space-6); }
.welcome-section h1{
  font-size: var(--h2);
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: var(--space-3);
}
.welcome-section .subtitle{
  color: var(--muted);
  font-size: var(--p);
  max-width: 60ch;
  margin-inline: auto;
}

/* ---- Success badge (soft gold pill) ---- */
.success-badge{
  display: inline-block;
  padding: .6rem 1rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--accent);
  color: var(--text);
  font-weight: 700;
  letter-spacing: .04em;
}

/* ---- Live availability note (glass box) ---- */
.loading-message{
  text-align: center;
  padding: var(--space-3);
  color: var(--text);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,193,7,0.6);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
          backdrop-filter: saturate(140%) blur(8px);
  border-radius: var(--radius);
}

/* ============================================
   FORM SHELL (match .form-card look)
   ============================================ */
.booking-form{
  padding: var(--space-5);
  border-radius: var(--radius);
  background: var(--ink);
  border: 1px solid #1b1b1b;
  border-bottom: 1px solid var(--accent);
  position: relative;
}
.form-header{ text-align: center; margin-bottom: var(--space-4); }
.form-header h2{
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin: 0 0 .25rem;
  color: var(--text);
}
.form-header p{ color: var(--muted); margin: 0; }

/* Grid rows from your site’s form rhythm */
.form-row{ display: grid; gap: .75rem; margin-bottom: var(--space-3); }
@media (min-width: 48rem){
  /* keep your original two-up where intended */
  .form-row{ grid-template-columns: 1fr 1fr; }
}

/* Labels and controls styled to match .input pattern */
.form-group label{
  display: block;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: .02em;
  font-size: .9em;
  margin-bottom: .35rem;
}
.form-group input,
.form-group select,
.form-group textarea{
  width: 100%;
  padding: .85rem 1rem;
  border-radius: 2rem;            /* pill single-line vibe */
  border: 0;
  border-bottom: 1px solid rgb(255,193,7);
  background: rgba(255,255,255,0.06);
  color: var(--text);
  font: inherit;
  line-height: 1.45;
  transition: box-shadow .25s ease, background-color .2s ease, border-color .2s ease;
}
.form-group textarea{ border-radius: var(--radius); }  /* square-ish textarea */
.form-group input::placeholder,
.form-group textarea::placeholder{ color: rgba(255,255,255,0.6); }

.form-group select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.25rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7l5 5 5-5' stroke='%23FFC107' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .8rem center;
  background-size: 1rem;
  border: 1px solid rgba(255,193,7,0.75);  /* select gets a full border */
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline: none;
  box-shadow: var(--gold-glow-ring), var(--gold-glow-outer);
}

/* ============================================
   PACKAGE OPTIONS (cards)
   ============================================ */
.package-options{
  display: grid;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
  grid-template-columns: 1fr;
}
@media (min-width: 56rem){
  .package-options{ grid-template-columns: 1fr 1fr; gap: var(--space-6); }
}

.package-option{
  background: var(--ink);
  border: 1px solid #1b1b1b;
  border-bottom: 1px solid var(--accent);
  border-radius: var(--radius);
  padding: var(--space-4);
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .2s ease;
  position: relative;
}
.package-option:hover{
  transform: translateY(-2px);
  box-shadow: var(--gold-glow-ring), var(--gold-glow-outer);
}
.package-option.selected{
  box-shadow: var(--gold-glow-ring), var(--gold-glow-outer);
  border-color: transparent;
  border-bottom-color: var(--true-black);
}
.package-badge{
  position: absolute; top: -10px; right: 10px;
  background: var(--accent); color: var(--true-black);
  padding: 4px 10px; border-radius: 12px;
  font-size: .7rem; font-weight: 700; letter-spacing: .5px;
}
.package-header h4{ font-size: 1.05rem; margin: 0 0 .35rem; }
.package-price{ margin: .4rem 0 .2rem; }
.price-large{ font-size: 1.35rem; font-weight: 700; color: var(--accent); display: block; }
.price-small{ font-size: .85rem; color: var(--muted); }
.package-option p,
.package-option li{ color: var(--muted); font-size: .95em; }
.package-option ul{ list-style: none; margin: .5rem 0 0; padding: 0; }

/* Discovery card */
.course-discovery{
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,193,7,0.6);
  border-radius: var(--radius);
  padding: var(--space-3);
  margin-top: var(--space-3);
}
.course-discovery h4{ color: var(--accent); font-size: .98rem; margin: 0 0 .35rem; }
.course-discovery p{ color: var(--muted); margin: 0 0 .35rem; }
.course-discovery a{ color: var(--accent); text-decoration: underline; }

/* ============================================
   CALENDAR
   ============================================ */
.calendar-container{
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,193,7,0.6);
  border-radius: var(--radius);
  padding: var(--space-4);
  margin-top: .5rem;
}
.calendar-header{
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-3);
}
.calendar-header h3{ color: var(--accent); font-size: var(--h3); margin: 0; }

/* nav buttons mimic your round arrows */
.nav-button{
  appearance: none;
  border: 1px solid var(--accent);
  background: rgba(255,255,255,0.06);
  color: var(--text);
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.25rem; height: 2.25rem;
  font-weight: 700;
  cursor: pointer;
  transition: box-shadow .25s ease, transform .15s ease, background-color .2s ease, border-color .2s ease;
}
.nav-button:hover,
.nav-button:focus-visible{
  outline: none;
  box-shadow: var(--gold-glow-ring), var(--gold-glow-outer);
}

.calendar-weekdays{
  display: grid; grid-template-columns: repeat(7, 1fr); gap: .35rem;
  margin-bottom: .5rem;
}
.weekday{
  text-align: center; padding: .6rem .25rem;
  color: var(--accent); font-weight: 700; font-size: .9rem;
}

.calendar-days{ display: grid; grid-template-columns: repeat(7, 1fr); gap: .35rem; }
.calendar-day{
  aspect-ratio: 1;
  display: grid; place-items: center;
  border-radius: var(--radius);
  font-weight: 600;
  position: relative;
  background: rgba(255,255,255,0.06);
  border: 1px solid #1b1b1b;
  color: var(--text);
  transition: border-color .2s ease, background-color .2s ease, color .2s ease, transform .15s ease;
}
.calendar-day.empty{ visibility: hidden; }
.calendar-day.past{
  color: #666; opacity: .5; pointer-events: none;
}
.calendar-day.available:hover{
  border-color: var(--accent);
}
.calendar-day.unavailable{
  background: rgba(255, 76, 76, 0.12);
  color: #FF6B6B;
  border-color: rgba(255, 76, 76, 0.35);
  cursor: not-allowed;
}
.calendar-day.selected{
  background: var(--accent);
  color: #111;
  border-color: var(--accent);
}
.calendar-day.block-session{
  background: rgba(76, 175, 80, 0.2);
  border: 1px solid #4CAF50;
  color: #4CAF50;
}
.calendar-day.block-session.selected{
  background: var(--accent); color: #111; border-color: var(--accent);
}
.calendar-day .session-number{
  position: absolute; top: 3px; right: 3px;
  background: #4CAF50; color: #fff;
  font-size: .7rem; font-weight: 700;
  border-radius: 999px; width: 16px; height: 16px;
  display: grid; place-items: center;
}

/* Selected date + time slots panel */
.selected-date-container{
  margin-top: var(--space-3);
  padding: var(--space-4);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,193,7,0.6);
  border-radius: var(--radius);
}
.selected-date h4{ color: var(--accent); font-size: 1.05rem; margin: 0 0 .5rem; }
.selected-date p{ color: var(--muted); margin: 0 0 .75rem; }

.available-times{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .6rem;
}
.time-slot{
  padding: .75rem 1rem;
  background: rgba(255,255,255,0.06);
  border: 1px solid #1b1b1b;
  border-radius: var(--radius);
  text-align: center; cursor: pointer;
  color: var(--text);
  transition: border-color .2s ease, background-color .2s ease, color .2s ease;
}
.time-slot:hover{ border-color: var(--accent); }
.time-slot.selected{
  background: var(--accent); color: #111; border-color: var(--accent);
}
.time-slot.unavailable{
  background: rgba(255,0,0,0.12); color: #FF6B6B; cursor: not-allowed; opacity: .8;
}
.no-slots-message{
  color: #FF6B6B; text-align: center; padding: var(--space-3);
  background: rgba(255, 76, 76, 0.1);
  border: 1px solid rgba(255, 76, 76, 0.3);
  border-radius: var(--radius);
}

/* 8-session schedule box */
.block-schedule{
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: rgba(255,255,255,0.06);
  border: 1px solid #4CAF50;
  border-radius: var(--radius);
}
.schedule-notice h4{ color: #4CAF50; margin: 0 0 .75rem; font-size: 1.05rem; }
.flexibility-notice{
  color: var(--text);
  margin-bottom: var(--space-3);
  padding: .85rem 1rem;
  background: rgba(255,255,255,0.06);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
}
.schedule-list{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: .6rem;
}
.schedule-item{
  background: rgba(255,255,255,0.06);
  padding: .75rem 1rem;
  border-radius: var(--radius);
  border: 1px solid #1b1b1b;
  display: flex; align-items: center; justify-content: space-between;
}
.schedule-item.first-session{
  border-color: var(--accent);
  background: rgba(255,193,7,0.08);
}
.session-number-text{ color: #4CAF50; font-weight: 700; font-size: .9rem; }
.session-date{ color: var(--muted); font-size: .9rem; }
.session-time{ color: var(--accent); font-weight: 700; font-size: .9rem; }

/* ============================================
   PAYMENT + SUBMIT
   ============================================ */
.payment-info{
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,193,7,0.6);
  border-radius: var(--radius);
  padding: var(--space-4);
  margin: var(--space-4) 0;
}
.payment-info h4{ color: var(--accent); margin: 0 0 .5rem; font-size: 1.05rem; }
.payment-info p{ color: var(--muted); margin: 0; }

/* Make your existing submit button look like .btn .btn-primary */
.submit-button{
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%;
  padding: var(--btn-pad-y) var(--btn-pad-x);
  border-radius: var(--btn-radius);
  border: 1px solid var(--true-black);
  background: var(--accent); color: #111;
  font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  cursor: pointer;
  transition: box-shadow .25s ease, transform .15s ease, background-color .2s ease, border-color .2s ease;
  margin-top: var(--space-3);
}
.submit-button:hover{ box-shadow: var(--gold-glow-ring), var(--gold-glow-outer); }
.submit-button:active{ transform: translateY(1px); }
.submit-button:disabled{
  opacity: .55; cursor: not-allowed; box-shadow: none; transform: none;
}

/* Loading spinner state from your existing class */
.loading .submit-button::after{
  content: "";
  width: 20px; height: 20px;
  border: 2px solid #111; border-top: 2px solid transparent;
  border-radius: 50%;
  display: inline-block; margin-left: 10px;
  animation: spin 1s linear infinite;
}
@keyframes spin{ to { transform: rotate(360deg); } }

/* Success message card */
#successMessage{
  background: linear-gradient(135deg, #4CAF50, #45a049);
  color: #fff;
  padding: 1.75rem;
  border-radius: var(--radius);
  text-align: center;
  font-size: 1.05rem;
  font-weight: 700;
  margin: var(--space-5) auto;
  max-width: 44rem;
  border: 2px solid #4CAF50;
  box-shadow: 0 10px 30px rgba(76, 175, 80, 0.3);
}

/* hide by default */
#successMessage { 
  display: none;
}

/* show after submit */
#successMessage.show { 
  display: block;
}
/* ===== Vertical rhythm for the whole booking form ===== */
:root{
  /* fallback if your tokens don't exist */
  --form-stack: 1.25rem;
  --form-stack-lg: 1.75rem;
}

/* Add top-margin between direct siblings inside the form shell */
.booking-form > * + * { margin-top: var(--form-stack); }

/* Header spacing */
.form-header { margin-bottom: var(--form-stack-lg); }

/* Rows & groups */
.form-row { 
  gap: 1rem;                       /* space between fields in the same row */
  margin-bottom: var(--form-stack);
}
.form-group { 
  margin-bottom: var(--form-stack); /* stack groups vertically */
}
.form-group label { margin-bottom: .5rem; }

/* Package section */
.package-options { 
  gap: var(--form-stack); 
  margin-bottom: var(--form-stack); 
}
.course-discovery { margin-top: var(--form-stack); }

/* Calendar block spacing */
.calendar-container { margin-top: .75rem; }
.selected-date-container { margin-top: var(--form-stack); }
.available-times { gap: .75rem; }

/* 8-week schedule spacing */
.block-schedule { margin-top: var(--form-stack); }
.schedule-list { gap: .75rem; }

/* Payment + submit spacing */
.payment-info { margin: var(--form-stack-lg) 0; }
.submit-button { margin-top: var(--form-stack); }

/* FAQ spacing */
.faq { padding-block: calc(var(--form-stack-lg) * 2); }
.faq h2 { margin-bottom: var(--form-stack-lg); }
.faq-item { margin-bottom: var(--form-stack); }

/* Make it breathe more on larger screens */
@media (min-width: 56rem){
  :root{
    --form-stack: 1.5rem;
    --form-stack-lg: 2rem;
  }
  .form-row { gap: 1.25rem; }
  .available-times { gap: 1rem; }
  .schedule-list { gap: 1rem; }
}
/* ===========================
   Calendar — compact sizing
   =========================== */

/* Tunable sizes */
:root{
  --cal-cell: 42px;      /* desktop cell height */
  --cal-gap: .35rem;     /* space between cells */
  --cal-pad: 1rem;       /* calendar container padding */
}

/* Keep the whole calendar from getting too wide on desktop */
.calendar-container{
  max-width: 560px;      /* tighten width */
  margin-inline: auto;   /* center it */
  padding: var(--cal-pad);
  
}

/* Tighter header */
.calendar-header{ margin-bottom: .75rem; }
.calendar-header h3{ font-size: 1.05rem; }

/* Weekday row: smaller, tighter */
.calendar-weekdays{
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: var(--cal-gap);
  margin-bottom: .35rem;
}
.weekday{
  padding: .4rem .2rem;
  font-size: .8rem;
  line-height: 1;
  word-break: keep-all;
}

/* Days grid: fixed row height; no aspect-ratio overflow */
.calendar-days{
  grid-template-columns: repeat(7, minmax(0, 1fr));
  grid-auto-rows: var(--cal-cell);
  gap: var(--cal-gap);
}

/* Day cells: use fixed height instead of aspect-ratio */
.calendar-day{
  height: var(--cal-cell);
  aspect-ratio: auto;            /* override previous aspect-ratio */
  padding: 0;                    /* ensure snug fit */
  font-size: .9rem;
}
.calendar-day .session-number{
  top: 2px; right: 2px;          /* keep badge inside tighter cell */
}

/* Make nav buttons smaller to match */
.nav-button{
  width: 1.9rem; height: 1.9rem;
  font-size: .95rem;
}

/* Selected-date panel spacing a bit tighter */
.selected-date-container{ padding: .9rem; }

/* ===========================
   Mobile safety net
   =========================== */
@media (max-width: 480px){
  :root{
    --cal-cell: 28px;    /* smaller cells on small phones */
    --cal-gap: .25rem;
    --cal-pad: .75rem;
  }

  .calendar-header h3{ font-size: .95rem; }
  .weekday{ font-size: .7rem; padding: .35rem .15rem; }

  /* Prevent any horizontal overflow */
  .calendar-grid,
  .calendar-container{ overflow: hidden; }

  /* Time slots tighten up too */
  .available-times{ gap: .5rem; }
  .time-slot{ padding: .6rem .7rem; font-size: .9rem; }
}

/* ===========================
   Medium screens/tablets
   =========================== */
@media (max-width: 768px){
  :root{
    --cal-cell: 34px;
    --cal-gap: .3rem;
  }
  .calendar-container{ max-width: 520px; }
  .calendar-header h3{ font-size: 1rem; }
}

/* Optional: super-compact mode toggle (add .calendar--compact to container if you ever want smaller) */
.calendar--compact .calendar-container{ max-width: 480px; }
.calendar--compact .calendar-days{ grid-auto-rows: 30px; }
.calendar--compact .weekday{ font-size: .72rem; }
/* Desktop upsize (keeps mobile compact) */
@media (min-width: 992px){
  .calendar-container{
    max-width: 680px;           /* was ~560px */
    padding: 1.25rem;           /* a touch more breathing room */
  }
  .calendar-header h3{ font-size: 1.15rem; }

  /* Slightly larger cells on desktop */
  .calendar-days{ grid-auto-rows: 52px; }   /* was ~42px */
  .calendar-day{ height: 52px; font-size: 1rem; }
  .weekday{ font-size: .92rem; padding: .5rem .25rem; }
}

/* Medium screens (tablets) – split the difference */
@media (min-width: 768px) and (max-width: 991px){
  .calendar-container{ max-width: 620px; }
  .calendar-days{ grid-auto-rows: 46px; }
  .calendar-day{ height: 46px; font-size: .95rem; }
}
/* Make submit button match site buttons (lowercase, normal spacing) */
.booking-form .submit-button{
  text-transform: none !important;   /* stop the uppercase */
  letter-spacing: 0;                 /* remove the wide tracking */
  font-weight: 600;                  /* adjust if your buttons use 600 */
  font-variant-caps: normal;
}
/* ===== Welcome section styled like the blog header ===== */
.welcome-section{
  text-align: center;
  padding-top: var(--space-8);
  padding-bottom: var(--space-6);
  margin-bottom: var(--space-4);
}

/* Main title — use your site’s heading scale; similar vibe to blog titles */
.welcome-section h1{
  margin: 0 0 .25rem;
  letter-spacing: .01em;
  text-transform: uppercase;                     /* keep like blog */
  font-size: var(--h2);   /* aligns with blog scale */
  color: var(--text);
  padding-bottom: var(--space-2);
}

/* Subhead — identical rules to #blog .blog-head .subhead */
.welcome-section .subhead{
  font-weight: 700;
  color: var(--text);
  text-transform: none;
  letter-spacing: .01em;
  margin-top: -.25rem;
  margin-bottom: 0;
  line-height: 1.15;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  opacity: 0.95; /* optional: slight softness like body text */
}

/* ==== Make booking welcome section match the blog header exactly ==== */
.welcome-section{
  /* same spacing as #blog */
  text-align: center;
  padding-bottom: var(--space-6);
  margin-bottom: var(--space-4);
}

/* Remove the outer gap above the welcome section */
.main-content{ 
  padding-top: 0 !important; 
}

/* Put the breathing room inside the green welcome block instead */
.welcome-section{
  padding-top: var(--space-8);   /* adjust to taste */
}
.loading-availability{
  display:block;
  margin:.5rem 0 1rem;
  font-size:.95rem;
  color: var(--muted);
}
