/* pages/schedule.css
   Schedule page-owned layout, cards, hero, and schedule helpers.
   Source: assets/css/ss.css migration split. */

.schedule-table {
  width: 100%;
  border-collapse: collapse;
  background: #fffaf2;
  font-size: 0.95rem;
  box-shadow: 0 25px 50px rgba(33, 29, 24, 0.08);
}

.calm-pricing-preview {
  padding: 3rem 0;
  background: #f7f3ec;
}

.pricing-preview-card {
  max-width: 860px;
  margin: 0 auto;
  padding: 2rem;
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 24px;
  background: #fffaf2;
  box-shadow: 0 18px 45px rgba(33, 29, 24, 0.06);
}

.pricing-preview-card .eyebrow {
  margin-bottom: 0.5rem;
  color: #5f6f52;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
}

.pricing-preview-card h2 {
  margin-bottom: 0.75rem;
  font-size: clamp(1.6rem, 3vw, 2.25rem);
  line-height: 1.1;
}

.pricing-preview-copy {
  max-width: 680px;
  margin-bottom: 1.5rem;
  color: #756b5f;
  font-size: 1.05rem;
  line-height: 1.6;
}

.pricing-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.pricing-preview-option {
  padding: 1.25rem;
  border-radius: 18px;
  background: #efe8dc;
  border: 1px solid rgba(33, 29, 24, 0.12);
}

.pricing-label,
.pricing-note {
  display: block;
}

.pricing-label {
  margin-bottom: 0.35rem;
  color: #211d18;
  font-weight: 700;
}

.pricing-preview-option strong {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 2rem;
  line-height: 1;
  color: #211d18;
}

.pricing-note {
  color: #756b5f;
  font-size: 0.95rem;
}

.pricing-guarantee {
  margin: 1rem 0 1.5rem;
  padding: 1rem;
  border-radius: 16px;
  background: rgba(255, 250, 242, 0.95);
  color: #211d18;
}

.pricing-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

@media (max-width: 640px) {
  .pricing-preview-card {
    padding: 1.35rem;
    border-radius: 20px;
  }

  .pricing-preview-grid {
    grid-template-columns: 1fr;
  }

  .pricing-preview-actions .btn {
    width: 100%;
    text-align: center;
  }
}

.schedule-table caption {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 0.5rem 0;
  color: rgba(33, 29, 24, 0.65);
}

.schedule-table td {
  border: 1px solid rgba(33, 29, 24, 0.12);
  padding: 0.85rem 0.75rem;
}

.schedule-table th {
  background: rgba(95, 111, 82, 0.08);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.schedule-table .day-sep th {
  border-top: 2px solid rgba(95, 111, 82, 0.35);
  border-bottom: none;
  background: rgba(95, 111, 82, 0.86);
  color: #fffaf2;
  font-size: 1rem;
}

.schedule-table .day-sep .note {
  margin-left: 0.75rem;
  color: rgba(255, 250, 242, 0.88);
  font-size: 0.85rem;
}

.schedule-table .col-action a.cta {
  display: inline-flex;
  justify-content: center;
  width: 100%;
}

.schedule-table .badge {
  font-size: 0.75rem;
  padding: 0.15rem 0.5rem;
}

@media (max-width: 768px) {
  .page-schedule .schedule-table {
    min-width: 0 !important;
    width: 100%;
  }

  .page-schedule .schedule-table-wrap {
    overflow: visible;
    border: 0;
    background: transparent;
  }

  .page-schedule .schedule-table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
  }

  .page-schedule .schedule-table tbody tr {
    display: block;
    margin: 0 0 12px;
    border-radius: 18px;
    border: 1px solid rgba(33, 29, 24, 0.12);
    background: linear-gradient(180deg, rgba(255, 250, 242, 0.98), rgba(239, 232, 220, 0.96));
    box-shadow: 0 10px 28px rgba(33, 29, 24, 0.12);
    overflow: hidden;
    position: relative;
  }

  .page-schedule .schedule-table tbody tr::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: rgba(185, 138, 60, 0.55);
  }

  .page-schedule .schedule-table tbody th[scope="row"] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 12px;
    font-weight: 950;
    letter-spacing: .02em;
    border-bottom: 1px solid rgba(33, 29, 24, 0.10);
    background:
      radial-gradient(520px 160px at 20% 0%, rgba(184, 138, 68, 0.22), transparent 55%),
      rgba(255, 250, 242, 0.98);
    color: #211d18;
  }

  .page-schedule .schedule-table tbody td {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(33, 29, 24, 0.08);
    text-align: right;
    align-items: flex-start;
    color: #211d18;
  }

  .page-schedule .schedule-table tbody td:last-child {
    border-bottom: 0;
  }

  .page-schedule .schedule-table tbody td::before {
    content: attr(data-label);
    flex: 0 0 auto;
    font-weight: 850;
    color: #756b5f;
    text-align: left;
  }

  .page-schedule .schedule-table tbody td[data-label="Time"] {
    padding-top: 12px;
    padding-bottom: 12px;
    font-size: 16px;
    font-weight: 900;
    letter-spacing: .01em;
  }

  .page-schedule .schedule-table tbody td[data-label="Class"] {
    font-size: 15px;
    font-weight: 850;
  }

  .page-schedule .schedule-table tbody td[data-label="Notes"]::before {
    content: "Details";
  }

  .page-schedule .schedule-table .badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 950;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(33, 29, 24, 0.12);
    background: rgba(255, 250, 242, 0.9);
    margin-left: 8px;
    white-space: nowrap;
  }

  .page-schedule .schedule-table .badge::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 99px;
    background: rgba(185, 138, 60, 0.95);
    box-shadow: 0 0 0 3px rgba(185, 138, 60, 0.18);
  }

  .page-schedule .schedule-table .badge--nogi::before {
    background: rgba(95, 111, 82, 0.82);
    box-shadow: 0 0 0 3px rgba(95, 111, 82, 0.16);
  }

  .page-schedule .mobile-card-cta-wrap {
    margin-top: 10px;
    display: flex;
    justify-content: flex-end;
  }

  .page-schedule .mobile-card-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    max-width: 360px;
    padding: 12px 14px;
    border-radius: 14px;
    font-weight: 950;
    text-decoration: none;
    background: var(--button-color);
    color: var(--button-text);
    border: 1px solid var(--button-color);
    box-shadow: 0 10px 24px rgba(245, 158, 11, 0.30);
  }

  .page-schedule .mobile-card-cta:active {
    transform: translateY(1px);
  }

  .page-schedule .mobile-card-cta:hover {
    background: var(--button-hover);
    border-color: var(--button-hover);
  }

  .page-schedule .mobile-card-cta small {
    display: block;
    font-weight: 800;
    opacity: .86;
  }
}

.schedule-table {
  width: 100%;
  border-collapse: collapse;
  background: #fffaf2;
  font-size: 0.95rem;
  box-shadow: 0 25px 50px rgba(33, 29, 24, 0.08);
}

.schedule-table caption {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 0.5rem 0;
  color: rgba(33, 29, 24, 0.65);
}

.schedule-table td {
  border: 1px solid rgba(33, 29, 24, 0.12);
  padding: 0.85rem 0.75rem;
}

.schedule-table th {
  background: rgba(95, 111, 82, 0.08);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.schedule-table .day-sep th {
  border-top: 2px solid rgba(95, 111, 82, 0.35);
  border-bottom: none;
  background: rgba(95, 111, 82, 0.86);
  color: #fffaf2;
  font-size: 1rem;
}

.schedule-table .day-sep .note {
  margin-left: 0.75rem;
  color: rgba(255, 250, 242, 0.88);
  font-size: 0.85rem;
}

.schedule-table .col-action a.cta {
  display: inline-flex;
  justify-content: center;
  width: 100%;
}

.schedule-table .badge {
  font-size: 0.75rem;
  padding: 0.15rem 0.5rem;
}

.ssched .lead .ss-location-link {
  color: #0a0a0a !important;
}

#schedule section.ssched .switch label:nth-child(4) a {
  color: #0a0a0a;
}

.hero-schedule-grid {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr)minmax(260px, 320px);
  gap: clamp(1.5rem, 2.5vw, 2.5rem);
  padding-top: 1rem
}

.hero-schedule__panel {
  background: linear-gradient(180deg, rgba(255, 250, 242, 0.96) 0%, rgba(239, 232, 220, 0.92) 100%);
  border-radius: 24px;
  padding: 1.75rem;
  border: 1px solid rgba(33, 29, 24, 0.12);
  box-shadow: 0 20px 40px rgba(33, 29, 24, 0.16);
  color: #211d18;
  backdrop-filter: blur(12px)
}

.hero-schedule__panel-header {
  display: flex;
  flex-direction: column;
  gap: 0.35rem
}

.hero-schedule__panel-title {
  font-size: 1.5rem;
  margin-bottom: 0;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600
}

.hero-schedule__panel-subtitle,
.hero-schedule__panel-note,
.hero-schedule__panel-times strong {
  color: rgba(33, 29, 24, 0.95)
}

.hero-schedule__panel-subtitle {
  font-size: 0.9rem;
  letter-spacing: 0.2em;
  text-transform: uppercase
}

.hero-schedule__panel-times {
  line-height: 1.6;
  font-weight: 500
}

.hero-schedule__panel-note {
  font-size: 0.9rem;
  letter-spacing: 0.08em
}

.hero-schedule__panel-cta {
  border-color: rgba(33, 29, 24, 0.15);
  color: #211d18
}

.hero-schedule__panel-cta {
  border-color: rgba(255, 250, 242, 0.5)
}

@media(max-width: 991.98px) {
  .hero-schedule-grid {
    grid-template-columns: 1fr
  }

  .hero-schedule__panel {
    padding: 1.5rem
  }
}

.schedule-wrapper {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  border: 1px solid #e2e8f0
}

.schedule-location-switch {
  background: rgba(255, 250, 242, 0.96);
  margin: 1rem auto 0;
  padding: 1rem;
  border-radius: 24px;
  max-width: 760px;
  border: 1px solid rgba(33, 29, 24, 0.08);
  box-shadow: 0 20px 40px rgba(33, 29, 24, 0.08);
  text-align: center
}

.schedule-location-switch p a {
  color: #0a0a0a !important;
}

.page-schedule #class-times,
.page-schedule #weekly-class-times {
  scroll-margin-top: 90px;
}

.page-schedule .schedule-hero-actions {
  margin: 0.75rem 0 1.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.page-schedule {
  --schedule-mini-h: 132px;
}

.page-schedule .schedule-mini-bar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1200;
  padding: 8px 12px calc(8px + env(safe-area-inset-bottom));
  background: rgba(15, 12, 8, 0.92);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(12px);
  display: none;
}

.schedule-mini-bar__inner {
  display: grid;
  gap: 8px;
}

.schedule-mini-bar__locations,
.schedule-mini-bar__lanes {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}

.schedule-mini-bar__chip {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

.schedule-mini-bar__book {
  width: 100%;
  border-radius: 999px;
  padding: 0.45rem 0.75rem;
  font-weight: 700;
}

.page-schedule .schedule-mini-bar .schedule-location-switch__button {
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.72rem;
  padding: 0.3rem 0.65rem;
}

.page-schedule .schedule-mini-bar .schedule-location-switch__button--active {
  background: #36ff9a;
  color: rgba(0, 0, 0, 0.88);
  border-color: rgba(0, 0, 0, 0.1);
}

@media(max-width: 860px) {
  .page-schedule {
    padding-bottom: calc(var(--schedule-mini-h) + env(safe-area-inset-bottom));
  }

  .page-schedule .schedule-mini-bar {
    display: block;
  }

  .page-schedule .mobile-sticky-cta {
    display: none;
  }
}

.schedule-grid {
  display: grid;
  gap: 12px;
  width: 100%;
}

.schedule-grid__head {
  display: none;
}

.schedule-slot {
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 14px;
  padding: 12px 14px;
  background: #fffaf2;
}

.slot__day {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  color: rgba(33, 29, 24, 0.55);
  font-weight: 700;
}

.slot__time {
  font-size: 1.1rem;
  font-weight: 700;
  margin-top: 4px;
}

.slot__title {
  font-size: 1rem;
  font-weight: 600;
  margin-top: 6px;
}

.slot__meta {
  font-size: 0.88rem;
  color: rgba(33, 29, 24, 0.75);
  margin-top: 6px;
}

@media(min-width: 860px) {
  .schedule-grid:not(.ss-schedule-table) {
    grid-template-columns: 110px 170px minmax(0, 1.21fr) minmax(0, 1.79fr);
    gap: 0;
  }

  .schedule-grid__head {
    display: contents;
  }

  .schedule-grid__head&gt;
  div,
  .schedule-slot&gt;

  div {
    padding: 10px 12px;
    border-bottom: 1px solid rgba(15, 12, 8, 0.1);
    min-width: 0;
  }

  .schedule-grid__head&gt;

  div {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(15, 12, 8, 0.6);
    font-weight: 700;
  }

  .schedule-slot {
    display: contents;
    border: 0;
    padding: 0;
    background: transparent;
  }

  .slot__day,
  .slot__time,
  .slot__title,
  .slot__meta {
    margin-top: 0;
  }

  .slot__time {
    font-size: 1rem;
  }
}

.schedule-location-switch .schedule-location-switch__button--active {
  background: transparent;
  color: #0f0c08;
  border-color: rgba(15, 12, 8, 0.2);
}

.ss-book .schedule-location-switch {
  color: #0f0c08;
  --ss-muted: rgba(15, 12, 8, .7)
}

.ss-book .schedule-location-switch .text-muted {
  color: rgba(15, 12, 8, .7) !important;
}

body[data-layout="booking"] .ss-book .schedule-location-switch a.ss-location-link,
body[data-layout="booking"] .ss-book .schedule-location-switch a.ss-location-link:visited,
body[data-layout="booking"] .ss-book .schedule-location-switch a.ss-location-link:hover,
body[data-layout="booking"] .ss-book .schedule-location-switch a.ss-location-link:focus,
body[data-layout="booking"] .ss-book .schedule-location-switch a[href*="Tannersville"],
body[data-layout="booking"] .ss-book .schedule-location-switch a[href*="Tannersville"]:visited,
body[data-layout="booking"] .ss-book .schedule-location-switch a[href*="Tannersville"]:hover,
body[data-layout="booking"] .ss-book .schedule-location-switch a[href*="Tannersville"]:focus {
  color: #0f0c08 !important;
}

body[data-layout="booking"] .ss-book .schedule-location-switch .text-muted a.ss-location-link,
body[data-layout="booking"] .ss-book .schedule-location-switch .text-muted a[href*="Tannersville"] {
  color: #0f0c08 !important;
}

/* Schedule page top rebuild */
.page-schedule .ss-schedule-hero {
  background:
    radial-gradient(900px 320px at 12% 0%, rgba(95, 111, 82, 0.16), transparent 58%),
    linear-gradient(180deg, #fffaf2 0%, #f7f3ec 100%);
  color: #211d18;
  padding: clamp(3rem, 7vw, 5.5rem) 0 clamp(2.25rem, 5vw, 4rem);
}

.page-schedule .ss-schedule-hero__inner {
  max-width: 960px;
}

.page-schedule .ss-eyebrow {
  margin: 0 0 0.75rem;
  color: var(--ss-cyan, #00dde0);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.82rem;
}

.page-schedule .ss-schedule-hero h1 {
  max-width: 850px;
  margin: 0;
  font-size: clamp(2.25rem, 6vw, 4.75rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
  font-weight: 900;
}

.page-schedule .ss-hero-lede {
  margin: 1rem 0 1.5rem;
  max-width: 620px;
  font-size: clamp(1.2rem, 2.5vw, 1.65rem);
  line-height: 1.35;
  color: #756b5f;
}

.page-schedule .ss-time-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
  margin: 1.5rem 0;
  max-width: 760px;
}

.page-schedule .ss-time-card {
  display: block;
  padding: 1rem;
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 1rem;
  background: rgba(255, 250, 242, 0.94);
  color: #211d18;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(33, 29, 24, 0.09);
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.page-schedule .ss-time-card:hover,
.page-schedule .ss-time-card:focus {
  transform: translateY(-2px);
  background: #fffaf2;
  border-color: rgba(95, 111, 82, 0.32);
  color: #211d18;
  box-shadow: 0 16px 34px rgba(33, 29, 24, 0.12);
}

.page-schedule .ss-time-card strong {
  display: block;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1;
  font-weight: 900;
  color: #211d18;
}

.page-schedule .ss-time-card span {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.98rem;
  color: #756b5f;
}

.page-schedule .ss-first-day-proof {
  margin: 1.25rem 0;
  font-weight: 800;
  font-size: 1.05rem;
  color: #362b24;
}

.page-schedule .ss-schedule-hero .ss-safety-strip {
  display: block;
  margin: 1.5rem 0 0;
  padding-block: 1.5rem !important;
}

.page-schedule .ss-schedule-hero .ss-safety-strip>.container {
  width: 100%;
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

.page-schedule .ss-schedule-hero .ss-safety-strip .row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  gap: 0.85rem;
  margin-left: 0;
  margin-right: 0;
}

.page-schedule .ss-schedule-hero .ss-safety-strip .row>[class*="col-"] {
  width: auto;
  padding-left: 0;
  padding-right: 0;
}

.page-schedule .ss-schedule-hero .ss-proof-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3.5rem;
  width: 100%;
  height: 100%;
  text-align: center;
  white-space: normal;
  writing-mode: horizontal-tb;
  text-orientation: mixed;
}

@media (max-width: 575.98px) {
  .page-schedule .ss-schedule-hero .ss-safety-strip {
    width: 100%;
    max-width: 310px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-schedule .ss-schedule-hero .ss-safety-strip .row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
  }
}

.page-schedule .ss-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.4rem;
}

.page-schedule .ss-main .ss-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.85rem 1.15rem;
  border-radius: 999px;
  font-weight: 900;
  text-decoration: none;
  line-height: 1;
}

.page-schedule .ss-main .ss-btn-primary {
  background: var(--ss-green, #116A42);
  color: #fff;
}

.page-schedule .ss-main .ss-btn-primary:hover,
.page-schedule .ss-main .ss-btn-primary:focus {
  color: #fff;
  filter: brightness(1.05);
}

.page-schedule .ss-main .ss-btn-secondary {
  background: #fffaf2;
  color: #211d18;
}

.page-schedule .ss-main .ss-btn-secondary:hover,
.page-schedule .ss-main .ss-btn-secondary:focus {
  color: #211d18;
  filter: brightness(0.98);
}

.page-schedule .ss-weekly-schedule {
  padding: clamp(2.25rem, 5vw, 4rem) 0;
  background: #f7f3ec;
}

.page-schedule .ss-section-head {
  max-width: 760px;
  margin-bottom: 1.5rem;
}

.page-schedule .ss-section-head h2 {
  margin: 0 0 0.5rem;
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: -0.03em;
  font-weight: 900;
  color: #211d18;
}

.page-schedule .ss-section-head p:last-child {
  margin: 0;
  color: #756b5f;
  font-size: 1.05rem;
}

.page-schedule .ss-schedule-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1rem;
}

/* Legacy .ss-day-card rules removed — see "Mobile Day Cards" section below */

@media (max-width: 991.98px) {
  .page-schedule .ss-schedule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 575.98px) {

  .page-schedule .ss-main,
  .page-schedule .ss-main>section {
    max-width: 100%;
    box-sizing: border-box;
  }

  .page-schedule .ss-main {
    padding-left: 0;
    padding-right: 0;
  }

  .page-schedule .ss-schedule-hero {
    overflow: hidden;
  }

  .page-schedule .ss-schedule-hero>.container {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: 0 !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    box-sizing: border-box;
  }

  .page-schedule .ss-schedule-hero__inner,
  .page-schedule .ss-time-row,
  .page-schedule .ss-hero-actions {
    min-width: 0;
    max-width: 100%;
  }

  .page-schedule .ss-time-row,
  .page-schedule .ss-hero-actions {
    position: relative;
    left: calc((100% - 100vw) / 2);
    width: 100%;
    max-width: 310px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-schedule .ss-schedule-hero h1 {
    max-width: 13ch;
    margin-left: auto;
    margin-right: auto;
    font-size: clamp(2.25rem, 12vw, 2.9rem);
    letter-spacing: -0.03em;
  }

  .page-schedule .ss-time-row,
  .page-schedule .ss-schedule-grid {
    grid-template-columns: 1fr;
  }

  .page-schedule .ss-first-day-proof {
    max-width: 28ch;
    margin-left: auto;
    margin-right: auto;
  }

  .page-schedule .ss-hero-actions {
    flex-direction: column;
  }

  .page-schedule .ss-hero-actions .ss-btn {
    width: 100%;
  }
}

/* Schedule card component refactor (scoped to /schedule) */
.page-schedule .ssched {
  --ssched-surface: #fffaf2;
  --ssched-surface-subtle: #efe8dc;
  --ssched-border: rgba(33, 29, 24, 0.12);
  --ssched-text: #211d18;
  --ssched-muted: #756b5f;
  --ssched-accent: #5f6f52;
  --ssched-focus: rgba(184, 138, 68, 0.34);
  --ssched-shadow: 0 14px 34px rgba(33, 29, 24, 0.08);
  --ssched-shadow-soft: 0 8px 20px rgba(33, 29, 24, 0.06);
  --ssched-radius: 18px;
}

.page-schedule .ssched .wrap {
  max-width: 1120px;
}

.page-schedule .ssched .schedule-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

.page-schedule .ssched .day-card {
  border: 1px solid var(--ssched-border);
  border-radius: var(--ssched-radius);
  background: var(--ssched-surface);
  box-shadow: var(--ssched-shadow-soft);
  overflow: hidden;
}

.page-schedule .ssched .day-card--saturday {
  border-color: rgba(15, 118, 110, 0.45);
  box-shadow: 0 16px 30px rgba(15, 118, 110, 0.14);
}

.page-schedule .ssched .day-card__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px;
  background: var(--ssched-surface-subtle);
  border-bottom: 1px solid var(--ssched-border);
}

.page-schedule .ssched .day-card__header h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 750;
}

.page-schedule .ssched .day-card__header .note {
  margin: 0;
  color: var(--ssched-muted);
  font-size: 0.85rem;
  font-weight: 600;
}

.page-schedule .ssched .day-card__slots {
  list-style: none;
  margin: 0;
  padding: 14px 16px;
  display: grid;
  gap: 10px;
}

.page-schedule .ssched .day-card .slot {
  margin: 0;
  border: 1px solid var(--ssched-border);
  border-radius: 12px;
  background: var(--ssched-surface);
  padding: 10px 12px;
}

.page-schedule .ssched .day-card .meta {
  display: grid;
  grid-template-columns: minmax(96px, 120px) 1fr auto;
  gap: 10px;
  align-items: baseline;
}

.page-schedule .ssched .day-card .time {
  font-weight: 800;
  color: var(--ssched-text);
}

.page-schedule .ssched .day-card .class {
  font-weight: 700;
  color: var(--ssched-text);
}

.page-schedule .ssched .day-card__cta {
  padding: 0 16px 16px;
}

.page-schedule .ssched .day-card__cta .cta {
  width: 100%;
}

.page-schedule .ssched .day-card__cta--stack {
  display: grid;
  gap: 8px;
}

.page-schedule .ssched .day-card .badge {
  font-size: 0.72rem;
  letter-spacing: 0.03em;
  border-radius: 999px;
  padding: 4px 8px;
}

.page-schedule .ssched .schedule-conversion {
  margin-top: 20px;
  padding: 20px 16px;
  border: 1px solid var(--ssched-border);
  border-radius: var(--ssched-radius);
  background: linear-gradient(180deg, var(--ssched-surface) 0%, var(--ssched-surface-subtle) 100%);
  box-shadow: var(--ssched-shadow);
}

.page-schedule .ssched .schedule-conversion__title {
  margin: 0 0 6px;
  font-size: 1.15rem;
}

.page-schedule .ssched .schedule-conversion__copy {
  margin: 0 auto 12px;
  max-width: 60ch;
  color: var(--ssched-muted);
}

.page-schedule .ssched .chip:focus-visible,
.page-schedule .ssched .cta:focus-visible {
  outline: 3px solid var(--ssched-focus);
  outline-offset: 2px;
}

@media (min-width: 700px) {
  .page-schedule .ssched .schedule-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1040px) {
  .page-schedule .ssched .schedule-card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }
}

@media (max-width: 520px) {
  .page-schedule .ssched .day-card .meta {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .page-schedule .ssched .day-card .badge {
    justify-self: start;
  }
}

.schedule-module {
  padding: 1.5rem 0;
}

.page-schedule .schedule-quick-path {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  border-color: rgba(33, 29, 24, 0.12);
  background: linear-gradient(180deg, rgba(255, 250, 242, 0.98), rgba(239, 232, 220, 0.94));
}

.page-schedule .schedule-quick-path__promise {
  margin: 0 0 0.65rem;
  font-weight: 700;
  color: rgba(15, 12, 8, 0.92);
}

.page-schedule .schedule-quick-path__table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 0.8rem;
  background: rgba(255, 250, 242, 0.8);
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 12px;
  overflow: hidden;
}

.page-schedule .schedule-quick-path__table th,
.page-schedule .schedule-quick-path__table td {
  padding: 0.5rem 0.62rem;
  border-bottom: 1px solid rgba(15, 12, 8, 0.1);
  font-size: 0.92rem;
}

.page-schedule .schedule-quick-path__table tr:last-child th,
.page-schedule .schedule-quick-path__table tr:last-child td {
  border-bottom: 0;
}

.page-schedule .schedule-quick-path__table th {
  width: 38%;
  font-weight: 700;
  color: rgba(15, 12, 8, 0.86);
}

.page-schedule .schedule-quick-path__table td {
  font-weight: 600;
  text-align: right;
  color: rgba(15, 12, 8, 0.92);
}

.page-schedule .schedule-quick-path__cta {
  width: 100%;
  margin: 0 0 0.55rem;
}

.page-schedule .schedule-quick-path__reassurance {
  margin: 0;
  line-height: 1.35;
}

.schedule-module__surface {
  background: linear-gradient(165deg, rgba(255, 250, 242, 0.95), rgba(239, 232, 220, 0.9));
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 20px;
  padding: 1.25rem;
  box-shadow: 0 20px 45px rgba(33, 29, 24, 0.08);
}

.schedule-module__eyebrow {
  margin: 0 0 0.35rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  font-size: 0.72rem;
  color: rgba(15, 12, 8, 0.6);
}

.schedule-module__title {
  margin: 0 0 0.45rem;
  font-size: clamp(1.35rem, 3.4vw, 2rem);
}

.schedule-module__subhead {
  margin: 0 0 1rem;
  color: rgba(15, 12, 8, 0.78);
}

.schedule-module__cta-row {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
  margin-bottom: 0.9rem;
}

.schedule-module__microcopy {
  list-style: none;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin: 0 0 1rem;
  padding: 0;
}

.schedule-module__microcopy li {
  font-size: 0.82rem;
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 999px;
  padding: 0.25rem 0.65rem;
  background: rgba(255, 250, 242, 0.8);
}

.schedule-module__poster {
  margin: 0;
}

.schedule-module__poster img {
  width: 100%;
  height: auto;
  border-radius: 14px;
  border: 1px solid rgba(15, 12, 8, 0.1);
}

.schedule-module__poster figcaption {
  font-size: 0.84rem;
  color: rgba(15, 12, 8, 0.72);
  margin-top: 0.5rem;
}

.schedule-module__table-wrap {
  overflow-x: auto;
  border: 1px solid rgba(15, 12, 8, 0.12);
  border-radius: 16px;
}

.schedule-module__table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
  background: #fffaf2;
}

.schedule-module__table th,
.schedule-module__table td {
  padding: 0.72rem 0.65rem;
  border-bottom: 1px solid rgba(15, 12, 8, 0.09);
  text-align: left;
  vertical-align: middle;
}

.schedule-module__table th {
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.76rem;
  color: rgba(15, 12, 8, 0.72);
  background: rgba(15, 12, 8, 0.03);
}

.schedule-module__actions {
  white-space: nowrap;
}

.schedule-module__actions a {
  display: inline-block;
  margin-right: 0.55rem;
  font-weight: 700;
  text-decoration: none;
}

.schedule-module__action-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.schedule-module__showup {
  margin-top: 1rem;
  border-radius: 14px;
  border: 1px solid rgba(15, 12, 8, 0.1);
  background: rgba(15, 12, 8, 0.03);
  padding: 0.95rem 1rem;
}

.schedule-module__showup h3 {
  margin: 0 0 0.45rem;
  font-size: 1.05rem;
}

.schedule-module__showup ul {
  margin: 0;
  padding-left: 1rem;
}

.schedule-module__cta-row--bottom {
  margin-top: 0.95rem;
  margin-bottom: 0;
}

.schedule-mobile-sticky {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1030;
  padding: 0.6rem 0.8rem calc(0.6rem + env(safe-area-inset-bottom));
  background: rgba(255, 250, 242, 0.97);
  border-top: 1px solid rgba(33, 29, 24, 0.12);
  display: none;
  grid-template-columns: 1fr auto;
  gap: 0.6rem;
  align-items: center;
}

.schedule-mobile-sticky__book {
  width: 100%;
}

.schedule-mobile-sticky__text {
  font-weight: 700;
  text-decoration: none;
}

@media (max-width: 991.98px) {
  .schedule-mobile-sticky {
    display: grid;
  }

  .page-schedule .cta-footer-block {
    margin-bottom: 5.4rem;
  }
}

@media (max-width: 767.98px) {
  .page-schedule .schedule-quick-path {
    margin-top: 0.75rem !important;
    padding: 0.82rem !important;
  }

  .page-schedule .schedule-quick-path__promise {
    font-size: 0.92rem;
    margin-bottom: 0.55rem;
  }

  .page-schedule .schedule-quick-path__table {
    margin-bottom: 0.62rem;
  }

  .page-schedule .schedule-quick-path__table th,
  .page-schedule .schedule-quick-path__table td {
    padding: 0.42rem 0.52rem;
    font-size: 0.86rem;
  }

  .page-schedule .schedule-quick-path__cta {
    margin-bottom: 0.45rem;
    min-height: 48px;
    font-size: 0.94rem;
  }

  .page-schedule .schedule-quick-path__reassurance {
    font-size: 0.8rem;
  }
}

@media (max-width: 640px) {
  .schedule-module__cta-row .btn {
    width: 100%;
  }
}

@media (max-width: 767.98px) {
  .schedule-module__table-wrap {
    overflow: visible;
    border: 0;
    background: transparent;
  }

  .schedule-module__table {
    min-width: 0;
    border-collapse: separate;
    border-spacing: 0 0.65rem;
    background: transparent;
  }

  .schedule-module__table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
  }

  .schedule-module__table tbody tr[data-schedule-table-row] {
    display: block;
    border: 1px solid rgba(33, 29, 24, 0.14);
    border-radius: 14px;
    background: #fffaf2;
    box-shadow: 0 10px 24px rgba(33, 29, 24, 0.09);
    overflow: hidden;
  }

  .schedule-module__table tbody tr[data-schedule-table-row] td {
    display: block;
    padding: 0.6rem 0.82rem;
    border-bottom: 1px solid rgba(15, 12, 8, 0.08);
  }

  .schedule-module__table tbody tr[data-schedule-table-row] td:last-child {
    border-bottom: 0;
  }

  .schedule-module__table tbody tr[data-schedule-table-row] td:nth-child(1) {
    font-weight: 750;
    font-size: 0.95rem;
  }

  .schedule-module__table tbody tr[data-schedule-table-row] td:nth-child(2),
  .schedule-module__table tbody tr[data-schedule-table-row] td:nth-child(3) {
    font-size: 0.92rem;
    color: rgba(15, 12, 8, 0.86);
  }

  .schedule-module__actions {
    white-space: normal;
    padding-top: 0.75rem !important;
  }

  .schedule-module__actions a {
    margin-right: 0;
  }

  .schedule-module__action-book {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 48px;
    padding: 0.68rem 0.92rem;
    border-radius: 10px;
    background: var(--button-color);
    color: var(--button-text) !important;
    border: 1px solid var(--button-color);
    font-size: 0.97rem;
    font-weight: 800;
    text-decoration: none;
  }

  .schedule-module__action-secondary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    margin-top: 0.5rem;
  }

  .schedule-module__action-secondary a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    border-radius: 9px;
    border: 1px solid rgba(15, 12, 8, 0.18);
    color: rgba(15, 12, 8, 0.9);
    background: rgba(15, 12, 8, 0.03);
    font-size: 0.84rem;
    font-weight: 700;
    text-decoration: none;
  }
}

.page-schedule .schedule-shell {
  max-width: 1100px;
  padding-top: 2rem;
  padding-bottom: 3rem;
}

.page-schedule .schedule-panel {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 24px;
  padding: 1.25rem;
  margin-bottom: 1rem;
  background:
    radial-gradient(720px 220px at 20% 0%, rgba(17, 106, 66, 0.2), transparent 60%),
    linear-gradient(180deg, rgba(7, 10, 14, 0.88), rgba(11, 14, 20, 0.94));
  color: #f2f5f8;
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.28);
}

.page-schedule .schedule-panel h1,
.page-schedule .schedule-panel h2,
.page-schedule .schedule-panel h3 {
  color: #f4f8fc !important;
}

.page-schedule .schedule-panel p,
.page-schedule .schedule-panel li {
  color: rgba(230, 236, 243, 0.95) !important;
}

.page-schedule .schedule-panel strong {
  color: #ffffff !important;
}

.page-schedule .schedule-panel a {
  color: #55e4e7 !important;
  text-decoration-color: rgba(85, 228, 231, 0.7);
}

.page-schedule .schedule-panel a:hover,
.page-schedule .schedule-panel a:focus-visible {
  color: #8ff6f7 !important;
  text-decoration-color: #8ff6f7;
}

.page-schedule .schedule-panel .text-muted {
  color: rgba(222, 227, 233, 0.82) !important;
}

.page-schedule .schedule-eyebrow {
  letter-spacing: 0.16em;
  color: #289FA1;
}

.page-schedule .schedule-lede {
  max-width: 820px;
}

.page-schedule .schedule-chip-row {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.page-schedule .schedule-chip {
  display: inline-flex;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(17, 106, 66, 0.5);
  background: rgba(17, 106, 66, 0.14);
  color: #f8fbff !important;
  font-weight: 700;
  font-size: 0.9rem;
}

.page-schedule .schedule-hero-actions .btn {
  min-height: 48px;
}

.page-schedule .schedule-hero-lanes {
  margin-top: 1rem;
  display: grid;
  gap: 0.8rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.page-schedule .schedule-hero-lanes article {
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(19, 23, 31, 0.7);
  padding: 0.75rem;
}

.page-schedule .schedule-hero-lanes h2 {
  font-size: 0.92rem;
  margin: 0 0 0.2rem;
  color: #f8fafc;
}

.page-schedule .schedule-hero-lanes p {
  margin: 0;
  color: rgba(220, 227, 234, 0.82);
  font-size: 0.84rem;
}

.page-schedule .schedule-hero-lanes article p {
  color: rgba(229, 236, 243, 0.93) !important;
}

.page-schedule .lane-card {
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(15, 19, 26, 0.72);
  color: #edf2f7;
}

.page-schedule #lane-picker .lane-card__header {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.page-schedule .lane-card h2,
.page-schedule .lane-card h3,
.page-schedule .lane-card h4,
.page-schedule .lane-card h5,
.page-schedule .lane-card p,
.page-schedule .lane-card li,
.page-schedule .lane-card summary {
  color: rgba(234, 240, 246, 0.96) !important;
}

.page-schedule .schedule-mini-details {
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.13);
  background: rgba(10, 14, 20, 0.58);
  padding: 0.6rem 0.75rem;
}

.page-schedule .schedule-mini-details p,
.page-schedule .schedule-mini-details li,
.page-schedule .schedule-mini-details summary {
  color: rgba(234, 240, 246, 0.96) !important;
}

.page-schedule #lane-picker .lane-card__micro {
  color: rgba(229, 236, 243, 0.95) !important;
}

.page-schedule .schedule-mini-details summary,
.page-schedule .schedule-accordion-group details>summary {
  cursor: pointer;
  font-weight: 700;
}

.page-schedule .schedule-details summary {
  list-style: none;
}

.page-schedule .schedule-details summary::-webkit-details-marker {
  display: none;
}

.page-schedule .schedule-details__body {
  margin-top: 1rem;
}

.page-schedule .schedule-accordion-group {
  display: grid;
  gap: 0.55rem;
}

.page-schedule .schedule-accordion-group details {
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(12, 16, 22, 0.62);
  padding: 0.65rem 0.85rem;
}

.page-schedule .schedule-accordion-group details[open] {
  border-color: rgba(17, 106, 66, 0.65);
}

.page-schedule .schedule-panel .cta,
.page-schedule .schedule-panel .btn-primary {
  background: #116A42;
  border-color: #116A42;
}

.page-schedule .schedule-panel .btn-outline-primary {
  border-color: rgba(17, 106, 66, 0.58);
  color: #f4f7fa;
}

.page-schedule .schedule-panel .btn-outline-primary:hover {
  background: rgba(17, 106, 66, 0.2);
  color: #fff;
}

.page-schedule .schedule-help-card {
  max-width: 1100px;
  margin: 2rem auto;
  padding: 1.5rem;
  border-radius: 1.25rem;
  background: #f6fbfb;
  border: 1px solid rgba(40, 159, 161, 0.22);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.06);
}

.page-schedule .schedule-help-card .eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #289FA1;
}

.page-schedule .schedule-help-card h2 {
  margin: 0 0 0.75rem;
}

.page-schedule .schedule-help-card p {
  max-width: 42rem;
  margin-bottom: 1rem;
}

@media (max-width: 991.98px) {
  .page-schedule .schedule-hero-lanes {
    grid-template-columns: 1fr;
  }
}

/* Mobile app-style schedule shell */
.page-schedule .schedule-mobile-app {
  display: none;
}

@media (max-width: 991.98px) {
  .page-schedule .schedule-shell {
    max-width: 760px;
    padding-top: 1rem;
    padding-bottom: 7.5rem;
  }

  .page-schedule .schedule-mobile-app {
    display: block;
  }

  .page-schedule .schedule-mobile-app__header {
    border: 1px solid rgba(255, 139, 61, 0.28);
    border-radius: 20px;
    padding: 1rem;
    margin-bottom: 0.9rem;
    background:
      radial-gradient(460px 160px at 5% 0%, rgba(17, 106, 66, 0.24), transparent 70%),
      linear-gradient(180deg, rgba(8, 12, 18, 0.93), rgba(12, 16, 22, 0.96));
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.24);
  }

  .page-schedule .schedule-mobile-app__eyebrow {
    margin: 0 0 0.3rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: #289FA1;
    font-size: 0.75rem;
    font-weight: 700;
  }

  .page-schedule .schedule-mobile-app__header h1 {
    margin: 0;
    font-size: 1.5rem;
    color: #f8fafc;
    font-weight: 750;
  }

  .page-schedule .schedule-mobile-app__header p {
    margin: 0.55rem 0 0;
    color: rgba(226, 233, 239, 0.88);
    font-size: 0.96rem;
  }

  .page-schedule .schedule-mobile-app__days {
    position: sticky;
    top: 68px;
    z-index: 30;
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    padding: 0.6rem 0 0.2rem;
    margin-bottom: 0.8rem;
    scrollbar-width: none;
    background: linear-gradient(180deg, rgba(10, 14, 20, 0.97), rgba(10, 14, 20, 0.8));
  }

  .page-schedule .schedule-mobile-app__days::-webkit-scrollbar {
    display: none;
  }

  .page-schedule .schedule-mobile-app__days span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 62px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(237, 242, 247, 0.92);
    padding: 0.4rem 0.7rem;
    font-size: 0.8rem;
    font-weight: 700;
  }

  .page-schedule .schedule-mobile-app__days span.is-active {
    border-color: rgba(17, 106, 66, 0.68);
    background: rgba(17, 106, 66, 0.2);
    color: #fff;
  }

  .page-schedule .schedule-mobile-app__filters {
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    padding-bottom: 0.2rem;
    margin-bottom: 0.85rem;
    scrollbar-width: none;
  }

  .page-schedule .schedule-mobile-app__filters::-webkit-scrollbar {
    display: none;
  }

  .page-schedule .schedule-mobile-app__filters a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 999px;
    padding: 0.42rem 0.82rem;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(237, 242, 247, 0.92);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 700;
  }

  .page-schedule .schedule-mobile-app__filters a.is-active {
    border-color: rgba(17, 106, 66, 0.74);
    background: rgba(17, 106, 66, 0.22);
    color: #fff;
  }

  .page-schedule .schedule-mobile-app__list h2 {
    margin: 0 0 0.7rem;
    font-size: 1.2rem;
    color: #f8fafc;
  }

  .page-schedule .schedule-mobile-card {
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 18px;
    background: rgba(11, 15, 22, 0.88);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
    padding: 0.85rem;
    margin-bottom: 0.75rem;
  }

  .page-schedule .schedule-mobile-card__head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.7rem;
    margin-bottom: 0.6rem;
  }

  .page-schedule .schedule-mobile-card__head h3 {
    margin: 0;
    font-size: 1rem;
    color: #f8fafc;
  }

  .page-schedule .schedule-mobile-card__head span {
    color: rgba(215, 224, 231, 0.8);
    font-size: 0.78rem;
  }

  .page-schedule .schedule-mobile-card ul {
    margin: 0 0 0.75rem;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.45rem;
  }

  .page-schedule .schedule-mobile-slot {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.18rem;
    border-left: 3px solid rgba(17, 106, 66, 0.7);
    padding: 0.35rem 0 0.35rem 0.62rem;
  }

  .page-schedule .schedule-mobile-slot .time {
    color: #289FA1;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.01em;
  }

  .page-schedule .schedule-mobile-slot .title {
    color: #eff4f8;
    font-size: 0.95rem;
    font-weight: 700;
  }

  .page-schedule .schedule-mobile-slot .tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: max-content;
    margin-top: 0.1rem;
    border-radius: 999px;
    padding: 0.12rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }

  .page-schedule .schedule-mobile-slot .tag--gi {
    background: rgba(17, 106, 66, 0.2);
    color: #82e2b9;
  }

  .page-schedule .schedule-mobile-slot .tag--nogi {
    background: rgba(148, 163, 184, 0.24);
    color: #d5dee8;
  }

  .page-schedule .schedule-mobile-slot .tag--mix {
    background: rgba(45, 212, 191, 0.2);
    color: #8df3e4;
  }

  .page-schedule .schedule-mobile-slot .tag--bio {
    background: rgba(129, 140, 248, 0.2);
    color: #b7c0ff;
  }

  .page-schedule .schedule-mobile-card>.btn,
  .page-schedule .schedule-mobile-card__stack .btn {
    width: 100%;
    min-height: 46px;
    font-weight: 750;
  }

  .page-schedule .schedule-mobile-card__stack {
    display: grid;
    gap: 0.45rem;
  }

  .page-schedule .schedule-mobile-guide {
    margin-top: 0.9rem;
    border: 1px solid rgba(17, 106, 66, 0.24);
    border-radius: 18px;
    padding: 0.95rem;
    background:
      radial-gradient(400px 140px at 15% 0%, rgba(17, 106, 66, 0.18), transparent 70%),
      rgba(10, 14, 20, 0.86);
  }

  .page-schedule .schedule-mobile-guide h2 {
    margin: 0 0 0.7rem;
    font-size: 1.1rem;
    color: #f8fafc;
  }

  .page-schedule .schedule-mobile-guide ol {
    margin: 0 0 0.9rem;
    padding-left: 1.1rem;
    color: rgba(225, 233, 239, 0.92);
    display: grid;
    gap: 0.45rem;
  }

  .page-schedule .schedule-mobile-guide li {
    font-size: 0.9rem;
  }

  .page-schedule .schedule-mobile-guide li strong {
    color: #fff;
  }

  .page-schedule .schedule-mobile-sticky-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: calc(68px + env(safe-area-inset-bottom));
    z-index: 65;
    padding: 0.55rem 0.8rem 0.7rem;
    background: linear-gradient(180deg, rgba(10, 14, 20, 0), rgba(10, 14, 20, 0.94) 36%);
  }
}

/* =========================================================
   Sensei Sandy Mobile Nav Click Fix (Nuclear Edition)
   Fixes mobile dropdown links becoming unclickable
   ========================================================= */
@media (max-width: 991.98px) {

  .navbar,
  .site-header,
  .ss-header,
  .ss-nav,
  .ss-nav--glass,
  .ss-header--glass {
    z-index: 99999 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    overflow: visible !important;
    contain: none !important;
  }

  .navbar .navbar-collapse.show,
  .navbar .navbar-collapse.collapsing,
  .ss-nav .navbar-collapse.show,
  .ss-nav .navbar-collapse.collapsing,
  .ss-mobile-menu.show,
  .ss-mobile-menu.is-open {
    position: absolute !important;
    top: 100% !important;
    left: 0;
    right: 0;
    background: #fffaf2 !important;
    border-bottom: 1px solid rgba(33, 29, 24, 0.12) !important;
    box-shadow: 0 16px 30px rgba(33, 29, 24, 0.12) !important;
    z-index: 100000 !important;
    pointer-events: auto !important;
    transform: none !important;
    clip-path: none !important;
  }

  .navbar-collapse a,
  .ss-mobile-menu a,
  .nav-link,
  .dropdown-item {
    position: relative !important;
    z-index: 100001 !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }

  .ss-mobile-actions,
  .mobile-sticky-cta,
  .ss-sticky-mobile-bar,
  .bottom-action-bar,
  .mobile-bottom-bar,
  .cta-bar {
    z-index: 90000 !important;
  }
}

/* --- Conversion Optimization Upgrades 2026-05-12 --- */
.ss-best-first-visit {
  background:
    radial-gradient(circle at top left, rgba(17, 106, 66, 0.10), transparent 32rem),
    #FBFAF8;
}

.ss-visit-card,
.ss-card {
  padding: 1.25rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: #FFFFFF;
  box-shadow: 0 10px 30px rgba(54, 43, 36, 0.06);
}

.ss-featured {
  border: 2px solid #116A42;
}

.ss-badge {
  display: inline-flex;
  padding: .35rem .65rem;
  border-radius: 999px;
  background: rgba(17, 106, 66, 0.10);
  color: #116A42;
  font-size: .75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.ss-proof-pill {
  padding: .9rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: #FFFFFF;
  font-weight: 800;
  color: #1F1712;
}

.ss-saturday-block {
  background:
    radial-gradient(circle at bottom right, rgba(40, 159, 161, 0.12), transparent 30rem),
    #FBFAF8;
}

.ss-checklist {
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
}

.ss-checklist li {
  position: relative;
  padding-left: 1.75rem;
  margin-bottom: .55rem;
}

.ss-checklist li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: #116A42;
  font-weight: 900;
}

/* Schedule page centering */
.page-schedule #lane-picker,
.page-schedule #locations,
.page-schedule #pricing {
  text-align: center;
}

.page-schedule #lane-picker p,
.page-schedule #locations p,
.page-schedule #pricing p {
  margin-left: auto;
  margin-right: auto;
}

.page-schedule #lane-picker .row,
.page-schedule #locations .location-cards {
  justify-content: center;
}

.page-schedule #lane-picker ul {
  list-style: none;
  padding-left: 0;
  margin-left: auto;
  margin-right: auto;
}

.page-schedule #micro-faq {
  text-align: center;
}

.page-schedule #micro-faq details {
  margin-left: auto;
  margin-right: auto;
  max-width: 720px;
  text-align: center;
}

.page-schedule #micro-faq summary {
  text-align: center;
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.page-schedule #micro-faq summary::marker {
  content: "";
}

.page-schedule #micro-faq p {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* Schedule page extracted styles (migrated from schedule.html inline CSS) */
.page-schedule .schedule-center-stack {
  text-align: center;
}

.page-schedule .schedule-center-stack h1,
.page-schedule .schedule-center-stack p {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.page-schedule .schedule-center-stack .lead {
  max-width: 36ch;
}

.page-schedule .schedule-center-stack .ss-kicker {
  max-width: 46ch;
}

.page-schedule .schedule-center-stack .small {
  max-width: 54ch;
}

.page-schedule .schedule-reassurance {
  max-width: 720px;
  text-align: center;
}

.page-schedule .schedule-reassurance p {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  max-width: 58ch;
}

.page-schedule #book .ss-book__eyebrow {
  display: block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* =========================
   8) SCHEDULE HERO FIXES
   Restored from schedule.css
========================= */
/* Schedule Hero Styles extracted from schedule.css */

.page-schedule .ss-schedule-hero {
  background:
    radial-gradient(900px 320px at 12% 0%, rgba(40, 159, 161, 0.16), transparent 58%),
    linear-gradient(180deg, #fffaf2 0%, #efe8dc 100%);
  color: #1f1712;
  padding: clamp(3rem, 7vw, 5.5rem) 0 clamp(2.25rem, 5vw, 4rem);
}

.page-schedule .ss-schedule-hero__inner {
  max-width: 960px;
}

.page-schedule .ss-eyebrow {
  margin: 0 0 0.75rem;
  color: var(--ss-cyan, #00dde0);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.82rem;
}

.page-schedule .ss-schedule-hero h1 {
  max-width: 850px;
  margin: 0;
  font-size: clamp(2.25rem, 6vw, 4.75rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
  font-weight: 900;
}

.page-schedule .ss-hero-lede {
  margin: 1rem 0 1.5rem;
  max-width: 620px;
  font-size: clamp(1.2rem, 2.5vw, 1.65rem);
  line-height: 1.35;
  color: #4f433c;
}

.page-schedule .ss-time-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
  margin: 1.5rem 0;
  max-width: 760px;
}

.page-schedule .ss-time-card {
  display: block;
  padding: 1rem;
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 1rem;
  background: rgba(255, 250, 242, 0.94);
  color: #211d18;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(33, 29, 24, 0.09);
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.page-schedule .ss-time-card:hover,
.page-schedule .ss-time-card:focus {
  transform: translateY(-2px);
  background: #fffaf2;
  border-color: rgba(95, 111, 82, 0.32);
  color: #211d18;
  box-shadow: 0 16px 34px rgba(33, 29, 24, 0.12);
}

.page-schedule .ss-time-card strong {
  display: block;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1;
  font-weight: 900;
  color: #211d18;
}

.page-schedule .ss-time-card span {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.98rem;
  color: #756b5f;
}

.page-schedule .ss-first-day-proof {
  margin: 1.25rem 0;
  font-weight: 800;
  font-size: 1.05rem;
  color: #211d18;
}

.page-schedule .ss-schedule-hero .ss-safety-strip {
  display: block;
  margin: 1.5rem 0 0;
  padding-block: 1.5rem !important;
}

.page-schedule .ss-schedule-hero .ss-safety-strip>.container {
  width: 100%;
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

.page-schedule .ss-schedule-hero .ss-safety-strip .row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  gap: 0.85rem;
  margin-left: 0;
  margin-right: 0;
}

.page-schedule .ss-schedule-hero .ss-safety-strip .row>[class*="col-"] {
  width: auto;
  padding-left: 0;
  padding-right: 0;
}

.page-schedule .ss-schedule-hero .ss-proof-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3.5rem;
  width: 100%;
  height: 100%;
  text-align: center;
  white-space: normal;
  writing-mode: horizontal-tb;
  text-orientation: mixed;
}

.page-schedule .ss-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.4rem;
}

.page-schedule .ss-main .ss-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.85rem 1.15rem;
  border-radius: 999px;
  font-weight: 900;
  text-decoration: none;
  line-height: 1;
}

.page-schedule .ss-main .ss-btn-primary {
  background: var(--ss-green, #116A42);
  color: #fff;
}

.page-schedule .ss-main .ss-btn-primary:hover,
.page-schedule .ss-main .ss-btn-primary:focus {
  color: #fff;
  filter: brightness(1.05);
}

.page-schedule .ss-main .ss-btn-secondary {
  background: #fffaf2;
  color: #211d18;
}

.page-schedule .ss-main .ss-btn-secondary:hover,
.page-schedule .ss-main .ss-btn-secondary:focus {
  color: #211d18;
  filter: brightness(0.98);
}

.ss-proof-pill {
  padding: .9rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: #fffaf2;
  font-weight: 800;
  color: #1F1712;
}

@media (max-width: 575.98px) {
  .page-schedule .ss-schedule-hero {
    overflow: hidden;
  }

  .page-schedule .ss-schedule-hero>.container {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: 0 !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    box-sizing: border-box;
  }

  .page-schedule .ss-schedule-hero__inner,
  .page-schedule .ss-time-row,
  .page-schedule .ss-hero-actions {
    min-width: 0;
    max-width: 100%;
  }

  .page-schedule .ss-time-row,
  .page-schedule .ss-hero-actions {
    position: relative;
    left: calc((100% - 100vw) / 2);
    width: 100%;
    max-width: 310px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-schedule .ss-schedule-hero h1 {
    max-width: 13ch;
    margin-left: auto;
    margin-right: auto;
    font-size: clamp(2.25rem, 12vw, 2.9rem);
    letter-spacing: -0.03em;
  }

  .page-schedule .ss-time-row {
    grid-template-columns: 1fr;
  }

  .page-schedule .ss-first-day-proof {
    max-width: 28ch;
    margin-left: auto;
    margin-right: auto;
  }

  .page-schedule .ss-hero-actions {
    flex-direction: column;
  }

  .page-schedule .ss-hero-actions .ss-btn {
    width: 100%;
  }

  .page-schedule .ss-schedule-hero .ss-safety-strip {
    width: 100%;
    max-width: 310px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-schedule .ss-schedule-hero .ss-safety-strip .row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
  }
}

/* Links Section Styling */
.ss-links {
  margin: 2rem 0;
  padding: 1.25rem;
  border: 1px solid rgba(54, 43, 36, 0.14);
  border-radius: 1rem;
  background: #FBFAF8;
}

.ss-links h2 {
  margin: 0 0 .75rem;
  color: #362B24;
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.15;
}

.ss-links ul {
  margin: 0;
  padding-left: 1.15rem;
}

.ss-links li+li {
  margin-top: .55rem;
}

.ss-links a {
  color: #306061;
  font-weight: 700;
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}

.ss-links a:hover,
.ss-links a:focus-visible {
  color: #116A42;
}

.page-bjj-glossary .learning-path-card,
.page-bjj-glossary .path-card,
.page-bjj-glossary .cta-card,
.page-bjj-glossary .intro-card,
.page-bjj-glossary .ready-card,
.page-bjj-glossary .quick-start-card,
.page-bjj-glossary .filter-panel .card,
.page-bjj-glossary .map-card {
  background: var(--ss-surface) !important;
  color: var(--ss-ink) !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

/* --- Schedule Page CRO Overhaul 2026-05-15 --- */

/* 1. Global / Utilities */
body.page-schedule .ss-mobile-actions {
  display: none !important;
}

/* 2. Desktop CRO Fixes */
.ss-schedule-desktop-hero {
  padding: clamp(4rem, 8vw, 7rem) 0 3rem;
  background:
    radial-gradient(circle at top left, rgba(17, 106, 66, .12), transparent 34rem),
    var(--ss-bg, #f7f3ec);
}

.ss-schedule-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, .85fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

.ss-schedule-hero-copy h1 {
  font-size: clamp(3.25rem, 7vw, 6.25rem);
  line-height: .9;
  letter-spacing: -0.06em;
  max-width: 9ch;
  margin-bottom: 1rem;
}

.ss-lead {
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  line-height: 1.5;
  color: var(--ss-muted, #4f433c);
  max-width: 62ch;
}

.ss-hero-actions,
.ss-head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.25rem;
}

.page-schedule .ss-main .ss-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 999px;
  padding: .85rem 1.15rem;
  font-weight: 900;
  text-decoration: none;
}

.page-schedule .ss-main .ss-btn-primary {
  background: var(--ss-green, #116A42);
  color: #fff;
}

.page-schedule .ss-main .ss-btn-secondary {
  background: var(--ss-surface, #fff);
  color: var(--ss-ink, #1f1712);
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
}

.ss-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  padding: 0;
  margin: 1.5rem 0 0;
  list-style: none;
}

.ss-trust-row li {
  background: var(--ss-surface, #fffaf2);
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  border-radius: 999px;
  padding: .55rem .8rem;
  font-weight: 800;
  color: var(--ss-ink, #1f1712);
}

.ss-first-visit-planner {
  background: var(--ss-surface, #fffaf2);
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  border-radius: 1.5rem;
  padding: 1.5rem;
  box-shadow: 0 20px 50px rgba(54, 43, 36, .12);
}

.ss-first-visit-planner h2 {
  font-size: 2rem;
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: 1rem;
}

.ss-planner-option {
  border-top: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  padding: 1rem 0;
}

.ss-planner-option span {
  display: block;
  color: var(--ss-green, #116A42);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .78rem;
  margin-bottom: .25rem;
}

.ss-planner-option strong {
  display: block;
  font-size: 1.05rem;
  margin-bottom: .7rem;
}

.ss-planner-option a {
  display: inline-flex;
  color: var(--ss-green, #116A42);
  font-weight: 900;
  text-decoration: none;
}

.ss-section {
  padding: clamp(3rem, 6vw, 5.5rem) 0;
}

.ss-section-head {
  max-width: 760px;
  margin-bottom: 1.75rem;
}

.ss-section-head h2 {
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: .98;
  letter-spacing: -0.05em;
}

.ss-split-head {
  max-width: none;
  display: flex;
  justify-content: space-between;
  gap: 2rem;
  align-items: end;
}

.ss-lane-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.ss-lane-grid>* {
  min-width: 0;
}

.ss-lane-grid--primary {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ss-lane-card,
.ss-info-card,
.ss-proof-card,
.ss-contact-card,
.ss-price-card {
  background: var(--ss-surface, #fff);
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  border-radius: 1.25rem;
  padding: 1.25rem;
  box-shadow: 0 12px 32px rgba(54, 43, 36, .08);
}

.ss-feature-card {
  border-color: rgba(17, 106, 66, .35);
  box-shadow: 0 18px 44px rgba(17, 106, 66, .12);
}

.ss-card-label,
.ss-eyebrow {
  color: var(--ss-green, #116A42);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .78rem;
}

.ss-lane-card h3 {
  font-size: 1.35rem;
  margin-bottom: .5rem;
}

.ss-lane-card p {
  color: var(--ss-muted, #4f433c);
  min-height: 5rem;
}

.ss-lane-card a,
.ss-contact-card a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border-radius: 999px;
  padding: .7rem 1rem;
  background: var(--ss-green, #116A42);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  text-align: center;
  white-space: normal;
}

.ss-schedule-table {
  display: grid;
  border: 1px solid var(--ss-border, rgba(33, 29, 24, 0.12));
  border-radius: 1.25rem;
  overflow: hidden;
  background: var(--ss-surface, #fffaf2);
  box-shadow: 0 12px 32px rgba(33, 29, 24, .08);
}

.schedule-grid {
  display: none;
}

.schedule-day-cards {
  display: grid;
  gap: 1rem;
}

@media (min-width: 768px) {
  .schedule-grid {
    display: grid;
  }

  .schedule-day-cards {
    display: none;
  }
}

/* ── Mobile Day Cards ── */
.schedule-day-cards .ss-day-card {
  display: flex;
  flex-direction: column;
  padding: 1.25rem;
  border: 1px solid rgba(33, 29, 24, 0.12);
  border-radius: 1.15rem;
  background: #fffaf2;
  box-shadow: 0 8px 24px rgba(33, 29, 24, 0.07);
}

.ss-day-card__day {
  margin: 0 0 .75rem;
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #211d18;
}

.ss-day-card__times {
  list-style: none;
  margin: 0 0 .85rem;
  padding: 0;
}

.ss-day-card__times li {
  padding: .5rem 0;
  border-bottom: 1px solid rgba(33, 29, 24, 0.08);
  font-size: 1.05rem;
  color: #756b5f;
}

.ss-day-card__times li:last-child {
  border-bottom: 0;
}

.ss-day-card__times strong {
  font-weight: 900;
  color: #062f35;
  margin-right: .35rem;
}

.ss-day-card__best {
  margin: 0 0 1rem;
  font-size: .92rem;
  font-weight: 700;
  color: var(--ss-teal, #289fa1);
  font-style: italic;
}

.ss-day-card__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: .85rem 1rem;
  border-radius: 999px;
  background: var(--ss-green, #116A42);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  text-align: center;
  transition: filter 160ms ease, transform 160ms ease;
  margin-top: auto;
}

.ss-day-card__cta:hover,
.ss-day-card__cta:focus {
  filter: brightness(1.08);
  color: #fff;
}

.ss-day-card__cta:active {
  transform: translateY(1px);
}

/* Saturday special card */
.ss-day-card--saturday {
  border-color: rgba(95, 111, 82, 0.28);
  background: linear-gradient(180deg, #fffaf2 0%, #efe8dc 100%);
  box-shadow: 0 10px 28px rgba(95, 111, 82, 0.12);
}

.ss-day-card__badge {
  display: inline-block;
  margin-bottom: .75rem;
  padding: .3rem .75rem;
  border-radius: 999px;
  background: rgba(95, 111, 82, 0.12);
  color: var(--ss-teal, #5f6f52);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  width: fit-content;
}

.ss-schedule-row {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr 1fr 1.3fr;
  min-height: 72px;
  border-top: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
}

.ss-schedule-row:first-child {
  border-top: 0;
}

.ss-schedule-row>div {
  padding: 1rem;
  border-left: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.ss-schedule-row>div:first-child {
  border-left: 0;
}

.ss-schedule-header {
  min-height: 52px;
  background: var(--ss-surface2, #f7f2ed);
  font-weight: 900;
  color: var(--ss-ink, #1f1712);
}

.ss-schedule-row strong {
  font-size: 1.05rem;
}

.ss-schedule-row span {
  color: var(--ss-muted, #4f433c);
  font-size: .9rem;
}

.ss-saturday-row {
  background: rgba(40, 159, 161, .06);
}

.ss-schedule-action-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding: 1rem;
  background: var(--ss-ink, #1f1712);
  color: #fff;
  border-radius: 1.25rem;
}

.ss-schedule-action-strip p {
  margin: 0;
  font-weight: 800;
  color: #fff;
}

.ss-schedule-action-strip a {
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, .3);
  border-radius: 999px;
  padding: .65rem .9rem;
}

.ss-saturday-grid,
.ss-location-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 1.5rem;
  align-items: center;
}

.ss-pricing-preview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(380px, 1.35fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

.ss-price-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

.ss-price-card {
  padding: 1.75rem 1.5rem !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 200px;
}

.ss-check-list {
  padding: 0;
  margin: 1rem 0;
  list-style: none;
}

.ss-check-list li {
  padding: .6rem 0;
  border-bottom: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  font-weight: 800;
}

.ss-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.ss-price {
  font-size: 2.75rem;
  line-height: 1;
  letter-spacing: -0.05em;
  font-weight: 950;
  color: var(--ss-green, #116A42);
  margin: .85rem 0;
}

@media (max-width: 991.98px) {

  .ss-schedule-hero-grid,
  .ss-saturday-grid,
  .ss-pricing-preview-grid,
  .ss-location-grid {
    grid-template-columns: 1fr;
  }

  .ss-lane-grid,
  .ss-info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ss-lane-grid--primary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ss-split-head,
  .ss-schedule-action-strip {
    align-items: start;
    flex-direction: column;
  }
}

/* 3. Mobile CRO Fixes */
@media (max-width: 767.98px) {
  body.page-schedule {
    padding-bottom: 82px;
    overflow-x: hidden;
  }

  .page-schedule .container {
    width: 100%;
    max-width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .page-schedule .ss-lane-card,
  .page-schedule .ss-day-card {
    max-width: 100%;
    box-sizing: border-box;
    overflow-wrap: anywhere;
  }

  .ss-schedule-hero {
    padding: 2rem 1rem 1.25rem;
  }

  .ss-schedule-hero h1 {
    font-size: clamp(2rem, 10vw, 3rem);
    line-height: .98;
    letter-spacing: -0.04em;
    margin-bottom: .75rem;
  }

  .ss-lead {
    font-size: 1.05rem;
    line-height: 1.45;
    color: var(--ss-muted, #4f433c);
    margin-bottom: 1rem;
  }

  .ss-mobile-hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: .65rem;
    margin: 1rem 0;
  }

  .ss-trust-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
    padding: 0;
    margin: 1rem 0 0;
    list-style: none;
  }

  .ss-trust-list li {
    background: var(--ss-surface, #fff);
    border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
    border-radius: .85rem;
    padding: .7rem;
    font-size: .9rem;
    font-weight: 800;
  }

  .ss-mobile-lanes,
  .ss-week-mobile {
    padding: 1.5rem 1rem;
  }

  .ss-mobile-lanes h2,
  .ss-week-mobile h2 {
    font-size: 1.75rem;
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin-bottom: 1rem;
  }

  .ss-lane-card {
    background: var(--ss-surface, #fff);
    border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
    border-radius: 1.15rem;
    padding: 1rem;
    margin-bottom: .85rem;
    box-shadow: 0 10px 26px rgba(54, 43, 36, .08);
  }

  .ss-lane-card a {
    width: 100%;
  }

  .ss-lane-grid,
  .ss-lane-grid--primary,
  .ss-info-grid,
  .ss-price-cards {
    grid-template-columns: 1fr;
  }

  .ss-lane-time {
    display: inline-flex;
    margin-bottom: .5rem;
    color: var(--ss-green, #116A42);
    font-size: .8rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
  }

  .ss-lane-card h3 {
    font-size: 1.2rem;
    margin-bottom: .35rem;
  }

  .ss-lane-card p {
    color: var(--ss-muted, #4f433c);
    margin-bottom: .8rem;
  }

  .ss-lane-card a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border-radius: 999px;
    background: var(--ss-green, #116A42);
    color: #fff;
    font-weight: 900;
    text-decoration: none;
  }

  .ss-lane-help a {
    background: var(--ss-slate, #64748b);
  }

  .ss-schedule-accordion .accordion-item {
    border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
    border-radius: 1rem;
    overflow: hidden;
    margin-bottom: .7rem;
    background: var(--ss-surface, #fff);
  }

  .ss-schedule-accordion .accordion-button {
    font-weight: 900;
    color: var(--ss-ink, #1f1712);
    background: var(--ss-surface, #fff);
    min-height: 52px;
  }

  .ss-schedule-accordion .accordion-button:not(.collapsed) {
    background: var(--ss-surface2, #f7f2ed);
    color: var(--ss-ink, #1f1712);
    box-shadow: none;
  }

  .ss-schedule-accordion ul {
    margin-bottom: .9rem;
  }

  .ss-mini-actions {
    display: grid;
    gap: .5rem;
  }

  .ss-mini-actions a {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 42px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 900;
    background: var(--ss-surface2, #f7f2ed);
    color: var(--ss-ink, #1f1712);
    border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  }

  .ss-mini-actions a:first-child {
    background: var(--ss-green, #116A42);
    color: #fff;
    border-color: var(--ss-green, #116A42);
  }

  .ss-schedule-sticky {
    position: fixed;
    z-index: 1050;
    left: 0;
    right: 0;
    bottom: 0;
    display: grid;
    grid-template-columns: 1.4fr .8fr .8fr;
    gap: .5rem;
    padding: .65rem;
    background: rgba(255, 250, 242, .96);
    border-top: 1px solid var(--ss-border, rgba(33, 29, 24, 0.12));
    box-shadow: 0 -10px 24px rgba(33, 29, 24, .14);
  }

  .ss-schedule-sticky a {
    min-height: 48px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-weight: 950;
    font-size: .95rem;
  }

  .ss-stick-primary {
    background: var(--ss-green, #116A42);
    color: #fff;
  }

  .ss-stick-secondary {
    background: var(--ss-surface2, #f7f2ed);
    color: var(--ss-ink, #1f1712);
    border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  }
}

/* --- New Filter Bar and Weekly Grid Styles --- */

.ss-schedule-section {
  padding: clamp(3rem, 6vw, 5rem) 0;
  background: radial-gradient(circle at 50% 0%, rgba(40, 159, 161, 0.03) 0%, transparent 60%), var(--ss-bg, #FBFAF8);
  position: relative;
}

/* Hero Section Image & Features Styling */
.ss-schedule-hero-image {
  width: 100%;
  height: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  transition: transform 1200ms cubic-bezier(0.32, 0.72, 0, 1);
}

.ss-hero-features-row {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.ss-hero-features-row li {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--ss-surface, #FFFFFF);
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  border-radius: 999px;
  padding: 0.45rem 1rem;
  font-family: 'Lexend', sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ss-muted, #4F433C);
  box-shadow: 0 2px 8px rgba(54, 43, 36, 0.02);
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

.ss-hero-features-row li:hover {
  border-color: var(--ss-green, #116A42);
  color: var(--ss-ink, #362B24);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(17, 106, 66, 0.06);
}

.ss-hero-features-row li i {
  color: var(--ss-teal, #289FA1);
  font-size: 1rem;
}

/* Filter Bar */
.ss-schedule-filter-bar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
  padding: 0.5rem 0;
}

.ss-filter-pills {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  scrollbar-width: none; /* Firefox */
  -webkit-overflow-scrolling: touch;
  padding: 0.25rem 0;
}

.ss-filter-pills::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}

.ss-filter-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  background: var(--ss-surface2, #F4F1ED);
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  color: var(--ss-muted, #4F433C);
  font-family: 'Lexend', sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.5rem 1.25rem;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  user-select: none;
}

.ss-filter-pill:hover {
  background: var(--ss-surface, #FFFFFF);
  color: var(--ss-green, #116A42);
  border-color: var(--ss-green, #116A42);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(17, 106, 66, 0.08);
}

.ss-filter-pill:focus-visible {
  outline: 3px solid rgba(17, 106, 66, 0.25);
  outline-offset: 2px;
}

.ss-filter-pill.active {
  background: var(--ss-green, #116A42);
  color: #FFFFFF;
  border-color: var(--ss-green, #116A42);
  box-shadow: 0 4px 14px rgba(17, 106, 66, 0.24);
}

.ss-filter-info {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--ss-muted, #4F433C);
  font-size: 0.875rem;
  font-weight: 500;
}

.ss-filter-info i {
  color: var(--ss-teal, #289FA1);
  font-size: 1.1rem;
}

/* Dynamic Filter Explainer (Soft-Skills Reassurance) - Double-Bezel Pattern */
.ss-filter-explainer-wrapper {
  background: rgba(40, 159, 161, 0.05);
  border: 1px solid rgba(40, 159, 161, 0.12);
  border-radius: 1.25rem;
  padding: 0.375rem;
  margin-top: -1rem;
  margin-bottom: 2rem;
  box-shadow: 0 4px 12px rgba(54, 43, 36, 0.02);
  transition: transform 0.7s cubic-bezier(0.32, 0.72, 0, 1), box-shadow 0.7s cubic-bezier(0.32, 0.72, 0, 1), border-color 0.7s cubic-bezier(0.32, 0.72, 0, 1);
}

.ss-filter-explainer-wrapper:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(40, 159, 161, 0.06);
  border-color: rgba(40, 159, 161, 0.2);
}

.ss-filter-explainer {
  background: var(--ss-surface, #FFFFFF) !important;
  border: 1px solid rgba(54, 43, 36, 0.06) !important;
  border-radius: calc(1.25rem - 0.375rem) !important;
  padding: 1rem 1.25rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6), 0 10px 30px rgba(54, 43, 36, 0.03) !important;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

@media (min-width: 768px) {
  .ss-schedule-filter-bar {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
  
  .ss-filter-pills {
    overflow-x: visible;
    flex-wrap: wrap;
  }
}

/* Weekly Grid Container */
.ss-weekly-grid-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  margin-top: 1.5rem;
}

@media (min-width: 576px) {
  .ss-weekly-grid-container {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 992px) {
  .ss-weekly-grid-container {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.75rem;
  }
}

/* Day Column Card & Bezel Layout */
.ss-day-column-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.ss-day-column-card .ss-double-bezel {
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 6px;
  border-radius: 1.5rem;
  background: rgba(54, 43, 36, 0.03);
  border: 1px solid rgba(33, 29, 24, 0.05);
  box-shadow: 0 4px 20px rgba(54, 43, 36, 0.02);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.ss-day-column-card .ss-double-bezel-inner {
  padding: 1.15rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  height: 100%;
  border-radius: calc(1.5rem - 6px);
  background: var(--ss-surface, #FFFFFF);
  border: 1px solid rgba(33, 29, 24, 0.08);
  box-shadow: inset 0 1px 2px rgba(255, 255, 255, 0.9);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.ss-day-column-card:hover .ss-double-bezel {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(54, 43, 36, 0.06);
  background: rgba(54, 43, 36, 0.04);
}

.ss-day-column-card:hover .ss-double-bezel-inner {
  border-color: rgba(54, 43, 36, 0.18);
}

/* Saturday Highlight */
.ss-day-column-card[data-day="saturday"] .ss-double-bezel {
  background: rgba(17, 106, 66, 0.04);
  border-color: rgba(17, 106, 66, 0.12);
}

.ss-day-column-card[data-day="saturday"] .ss-double-bezel-inner {
  background: linear-gradient(180deg, rgba(17, 106, 66, 0.02), #FFFFFF);
  border-color: rgba(17, 106, 66, 0.15);
}

/* Sunday Closed state */
.ss-day-column-card.sunday-closed .ss-double-bezel {
  background: rgba(54, 43, 36, 0.02);
  border-color: rgba(54, 43, 36, 0.05);
}

.ss-day-column-card.sunday-closed .ss-double-bezel-inner {
  background: var(--ss-surface2, #F4F1ED);
  border-color: var(--ss-border, rgba(54, 43, 36, 0.14));
  opacity: 0.85;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-height: 180px;
}

.ss-day-column-card.sunday-closed .closed-icon {
  color: var(--ss-muted, #4F433C);
  margin-bottom: 0.5rem;
}

.ss-day-column-card.sunday-closed .closed-icon svg {
  stroke-width: 1.5;
}

.ss-day-column-card.sunday-closed .closed-text {
  margin: 0;
  font-family: 'Lexend', sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--ss-muted, #4F433C);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Day Header */
.ss-day-header {
  margin: 0;
  font-family: 'Lexend', sans-serif;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--ss-ink, #362B24);
  border-bottom: 1.5px solid var(--ss-border, rgba(54, 43, 36, 0.14));
  padding-bottom: 0.5rem;
}

/* Slots List */
.ss-slots-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  flex-grow: 1;
}

/* Day Slot Item */
.ss-day-slot-item {
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.12));
  border-radius: 0.75rem;
  padding: 0.65rem 0.75rem;
  background: var(--ss-bg, #FBFAF8);
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
}

.ss-day-slot-item:hover {
  background: var(--ss-surface, #FFFFFF);
  border-color: rgba(54, 43, 36, 0.22);
  transform: scale(1.02);
  box-shadow: 0 4px 12px rgba(54, 43, 36, 0.03);
}

/* Dimmed filtering behavior */
.ss-day-slot-item.dimmed {
  opacity: 0.18;
  filter: grayscale(1) blur(0.5px);
  pointer-events: none;
  transform: scale(0.96);
}

/* Slot Meta Row */
.ss-slot-meta-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.3rem;
}

/* Slot Time Text */
.ss-slot-time-text {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--ss-green, #116A42);
  font-family: 'Lexend', sans-serif;
}

/* Slot Category Tag */
.ss-slot-category-tag {
  font-size: 0.62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  line-height: 1.2;
}

/* Tag Colors based on Category */
.tag-youth {
  background: rgba(40, 159, 161, 0.08);
  color: var(--ss-teal, #289FA1);
  border: 1px solid rgba(40, 159, 161, 0.16);
}

.tag-adults {
  background: rgba(17, 106, 66, 0.08);
  color: var(--ss-green, #116A42);
  border: 1px solid rgba(17, 106, 66, 0.16);
}

.tag-morning {
  background: rgba(139, 82, 46, 0.08);
  color: var(--ss-brown, #8B522E);
  border: 1px solid rgba(139, 82, 46, 0.16);
}

.tag-nogi {
  background: rgba(48, 96, 97, 0.08);
  color: var(--ss-slate, #306061);
  border: 1px solid rgba(48, 96, 97, 0.16);
}

/* Slot Name Text */
.ss-slot-name-text {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--ss-ink, #362B24);
  line-height: 1.2;
}

/* Slot Description (Soft Skills Reassurance) */
.ss-slot-desc {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.72rem;
  color: var(--ss-muted, #4F433C);
  line-height: 1.25;
  font-weight: 500;
}

/* Helpful Local Guides Section */
.ss-local-guides {
  margin: clamp(2rem, 5vw, 4rem) auto !important;
  padding: clamp(1.5rem, 4vw, 2.5rem) !important;
  border-radius: 24px !important;
  background: var(--ss-surface2, #F4F1ED) !important;
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14)) !important;
  color: var(--ss-text, #1F1712) !important;
}

.ss-local-guides h2 {
  color: var(--ss-ink, #362B24) !important;
  font-family: 'Lexend', sans-serif !important;
  font-weight: 800 !important;
  margin-top: 0 !important;
  margin-bottom: 0.75rem !important;
}

.ss-local-guides p {
  color: var(--ss-muted, #4F433C) !important;
  font-size: 0.95rem !important;
  line-height: 1.5 !important;
  margin-bottom: 1.5rem !important;
}

.ss-local-guides-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 0.75rem !important;
}

.ss-local-guides-grid a {
  display: flex !important;
  align-items: center !important;
  min-height: 52px !important;
  padding: 0.9rem 1.25rem !important;
  border-radius: 16px !important;
  background: var(--ss-surface, #FFFFFF) !important;
  border: 1px solid var(--ss-border, rgba(54, 43, 36, 0.14)) !important;
  color: var(--ss-green, #116A42) !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  box-shadow: 0 2px 8px rgba(54, 43, 36, 0.02) !important;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.ss-local-guides-grid a:hover {
  background: var(--ss-surface, #FFFFFF) !important;
  border-color: var(--ss-green, #116A42) !important;
  color: var(--ss-green, #116A42) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 20px rgba(17, 106, 66, 0.06) !important;
}

/* Schedule page premium refresh */
body.page-schedule {
  --schedule-bg: #f6f0e8;
  --schedule-surface: rgba(255, 251, 246, 0.92);
  --schedule-surface-strong: rgba(255, 255, 255, 0.97);
  --schedule-panel: rgba(53, 42, 33, 0.04);
  --schedule-ink: #201813;
  --schedule-muted: #5c4f46;
  --schedule-accent: #116a42;
  --schedule-accent-soft: #dbe9df;
  --schedule-teal-soft: rgba(40, 159, 161, 0.12);
  --schedule-bronze: #9f6c43;
  --schedule-shadow: 0 24px 80px rgba(48, 31, 15, 0.08);
  --schedule-shadow-soft: 0 14px 42px rgba(48, 31, 15, 0.06);
  --schedule-radius-xl: 32px;
  --schedule-radius-lg: 24px;
  --schedule-radius-md: 18px;
  --schedule-gap: clamp(1.2rem, 2vw, 1.75rem);
  --schedule-transition: 260ms cubic-bezier(0.22, 1, 0.36, 1);
  background:
    radial-gradient(circle at top left, rgba(17, 106, 66, 0.12), transparent 24rem),
    radial-gradient(circle at top right, rgba(159, 108, 67, 0.1), transparent 30rem),
    linear-gradient(180deg, #fbf7f1 0%, var(--schedule-bg) 52%, #f9f5ef 100%);
  color: var(--schedule-ink);
}

body.page-schedule .ss-main {
  position: relative;
  isolation: isolate;
}

body.page-schedule .ss-main::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 42rem;
  background:
    radial-gradient(circle at 14% 12%, rgba(40, 159, 161, 0.1), transparent 22rem),
    radial-gradient(circle at 86% 8%, rgba(159, 108, 67, 0.12), transparent 26rem);
  pointer-events: none;
  z-index: -1;
}

.page-schedule .ss-schedule-hero {
  position: relative;
  padding: clamp(3.4rem, 8vw, 6.5rem) 0 clamp(2.4rem, 5vw, 4.5rem);
  background:
    linear-gradient(135deg, rgba(255, 249, 242, 0.92), rgba(247, 241, 231, 0.76)),
    radial-gradient(circle at top left, rgba(17, 106, 66, 0.14), transparent 22rem);
  overflow: clip;
}

.page-schedule .ss-schedule-hero::before,
.page-schedule .ss-schedule-hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  filter: blur(2px);
}

.page-schedule .ss-schedule-hero::before {
  width: 22rem;
  height: 22rem;
  top: -9rem;
  right: -6rem;
  background: radial-gradient(circle, rgba(40, 159, 161, 0.16), transparent 68%);
}

.page-schedule .ss-schedule-hero::after {
  width: 18rem;
  height: 18rem;
  left: -6rem;
  bottom: -8rem;
  background: radial-gradient(circle, rgba(159, 108, 67, 0.15), transparent 72%);
}

.page-schedule .ss-schedule-hero .container,
.page-schedule .ss-schedule-section .container,
.page-schedule .ss-location-desktop .container,
.page-schedule .ss-faq-section .container,
.page-schedule .container.py-4 {
  max-width: 1180px;
}

.page-schedule .ss-schedule-hero-grid {
  align-items: stretch;
  gap: clamp(1.4rem, 4vw, 3.8rem);
}

.page-schedule .ss-schedule-hero-copy h1,
.page-schedule .ss-section-head h2,
.page-schedule .ss-faq-section h2,
.page-schedule #schedule-local-planning-title {
  font-family: "Instrument Serif", Georgia, serif;
  color: var(--schedule-ink);
}

.page-schedule .ss-schedule-hero-copy h1 {
  max-width: 10ch;
  font-size: clamp(3.4rem, 8vw, 6.6rem);
  line-height: 0.92;
  letter-spacing: -0.06em;
  margin-bottom: 1.1rem;
}

.page-schedule .ss-eyebrow,
.page-schedule .ss-eyebrow-badge,
.page-schedule .ss-card-eyebrow,
.page-schedule .ss-card-label {
  font-family: "Lexend", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.page-schedule .ss-eyebrow-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.9rem;
  border: 1px solid rgba(17, 106, 66, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 10px 26px rgba(48, 31, 15, 0.04);
}

.page-schedule .ss-lead {
  max-width: 58ch;
  color: var(--schedule-muted);
  font-size: clamp(1.05rem, 1.8vw, 1.28rem);
  line-height: 1.7;
}

.page-schedule .ss-hero-actions,
.page-schedule .ss-head-actions {
  gap: 0.9rem;
  margin-top: 1.6rem;
}

.page-schedule .ss-main .ss-btn {
  min-height: 52px;
  border-radius: 999px;
  padding: 0.9rem 1.3rem;
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
  transition:
    transform var(--schedule-transition),
    box-shadow var(--schedule-transition),
    background-color var(--schedule-transition),
    color var(--schedule-transition),
    border-color var(--schedule-transition);
}

.page-schedule .ss-main .ss-btn:hover,
.page-schedule .ss-main .ss-btn:focus-visible {
  transform: translateY(-1px);
}

.page-schedule .ss-main .ss-btn-primary {
  background: linear-gradient(135deg, #155b3d, #0f7a51);
  box-shadow: 0 16px 28px rgba(17, 106, 66, 0.18);
}

.page-schedule .ss-main .ss-btn-primary:hover,
.page-schedule .ss-main .ss-btn-primary:focus-visible {
  box-shadow: 0 20px 34px rgba(17, 106, 66, 0.24);
}

.page-schedule .ss-main .ss-btn:not(.ss-btn-primary) {
  color: var(--schedule-ink);
  background: rgba(255, 255, 255, 0.76);
  border-color: rgba(54, 43, 36, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.page-schedule .ss-schedule-desktop-hero,
.page-schedule .ss-reserve-cta-card,
.page-schedule .ss-first-visit-card,
.page-schedule .ss-proof-card,
.page-schedule .ss-contact-card,
.page-schedule .ss-location-grid,
.page-schedule .ss-day-column-card .ss-double-bezel,
.page-schedule .ss-faq-accordion .accordion-item,
.page-schedule .ss-local-guides .rounded-4 {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(252, 247, 241, 0.88));
  border: 1px solid rgba(54, 43, 36, 0.08);
  box-shadow: var(--schedule-shadow);
}

.page-schedule .ss-schedule-desktop-hero,
.page-schedule .ss-reserve-cta-card,
.page-schedule .ss-first-visit-card,
.page-schedule .ss-proof-card,
.page-schedule .ss-contact-card,
.page-schedule .ss-location-grid,
.page-schedule .ss-faq-accordion .accordion-item {
  border-radius: var(--schedule-radius-xl);
}

.page-schedule .ss-double-bezel {
  border-radius: var(--schedule-radius-xl);
  background:
    linear-gradient(135deg, rgba(17, 106, 66, 0.08), rgba(159, 108, 67, 0.08));
  border: 1px solid rgba(17, 106, 66, 0.08);
  padding: 1px;
}

.page-schedule .ss-double-bezel-inner,
.page-schedule .ss-schedule-desktop-hero,
.page-schedule .ss-reserve-cta-card,
.page-schedule .ss-first-visit-card,
.page-schedule .ss-proof-card,
.page-schedule .ss-contact-card {
  border-radius: calc(var(--schedule-radius-xl) - 1px);
}

.page-schedule .ss-schedule-desktop-hero,
.page-schedule .ss-reserve-cta-card,
.page-schedule .ss-first-visit-card,
.page-schedule .ss-proof-card,
.page-schedule .ss-contact-card {
  padding: clamp(1.3rem, 2.4vw, 1.9rem);
}

.page-schedule .ss-hero-features-row {
  gap: 0.8rem;
  margin-top: 1.5rem;
}

.page-schedule .ss-hero-features-row li {
  min-height: 48px;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(54, 43, 36, 0.1);
  box-shadow: 0 12px 28px rgba(48, 31, 15, 0.05);
}

.page-schedule .ss-schedule-section,
.page-schedule .ss-location-desktop,
.page-schedule .ss-faq-section,
.page-schedule .container.py-4 {
  position: relative;
  padding: clamp(3.2rem, 7vw, 5.6rem) 0;
}

.page-schedule .ss-schedule-section::before,
.page-schedule .ss-location-desktop::before,
.page-schedule .ss-faq-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.22), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.16));
  pointer-events: none;
}

.page-schedule .ss-section-head {
  margin-bottom: 2rem;
}

.page-schedule .ss-section-head h2,
.page-schedule .ss-faq-section h2,
.page-schedule #schedule-local-planning-title {
  font-size: clamp(2.4rem, 4vw, 4rem);
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.page-schedule .ss-section-head p,
.page-schedule .ss-faq-section p,
.page-schedule .ss-local-guides p,
.page-schedule .ss-contact-card p,
.page-schedule .ss-proof-card p,
.page-schedule .ss-first-visit-card p {
  color: var(--schedule-muted);
}

.page-schedule .ss-schedule-filter-bar {
  position: sticky;
  top: 5.2rem;
  z-index: 12;
  padding: 1.05rem 1.15rem 1.15rem;
  border-radius: 30px;
  background: rgba(255, 252, 248, 0.78);
  border: 1px solid rgba(54, 43, 36, 0.08);
  box-shadow: 0 18px 50px rgba(48, 31, 15, 0.08);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.page-schedule .ss-filter-pills {
  gap: 0.7rem;
}

.page-schedule .ss-filter-pill {
  min-height: 46px;
  padding: 0.72rem 1.15rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.12);
  background: rgba(244, 241, 237, 0.88);
  color: var(--schedule-muted);
  font-weight: 700;
  transition:
    transform var(--schedule-transition),
    box-shadow var(--schedule-transition),
    border-color var(--schedule-transition),
    background-color var(--schedule-transition),
    color var(--schedule-transition);
}

.page-schedule .ss-filter-pill:hover,
.page-schedule .ss-filter-pill:focus-visible {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(17, 106, 66, 0.2);
  box-shadow: 0 10px 20px rgba(17, 106, 66, 0.08);
}

.page-schedule .ss-filter-pill.active {
  background: linear-gradient(135deg, #14583b, #0f7a51);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 14px 24px rgba(17, 106, 66, 0.2);
}

.page-schedule .ss-filter-info {
  margin-top: 1rem;
  gap: 0.7rem;
  font-size: 0.95rem;
}

.page-schedule .ss-filter-explainer-wrapper {
  margin-top: 1rem;
  padding: 1rem 1.15rem;
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.84), rgba(219, 233, 223, 0.62));
  border: 1px solid rgba(17, 106, 66, 0.12);
  box-shadow: var(--schedule-shadow-soft);
}

.page-schedule .ss-filter-explainer {
  color: var(--schedule-ink);
  line-height: 1.6;
}

.page-schedule .ss-weekly-grid-container {
  gap: 1rem;
  align-items: stretch;
}

.page-schedule .ss-day-column-card {
  height: 100%;
}

.page-schedule .ss-day-column-card .ss-double-bezel {
  height: 100%;
  transition:
    transform var(--schedule-transition),
    box-shadow var(--schedule-transition),
    border-color var(--schedule-transition);
}

.page-schedule .ss-day-column-card .ss-double-bezel:hover {
  transform: translateY(-3px);
  box-shadow: 0 30px 54px rgba(48, 31, 15, 0.1);
}

.page-schedule .ss-day-column-card .ss-double-bezel-inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-height: 100%;
  padding: 1.15rem 1rem 1rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(250, 246, 239, 0.96));
}

.page-schedule .ss-day-column-card[data-day="saturday"] .ss-double-bezel {
  background: linear-gradient(135deg, rgba(17, 106, 66, 0.2), rgba(40, 159, 161, 0.18), rgba(159, 108, 67, 0.18));
  box-shadow: 0 32px 62px rgba(17, 106, 66, 0.12);
}

.page-schedule .ss-day-column-card[data-day="saturday"] .ss-double-bezel-inner {
  background:
    radial-gradient(circle at top right, rgba(40, 159, 161, 0.1), transparent 42%),
    linear-gradient(180deg, rgba(252, 255, 253, 0.98), rgba(244, 250, 247, 0.96));
}

.page-schedule .ss-day-column-card.sunday-closed .ss-double-bezel {
  box-shadow: none;
}

.page-schedule .ss-day-header {
  display: grid;
  gap: 0.35rem;
  padding-bottom: 0.95rem;
  border-bottom: 1px solid rgba(54, 43, 36, 0.1);
}

.page-schedule .ss-day-header .ss-day-label {
  margin: 0;
  font-family: "Lexend", sans-serif;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--schedule-ink);
}

.page-schedule .ss-day-header .ss-day-note {
  margin: 0;
  font-size: 0.86rem;
  color: var(--schedule-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.page-schedule .ss-slots-list {
  display: grid;
  gap: 0.8rem;
}

.page-schedule .ss-day-slot-item {
  display: grid;
  gap: 0.55rem;
  padding: 0.95rem 0.9rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(54, 43, 36, 0.08);
  box-shadow: 0 12px 24px rgba(48, 31, 15, 0.04);
  transition:
    transform var(--schedule-transition),
    opacity var(--schedule-transition),
    background-color var(--schedule-transition),
    border-color var(--schedule-transition),
    box-shadow var(--schedule-transition);
}

.page-schedule .ss-day-slot-item:hover {
  transform: translateY(-2px);
  border-color: rgba(17, 106, 66, 0.14);
  box-shadow: 0 18px 30px rgba(48, 31, 15, 0.06);
}

.page-schedule .ss-day-slot-item.dimmed {
  opacity: 0.2;
  transform: scale(0.975);
}

.page-schedule .ss-day-slot-item[data-tags*="morning"] {
  background: linear-gradient(180deg, rgba(248, 242, 236, 0.96), rgba(244, 237, 229, 0.96));
  border-color: rgba(159, 108, 67, 0.16);
}

.page-schedule .ss-day-slot-item[data-tags*="morning"] .ss-slot-category-tag {
  background: rgba(159, 108, 67, 0.1);
  color: var(--schedule-bronze);
  border-color: rgba(159, 108, 67, 0.18);
}

.page-schedule .ss-slot-time,
.page-schedule .ss-slot-name-text {
  color: var(--schedule-ink);
}

.page-schedule .ss-slot-time {
  font-family: "Lexend", sans-serif;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.page-schedule .ss-slot-name-text {
  font-size: 1rem;
  font-weight: 700;
}

.page-schedule .ss-slot-desc {
  color: var(--schedule-muted);
  line-height: 1.55;
}

.page-schedule .ss-slot-category-tag {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-schedule .ss-day-slot-item a {
  min-height: 44px;
  border-radius: 999px;
  justify-content: center;
  box-shadow: none;
}

.page-schedule .ss-day-slot-item[data-tags*="morning"] a {
  background: rgba(255, 255, 255, 0.76);
  color: var(--schedule-bronze);
  border: 1px solid rgba(159, 108, 67, 0.18);
}

.page-schedule .ss-first-visit-grid,
.page-schedule .ss-info-grid {
  gap: var(--schedule-gap);
}

.page-schedule .ss-first-visit-card,
.page-schedule .ss-proof-card,
.page-schedule .ss-contact-card {
  position: relative;
  overflow: clip;
}

.page-schedule .ss-first-visit-card::before,
.page-schedule .ss-proof-card::before,
.page-schedule .ss-contact-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, rgba(17, 106, 66, 0.92), rgba(40, 159, 161, 0.82), rgba(159, 108, 67, 0.82));
}

.page-schedule .ss-first-visit-item,
.page-schedule .ss-check-list li {
  padding: 0.95rem 0 0.95rem 1.6rem;
  border-bottom: 1px solid rgba(54, 43, 36, 0.08);
  position: relative;
}

.page-schedule .ss-first-visit-item:last-child,
.page-schedule .ss-check-list li:last-child {
  border-bottom: 0;
}

.page-schedule .ss-first-visit-item::before,
.page-schedule .ss-check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1.35rem;
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #116a42, #289fa1);
  box-shadow: 0 0 0 5px rgba(17, 106, 66, 0.08);
}

.page-schedule .ss-faq-section {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), transparent),
    linear-gradient(180deg, rgba(246, 240, 232, 0.3), rgba(246, 240, 232, 0));
}

.page-schedule .ss-faq-accordion {
  display: grid;
  gap: 0.9rem;
}

.page-schedule .ss-faq-accordion .accordion-item {
  overflow: clip;
}

.page-schedule .ss-faq-accordion .accordion-button {
  min-height: 72px;
  padding: 1.15rem 1.35rem;
  background: transparent;
  color: var(--schedule-ink);
  font-family: "Lexend", sans-serif;
  font-size: 1rem;
  font-weight: 700;
  box-shadow: none;
}

.page-schedule .ss-faq-accordion .accordion-button:not(.collapsed) {
  background: rgba(17, 106, 66, 0.04);
  color: var(--schedule-accent);
}

.page-schedule .ss-faq-accordion .accordion-button:focus {
  box-shadow: inset 0 0 0 2px rgba(17, 106, 66, 0.15);
}

.page-schedule .ss-faq-accordion .accordion-body {
  padding: 0 1.35rem 1.3rem;
  color: var(--schedule-muted);
  line-height: 1.7;
}

.page-schedule .ss-location-grid {
  gap: var(--schedule-gap);
  padding: clamp(1.35rem, 3vw, 2rem);
}

.page-schedule .ss-local-guides .rounded-4 {
  padding: clamp(1.35rem, 3vw, 2rem) !important;
  border-radius: var(--schedule-radius-xl) !important;
}

.page-schedule .ss-local-guides-grid {
  gap: 0.9rem !important;
}

.page-schedule .ss-local-guides-grid a {
  min-height: 60px !important;
  padding: 0.95rem 1rem !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, 0.82) !important;
  border: 1px solid rgba(54, 43, 36, 0.1) !important;
  box-shadow: 0 12px 24px rgba(48, 31, 15, 0.04) !important;
}

.page-schedule .ss-local-guides-grid a:hover,
.page-schedule .ss-local-guides-grid a:focus-visible {
  transform: translateY(-2px) !important;
  border-color: rgba(17, 106, 66, 0.2) !important;
  box-shadow: 0 18px 30px rgba(17, 106, 66, 0.08) !important;
}

@media (max-width: 991.98px) {
  .page-schedule .ss-schedule-filter-bar {
    top: 4.8rem;
    padding: 0.95rem 0.95rem 1rem;
  }

  .page-schedule .ss-schedule-hero-grid {
    gap: 1.35rem;
  }

  .page-schedule .ss-day-column-card .ss-double-bezel-inner {
    min-height: 100%;
  }
}

@media (max-width: 767.98px) {
  body.page-schedule {
    background:
      radial-gradient(circle at top left, rgba(17, 106, 66, 0.1), transparent 16rem),
      linear-gradient(180deg, #fbf7f1 0%, #f6f0e8 100%);
  }

  .page-schedule .ss-schedule-hero {
    padding: 2.6rem 0 1.6rem;
  }

  .page-schedule .ss-schedule-hero-copy h1,
  .page-schedule .ss-section-head h2,
  .page-schedule .ss-faq-section h2,
  .page-schedule #schedule-local-planning-title {
    font-size: clamp(2.3rem, 11vw, 3.2rem);
  }

  .page-schedule .ss-hero-features-row {
    gap: 0.6rem;
  }

  .page-schedule .ss-hero-features-row li {
    width: 100%;
    justify-content: center;
  }

  .page-schedule .ss-schedule-filter-bar {
    position: static;
    margin-top: 1rem;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .page-schedule .ss-weekly-grid-container {
    gap: 0.9rem;
  }

  .page-schedule .ss-day-column-card .ss-double-bezel-inner {
    padding: 1rem 0.95rem;
  }
}

/* HIGH-END VISUAL DESIGN OVERRIDES */
body.page-schedule {
  background-color: #ffffff;
  color: #111111;
  font-family: 'Plus Jakarta Sans', sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


/* Macro Whitespace */
.page-schedule .ss-section, .page-schedule section {
  padding-top: clamp(6rem, 15vw, 10rem) !important;
  padding-bottom: clamp(6rem, 15vw, 10rem) !important;
}

/* Typography */
.page-schedule h1, .page-schedule h2, .page-schedule h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #050505;
}

.page-schedule h1 {
  font-size: clamp(3rem, 8vw, 5rem) !important;
  line-height: 1.05;
  margin-bottom: 1.5rem;
}

.page-schedule h2 {
  font-size: clamp(2.5rem, 6vw, 4rem) !important;
  line-height: 1.1;
  margin-bottom: 1.25rem;
}

.page-schedule .ss-eyebrow, .page-schedule .ss-eyebrow-badge {
  display: inline-block;
  border-radius: 9999px;
  padding: 0.25rem 0.75rem;
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 600;
  background: rgba(0,0,0,0.04);
  color: #111;
  margin-bottom: 1.5rem;
}

/* Double-Bezel Containers */
.page-schedule .ss-double-bezel {
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid rgba(0, 0, 0, 0.04);
  padding: 0.5rem;
  border-radius: 2rem;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.05);
}
.page-schedule .ss-double-bezel-inner {
  background: #ffffff;
  border-radius: calc(2rem - 0.5rem);
  box-shadow: inset 0 1px 1px rgba(255,255,255,1), 0 10px 30px -10px rgba(0,0,0,0.03);
  padding: 2.5rem;
  height: 100%;
}

/* Button-in-Button CTA (Nested CTA) */
.page-schedule .ss-btn.group {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  padding: 0.75rem 0.75rem 0.75rem 1.5rem;
  font-weight: 600;
  font-size: 0.95rem;
  transition: all 0.7s cubic-bezier(0.32, 0.72, 0, 1);
  text-decoration: none;
  background: #050505;
  color: #ffffff;
  border: none;
}
.page-schedule .ss-btn.ss-btn-secondary.group {
  background: rgba(0,0,0,0.04);
  color: #050505;
}

.page-schedule .ss-btn.group .ss-btn-icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  margin-left: 1rem;
  transition: all 0.7s cubic-bezier(0.32, 0.72, 0, 1);
}
.page-schedule .ss-btn.ss-btn-secondary.group .ss-btn-icon-wrapper {
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

/* Magnetic Button Hover Physics */
.page-schedule .ss-btn.group:hover {
  transform: scale(0.98);
}
.page-schedule .ss-btn.group:hover .ss-btn-icon-wrapper {
  transform: translate(4px, -1px) scale(1.05);
}

/* Scroll Entry Animations */
.page-schedule .ss-reveal {
  opacity: 0;
  transform: translateY(4rem) scale(0.98);
  filter: blur(10px);
  transition: opacity 1s cubic-bezier(0.32, 0.72, 0, 1), transform 1s cubic-bezier(0.32, 0.72, 0, 1), filter 1s cubic-bezier(0.32, 0.72, 0, 1);
  will-change: transform, opacity, filter;
}
.page-schedule .ss-reveal.delay-1 { transition-delay: 100ms; }
.page-schedule .ss-reveal.delay-2 { transition-delay: 200ms; }
.page-schedule .ss-reveal.delay-3 { transition-delay: 300ms; }
.page-schedule .ss-reveal.delay-4 { transition-delay: 400ms; }

.page-schedule .ss-is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

/* Asymmetrical Bento Grid overrides for Schedule */
.page-schedule .ss-schedule-grid-shell {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
.page-schedule .ss-day-card {
  grid-column: span 4;
  background: #fff;
  border-radius: 1.5rem;
  border: 1px solid rgba(0,0,0,0.04);
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.03);
  padding: 2rem;
  display: flex;
  flex-direction: column;
}
/* Make some cards span more columns for bento effect */
.page-schedule .ss-day-card:nth-child(1),
.page-schedule .ss-day-card:nth-child(4) {
  grid-column: span 8;
}

@media (max-width: 992px) {
  .page-schedule .ss-day-card,
  .page-schedule .ss-day-card:nth-child(1),
  .page-schedule .ss-day-card:nth-child(4) {
    grid-column: span 6;
  }
}
@media (max-width: 768px) {
  .page-schedule .ss-schedule-grid-shell {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 0 1rem;
    width: 100%;
  }
}

/* Styling the slot items inside the bento grid */
.page-schedule .ss-day-card-header {
  margin-bottom: 2rem;
}
.page-schedule .ss-day-label {
  font-size: 1.5rem;
  font-weight: 800;
  margin-bottom: 0.25rem;
}
.page-schedule .ss-day-note {
  font-size: 0.85rem;
  color: rgba(0,0,0,0.5);
  font-weight: 500;
}
.page-schedule .ss-day-slot-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex-grow: 1;
}
.page-schedule .ss-day-slot-item {
  display: flex;
  align-items: center;
  padding: 1.25rem;
  border-radius: 1rem;
  background: rgba(0,0,0,0.02);
  gap: 1rem;
  transition: all 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}
.page-schedule .ss-day-slot-item:hover {
  background: rgba(0,0,0,0.04);
  transform: translateY(-2px);
}
.page-schedule .ss-slot-time-text {
  font-weight: 700;
  font-size: 1.1rem;
  color: #050505;
}
.page-schedule .ss-slot-main {
  flex-grow: 1;
}
.page-schedule .ss-slot-name-text {
  font-weight: 700;
  margin-bottom: 0.1rem;
}
.page-schedule .ss-slot-meta {
  font-size: 0.8rem;
  color: rgba(0,0,0,0.5);
  margin: 0;
}
.page-schedule .ss-slot-cta {
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  background: #050505;
  color: #fff;
  text-decoration: none;
  transition: all 0.3s ease;
}
.page-schedule .ss-slot-cta:hover {
  transform: scale(0.95);
}

/* Image wrappers */
.page-schedule .ss-home-media-frame {
  width: 100%;
  height: 100%;
  border-radius: calc(2rem - 0.75rem);
  overflow: hidden;
}
.page-schedule .ss-schedule-hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 10s ease;
}
.page-schedule .ss-schedule-hero-image-wrap:hover .ss-schedule-hero-image {
  transform: scale(1.05);
}

/* =========================================================================
   HERO EDITORIAL SPLIT & DOUBLE BEZEL CALENDAR (NEW LAYOUT)
   ========================================================================= */

.ss-hero-editorial-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  padding: clamp(8rem, 12vw, 10rem) 5% clamp(4rem, 8vw, 6rem);
  max-width: 1400px;
  margin: 0 auto;
  align-items: center;
}

@media (max-width: 991.98px) {
  .ss-hero-editorial-split {
    grid-template-columns: 1fr;
    padding-top: clamp(6rem, 10vw, 8rem);
  }
}

.ss-editorial-left {
  max-width: 600px;
}

.ss-eyebrow-badge {
  background: var(--ss-orange, #E05500);
  color: #fff;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.ss-editorial-title {
  font-family: "Instrument Serif", Georgia, serif;
  font-size: clamp(3.2rem, 6vw, 4.5rem);
  line-height: 1.05;
  font-weight: 400;
  color: var(--ss-ink, #362B24);
  margin-bottom: 1.5rem;
  letter-spacing: -0.02em;
}

.ss-editorial-lead {
  font-size: clamp(1.1rem, 2vw, 1.25rem);
  color: var(--ss-muted, #4F433C);
  line-height: 1.6;
  margin-bottom: 2rem;
  max-width: 90%;
}

.ss-hero-actions {
  margin-bottom: 2rem;
}

.ss-btn-premium {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  background: var(--ss-ink, #362B24);
  color: #fff;
  padding: 1rem 1.5rem;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  box-shadow: 0 10px 24px rgba(54, 43, 36, 0.15);
}

.ss-btn-premium:hover,
.ss-btn-premium:focus {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(54, 43, 36, 0.2);
  background: #1f1712;
  color: #fff;
}

.ss-btn-premium-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 50%;
  width: 32px;
  height: 32px;
}

.ss-hero-features-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.ss-hero-features-row li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ss-muted, #4F433C);
}

.ss-hero-features-row li i {
  font-size: 1.2rem;
  color: var(--ss-teal, #289FA1);
}

/* Calendar Right Side */
.ss-editorial-right {
  width: 100%;
}

.ss-calendar-groups {
  display: flex;
  flex-direction: column;
}

.ss-schedule-group-title {
  color: var(--ss-ink, #362B24);
}

.ss-calendar-bezel-outer {
  background: linear-gradient(145deg, #ffffff, #f4f1ed);
  padding: 8px;
  border-radius: 28px;
  box-shadow: 0 24px 48px rgba(54, 43, 36, 0.06), inset 0 2px 4px rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(54, 43, 36, 0.04);
}

.ss-calendar-bezel-inner {
  background: var(--ss-surface, #FFFFFF);
  border-radius: 20px;
  border: 1px solid rgba(54, 43, 36, 0.08);
  overflow: hidden;
}

.ss-cal-day {
  display: flex;
  flex-direction: column;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid rgba(54, 43, 36, 0.06);
  text-decoration: none;
  color: inherit;
  transition: background 0.2s ease;
}

a.ss-cal-day:hover,
a.ss-cal-day:focus {
  background: #fdfaf6;
  outline: none;
}

.ss-cal-day:last-child {
  border-bottom: none;
}

.ss-cal-day-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.ss-cal-day-name {
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--ss-ink, #362B24);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.ss-cal-day-badge {
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  padding: 0.35rem 0.65rem;
  border-radius: 8px;
  background: #e8e4dc;
  color: #5c554e;
  letter-spacing: 0.05em;
}

.ss-cal-day-badge.active {
  background: rgba(40, 159, 161, 0.12);
  color: var(--ss-teal, #289FA1);
}

.ss-cal-day-badge.nogi {
  background: rgba(224, 85, 0, 0.1);
  color: var(--ss-orange, #E05500);
}

.ss-cal-slot {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 1rem;
  align-items: center;
  margin-bottom: 0.5rem;
}

.ss-cal-slot:last-child {
  margin-bottom: 0;
}

.ss-cal-slot-time {
  font-weight: 800;
  color: var(--ss-slate, #306061);
  font-size: 0.95rem;
}

.ss-cal-slot-name {
  font-weight: 600;
  color: var(--ss-ink, #362B24);
  font-size: 1rem;
}

/* Animation utilities */
.ss-anim-fade-up {
  animation: ssFadeUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
  transform: translateY(20px);
}

.ss-anim-delay-1 {
  animation-delay: 0.15s;
}

@keyframes ssFadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

