/**
 * Skills at Will — Calendar Styles
 * File: /wp-content/themes/your-child-theme/assets/css/saw-calendar.css
 * Version: 3.0.0
 */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

/* ============================================================
   1. FORCE FULL WIDTH — override ANY WordPress theme
   ============================================================ */

body.page #primary                            { width: 100% !important; max-width: 100% !important; float: none !important; padding: 0 !important; margin: 0 !important; }
body.page #secondary                          { display: none !important; }
body.page .content-area                       { width: 100% !important; max-width: 100% !important; float: none !important; }
body.page .site-main                          { width: 100% !important; max-width: 100% !important; }
body.page main                                { width: 100% !important; max-width: 100% !important; padding: 0 !important; }
body.page .entry-content                      { padding: 0 !important; margin: 0 !important; max-width: 100% !important; }
body.page .entry-header                       { padding: 0 0 0 28px !important; }
body.page .container                          { max-width: 100% !important; padding-left: 0 !important; padding-right: 0 !important; }
body.page .site-content                       { padding: 0 !important; }
body.page .widget-area                        { display: none !important; }
body.page .sidebar                            { display: none !important; }
body.page #sidebar                            { display: none !important; }
body.page aside                               { display: none !important; }

/* ============================================================
   2. CSS VARIABLES
   ============================================================ */

#saw-calendar-root {
  --saw-brand:       #00BFFF;
  --saw-brand-dark:  #0088CC;
  --saw-brand-light: #33D4FF;
  --saw-surface:     #060A10;
  --saw-card:        rgba(8, 16, 24, 0.92);
  --saw-border:      rgba(0, 191, 255, 0.12);
  --saw-text:        #D9EEF8;
  --saw-muted:       rgba(217, 238, 248, 0.62);
  --saw-faint:       rgba(217, 238, 248, 0.32);
  --saw-green:       #00E5A0;
  --saw-purple:      #A78BFA;
  --saw-red:         #FB7185;
  --saw-amber:       #F59E0B;
  --saw-live:        #FF5B6E;
  --saw-zoom:        #2D8CFF;
  --radius-sm:       10px;
  --radius-md:       16px;
  --radius-lg:       22px;
  --transition:      all 0.22s ease;
}

/* ============================================================
   3. ROOT RESET
   ============================================================ */

#saw-calendar-root *,
#saw-calendar-root *::before,
#saw-calendar-root *::after {
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: 'Outfit', 'Inter', 'Helvetica Neue', sans-serif !important;
  line-height: normal !important;
}

#saw-calendar-root {
  background: var(--saw-surface) !important;
  color: var(--saw-text) !important;
  
  overflow: hidden !important;
  position: relative !important;
  min-height: 600px !important;
  width: 100% !important;
  max-width: 100% !important;
  display: block !important;
}

/* ============================================================
   4. BACKGROUND FX
   ============================================================ */

#saw-bg-fx {
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 0 !important;
  overflow: hidden !important;
}

#saw-bg-fx::before {
  content: '' !important;
  position: absolute !important;
  top: -18% !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 900px !important;
  height: 900px !important;
  background: radial-gradient(ellipse, rgba(0,191,255,0.10) 0%, rgba(0,136,204,0.05) 38%, transparent 70%) !important;
}

#saw-bg-fx::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background-image: linear-gradient(rgba(0,191,255,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(0,191,255,0.03) 1px, transparent 1px) !important;
  background-size: 64px 64px !important;
}

/* ============================================================
   5. HEADER
   ============================================================ */

#saw-header {
  position: relative !important;
  z-index: 2 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 20px !important;
  padding: 18px 28px !important;
  background: rgba(6, 10, 16, 0.84) !important;
  border-bottom: 1px solid var(--saw-border) !important;
  backdrop-filter: blur(18px) !important;
  flex-wrap: wrap !important;
}

#saw-header .saw-logo {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

#saw-header .saw-logo-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, var(--saw-brand), var(--saw-brand-dark)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 18px !important;
  box-shadow: 0 0 20px rgba(0,191,255,0.28) !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

#saw-header .saw-logo-text h2 {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: #fff !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

#saw-header .saw-logo-text h2 span {
  color: var(--saw-brand) !important;
}

#saw-header .saw-logo-text p {
  font-size: 11px !important;
  color: var(--saw-faint) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  margin-top: 2px !important;
  margin-bottom: 0 !important;
}

#saw-header .saw-header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

/* ============================================================
   6. VIEW TOGGLE
   ============================================================ */

#saw-header .saw-view-toggle {
  display: inline-flex !important;
  gap: 4px !important;
  background: rgba(0,191,255,0.05) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: 14px !important;
  padding: 4px !important;
}

#saw-header .saw-view-toggle button {
  background: transparent !important;
  border: none !important;
  color: var(--saw-muted) !important;
  padding: 9px 18px !important;
  border-radius: 10px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: var(--transition) !important;
  text-transform: capitalize !important;
  box-shadow: none !important;
}

#saw-header .saw-view-toggle button.active {
  background: rgba(0,191,255,0.14) !important;
  color: var(--saw-brand) !important;
}

/* ============================================================
   7. ALL BUTTONS
   ============================================================ */

#saw-calendar-root .saw-btn {
  border-radius: var(--radius-sm) !important;
  padding: 10px 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: var(--transition) !important;
  border: none !important;
  outline: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

#saw-calendar-root .saw-btn-primary {
  background: linear-gradient(135deg, var(--saw-brand), var(--saw-brand-dark)) !important;
  color: #fff !important;
  box-shadow: 0 8px 24px rgba(0,191,255,0.22) !important;
}

#saw-calendar-root .saw-btn-primary:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 28px rgba(0,191,255,0.32) !important;
}

#saw-calendar-root .saw-btn-ghost {
  background: rgba(0,191,255,0.06) !important;
  border: 1px solid var(--saw-border) !important;
  color: var(--saw-brand) !important;
}

#saw-calendar-root .saw-btn-ghost:hover {
  background: rgba(0,191,255,0.12) !important;
}

#saw-calendar-root .saw-btn-outline {
  background: transparent !important;
  border: 1px solid var(--saw-border) !important;
  color: var(--saw-muted) !important;
}

#saw-calendar-root .saw-btn-outline:hover {
  border-color: rgba(0,191,255,0.22) !important;
  color: var(--saw-text) !important;
}

#saw-calendar-root .saw-btn-live {
  background: linear-gradient(135deg, var(--saw-live), #D92D4A) !important;
  color: #fff !important;
  box-shadow: 0 8px 24px rgba(255,91,110,0.28) !important;
}

#saw-calendar-root .saw-btn-live:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 28px rgba(255,91,110,0.38) !important;
}

#saw-calendar-root .saw-btn-disabled {
  background: rgba(0,191,255,0.05) !important;
  border: 1px solid var(--saw-border) !important;
  color: var(--saw-faint) !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

#saw-calendar-root .saw-btn-sm {
  padding: 8px 14px !important;
  font-size: 12px !important;
}

#saw-calendar-root .saw-btn-icon {
  width: 42px !important;
  height: 42px !important;
  padding: 0 !important;
  border-radius: var(--radius-sm) !important;
  font-size: 20px !important;
}

/* ============================================================
   COURSE PILLS & TRACK TABS
   ============================================================ */

#saw-course-pills {
  position: relative !important;
  z-index: 2 !important;
  padding: 14px 28px !important;
  border-bottom: 1px solid var(--saw-border) !important;
  background: rgba(6,10,16,0.60) !important;
}

/* Track tabs */
#saw-course-pills .saw-track-tabs {
  display: flex !important;
  gap: 6px !important;
  margin-bottom: 12px !important;
}

#saw-course-pills .saw-track-tab {
  background: transparent !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: 999px !important;
  padding: 6px 16px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--saw-muted) !important;
  cursor: pointer !important;
  transition: var(--transition) !important;
  font-family: inherit !important;
}

#saw-course-pills .saw-track-tab.active {
  background: rgba(0,191,255,0.12) !important;
  border-color: rgba(0,191,255,0.30) !important;
  color: var(--saw-brand) !important;
}

#saw-course-pills .saw-track-tab:hover:not(.active) {
  border-color: rgba(0,191,255,0.18) !important;
  color: var(--saw-text) !important;
}

/* Course pills */
#saw-course-pills .saw-pills-wrap {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

#saw-course-pills .saw-course-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: rgba(0,191,255,0.04) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: 999px !important;
  padding: 7px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--saw-text) !important;
  text-decoration: none !important;
  transition: var(--transition) !important;
  cursor: pointer !important;
}

#saw-course-pills .saw-course-pill:hover {
  border-color: rgba(0,191,255,0.24) !important;
  background: rgba(0,191,255,0.08) !important;
  color: #fff !important;
}

#saw-course-pills .saw-pill-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--saw-brand) !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
}

#saw-course-pills .saw-pill-name {
  font-weight: 600 !important;
  color: var(--saw-text) !important;
}

#saw-course-pills .saw-pill-enrolled {
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  color: var(--saw-green) !important;
  background: rgba(0,229,160,0.12) !important;
  border: 1px solid rgba(0,229,160,0.22) !important;
  border-radius: 999px !important;
  padding: 2px 7px !important;
}

/* ============================================================
   8. HERO SECTION
   ============================================================ */

#saw-hero {
  position: relative !important;
  z-index: 2 !important;
  padding: 44px 28px 24px !important;
  border-bottom: 1px solid var(--saw-border) !important;
}

#saw-hero .saw-hero-inner {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
  gap: 24px !important;
  flex-wrap: wrap !important;
}

#saw-hero .saw-hero-text {
  max-width: 760px !important;
  flex: 1 1 420px !important;
}

/* Eyebrow — "Real live sessions. Real skill progression." */
#saw-hero .saw-hero-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--saw-brand) !important;
}

#saw-hero .saw-eyebrow-line {
  width: 22px !important;
  height: 1px !important;
  background: var(--saw-brand) !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
}

/* Headline */
#saw-hero .saw-hero-headline {
  margin: 0 0 16px 0 !important;
  font-size: clamp(32px, 4.3vw, 56px) !important;
  font-weight: 800 !important;
  line-height: 1.06 !important;
  letter-spacing: -0.035em !important;
  color: #fff !important;
  border: none !important;
  padding: 0 !important;
}

#saw-hero .saw-hero-gradient {
  background: linear-gradient(135deg, var(--saw-brand-light), var(--saw-brand)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* Subtext paragraph */
#saw-hero .saw-hero-sub {
  margin: 0 !important;
  color: var(--saw-muted) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  max-width: 680px !important;
}

/* View toggle inside hero */
#saw-hero .saw-view-toggle {
  display: inline-flex !important;
  gap: 4px !important;
  background: rgba(0,191,255,0.05) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: 14px !important;
  padding: 4px !important;
  align-self: flex-end !important;
  flex-shrink: 0 !important;
}

#saw-hero .saw-view-toggle button {
  background: transparent !important;
  border: none !important;
  color: var(--saw-muted) !important;
  padding: 9px 18px !important;
  border-radius: 10px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: var(--transition) !important;
  text-transform: capitalize !important;
  box-shadow: none !important;
}

#saw-hero .saw-view-toggle button.active {
  background: rgba(0,191,255,0.14) !important;
  color: var(--saw-brand) !important;
}

@media (max-width: 700px) {
  #saw-hero {
    padding: 28px 16px 20px !important;
  }

  #saw-hero .saw-hero-headline {
    font-size: 28px !important;
  }

  #saw-hero .saw-hero-sub {
    font-size: 14px !important;
  }
}

/* ============================================================
   9. FILTERS BAR
   ============================================================ */

#saw-filters {
  position: relative !important;
  z-index: 2 !important;
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  padding: 14px 28px !important;
  border-bottom: 1px solid var(--saw-border) !important;
  background: rgba(6,10,16,0.60) !important;
}

#saw-filters .saw-select {
  background: rgba(0,191,255,0.05) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 9px 14px !important;
  color: var(--saw-text) !important;
  font-size: 13px !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  outline: none !important;
  cursor: pointer !important;
  min-width: 160px !important;
  transition: var(--transition) !important;
}

#saw-filters .saw-select:hover,
#saw-filters .saw-select:focus {
  border-color: rgba(0,191,255,0.28) !important;
}

#saw-filters .saw-select option {
  background: #0D1520 !important;
  color: var(--saw-text) !important;
}

#saw-filters .saw-refresh-btn {
  margin-left: auto !important;
}

#saw-filters .saw-last-updated {
  font-size: 11px !important;
  color: var(--saw-faint) !important;
  align-self: center !important;
}

/* ============================================================
   9. MAIN LAYOUT
   ============================================================ */

#saw-main {
  position: relative !important;
  z-index: 2 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(340px, 0.8fr) !important;
  gap: 22px !important;
  padding: 22px 28px 40px !important;
  align-items: start !important;
}

#saw-main.saw-list-view {
  grid-template-columns: 1fr !important;
  max-width: 860px !important;
  margin: 0 auto !important;
}

/* ============================================================
   10. CALENDAR GRID
   ============================================================ */

#saw-calendar-grid {
  background: rgba(0,191,255,0.025) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 24px !important;
  backdrop-filter: blur(12px) !important;
}

#saw-calendar-grid .saw-cal-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 22px !important;
  gap: 12px !important;
}

#saw-calendar-grid .saw-cal-header h3 {
  font-size: 26px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: -0.02em !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#saw-calendar-grid .saw-cal-header h3 span {
  color: var(--saw-faint) !important;
  font-weight: 400 !important;
}

#saw-calendar-grid .saw-day-labels {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 5px !important;
  margin-bottom: 6px !important;
}

#saw-calendar-grid .saw-day-label {
  text-align: center !important;
  padding: 8px 0 !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--saw-faint) !important;
  font-weight: 700 !important;
}

#saw-calendar-grid .saw-days-grid {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 5px !important;
}

#saw-calendar-grid .saw-day-cell {
  aspect-ratio: 1 / 1 !important;
  border-radius: 16px !important;
  border: 1.5px solid transparent !important;
  background: transparent !important;
  color: var(--saw-text) !important;
  cursor: pointer !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  transition: var(--transition) !important;
  position: relative !important;
  font-size: 14px !important;
}

#saw-calendar-grid .saw-day-cell:hover {
  background: rgba(0,191,255,0.05) !important;
}

#saw-calendar-grid .saw-day-cell.today {
  border-color: rgba(0,191,255,0.18) !important;
}

#saw-calendar-grid .saw-day-cell.selected {
  background: linear-gradient(135deg, rgba(0,191,255,0.16), rgba(0,191,255,0.06)) !important;
  border-color: rgba(0,191,255,0.34) !important;
  box-shadow: 0 0 22px rgba(0,191,255,0.08) !important;
}

#saw-calendar-grid .saw-day-cell.past {
  opacity: 0.45 !important;
}

#saw-calendar-grid .saw-day-cell.blank {
  cursor: default !important;
  pointer-events: none !important;
}

#saw-calendar-grid .saw-day-num {
  font-size: 15px !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  color: var(--saw-text) !important;
}

#saw-calendar-grid .saw-day-cell.today    .saw-day-num,
#saw-calendar-grid .saw-day-cell.selected .saw-day-num {
  color: var(--saw-brand) !important;
  font-weight: 700 !important;
}

#saw-calendar-grid .saw-day-dots {
  display: flex !important;
  gap: 3px !important;
  align-items: center !important;
  min-height: 7px !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  max-width: 38px !important;
}

#saw-calendar-grid .saw-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
}

#saw-calendar-grid .saw-dot-more {
  font-size: 9px !important;
  color: var(--saw-faint) !important;
  font-weight: 700 !important;
  line-height: 1 !important;
}

#saw-calendar-grid .saw-live-dot {
  position: absolute !important;
  top: 5px !important;
  right: 5px !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--saw-live) !important;
  box-shadow: 0 0 8px rgba(255,91,110,0.7) !important;
  animation: saw-pulse 1.4s infinite !important;
}

/* Legend */
#saw-calendar-grid .saw-legend {
  margin-top: 20px !important;
  padding-top: 18px !important;
  border-top: 1px solid var(--saw-border) !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
}

#saw-calendar-grid .saw-legend-item {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  font-size: 12px !important;
  color: var(--saw-muted) !important;
}

#saw-calendar-grid .saw-legend-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
}

/* ============================================================
   11. SESSIONS PANEL
   ============================================================ */

#saw-sessions-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

/* Date header */
#saw-sessions-panel .saw-date-header {
  background: rgba(0,191,255,0.03) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 16px 18px !important;
}

#saw-sessions-panel .saw-date-header h3 {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 8px !important;
  border: none !important;
  padding: 0 !important;
}

#saw-sessions-panel .saw-date-meta {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

#saw-sessions-panel .saw-date-count {
  font-size: 13px !important;
  color: var(--saw-muted) !important;
}

#saw-sessions-panel .saw-today-badge {
  font-size: 10px !important;
  font-weight: 700 !important;
  color: var(--saw-brand) !important;
  background: rgba(0,191,255,0.11) !important;
  border: 1px solid rgba(0,191,255,0.20) !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.10em !important;
}

/* Session card */
#saw-sessions-panel .saw-session-card {
  position: relative !important;
  overflow: hidden !important;
  background: var(--saw-card) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 22px 22px 22px 26px !important;
  backdrop-filter: blur(12px) !important;
  transition: var(--transition) !important;
}

#saw-sessions-panel .saw-session-card:hover {
  border-color: rgba(0,191,255,0.22) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 28px rgba(0,0,0,0.28) !important;
}

#saw-sessions-panel .saw-session-stripe {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 4px !important;
  border-radius: 4px 0 0 4px !important;
}

#saw-sessions-panel .saw-session-top {
  display: flex !important;
  justify-content: space-between !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
}

#saw-sessions-panel .saw-session-left {
  flex: 1 1 260px !important;
  min-width: 220px !important;
}

#saw-sessions-panel .saw-session-meta {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  margin-bottom: 10px !important;
}

#saw-sessions-panel .saw-session-time {
  font-size: 13px !important;
  font-weight: 700 !important;
}

#saw-sessions-panel .saw-session-sep {
  font-size: 12px !important;
  color: var(--saw-faint) !important;
}

#saw-sessions-panel .saw-session-duration,
#saw-sessions-panel .saw-session-type {
  font-size: 12px !important;
  color: var(--saw-faint) !important;
}

#saw-sessions-panel .saw-live-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  color: var(--saw-live) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}

#saw-sessions-panel .saw-live-badge-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--saw-live) !important;
  box-shadow: 0 0 8px rgba(255,91,110,0.65) !important;
  animation: saw-pulse 1.4s infinite !important;
}

#saw-sessions-panel .saw-zoom-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: var(--saw-zoom) !important;
  background: rgba(45,140,255,0.10) !important;
  border: 1px solid rgba(45,140,255,0.20) !important;
  border-radius: 999px !important;
  padding: 3px 8px !important;
}

#saw-sessions-panel .saw-session-title {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: -0.015em !important;
  margin-bottom: 12px !important;
  line-height: 1.3 !important;
}

#saw-sessions-panel .saw-coach {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

#saw-sessions-panel .saw-coach-avatar {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  flex-shrink: 0 !important;
}

#saw-sessions-panel .saw-coach-name {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--saw-text) !important;
  line-height: 1.2 !important;
}

#saw-sessions-panel .saw-coach-specialty {
  font-size: 12px !important;
  color: var(--saw-muted) !important;
  margin-top: 1px !important;
}

#saw-sessions-panel .saw-session-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 10px !important;
  min-width: 160px !important;
}

/* Hide header */
#saw-header {
  display: none !important;
}

#saw-sessions-panel .saw-track-badge {
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 999px !important;
  padding: 5px 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  white-space: nowrap !important;
}

#saw-sessions-panel .saw-track-entry {
  color: var(--saw-green) !important;
  background: rgba(0,229,160,0.10) !important;
  border: 1px solid rgba(0,229,160,0.18) !important;
}

#saw-sessions-panel .saw-track-pro {
  color: var(--saw-purple) !important;
  background: rgba(167,139,250,0.10) !important;
  border: 1px solid rgba(167,139,250,0.18) !important;
}

#saw-sessions-panel .saw-source-zoom {
  font-size: 10px !important;
  color: rgba(45,140,255,0.80) !important;
  font-weight: 600 !important;
}

#saw-sessions-panel .saw-source-static {
  font-size: 10px !important;
  color: var(--saw-faint) !important;
  font-weight: 600 !important;
}

/* Empty state */
#saw-sessions-panel .saw-empty {
  background: rgba(0,191,255,0.02) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 36px 24px !important;
  text-align: center !important;
  color: var(--saw-muted) !important;
  line-height: 1.7 !important;
  font-size: 14px !important;
}

/* Day navigation */
#saw-sessions-panel .saw-day-nav {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  padding-top: 4px !important;
}

/* ============================================================
   12. COUNTDOWN TIMER
   ============================================================ */

#saw-sessions-panel .saw-countdown {
  margin-top: 12px !important;
  padding: 12px 14px !important;
  background: rgba(0,191,255,0.04) !important;
  border: 1px solid rgba(0,191,255,0.12) !important;
  border-radius: 12px !important;
  display: inline-flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

#saw-sessions-panel .saw-countdown-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.10em !important;
  color: var(--saw-faint) !important;
}

#saw-sessions-panel .saw-countdown-inner {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

#saw-sessions-panel .saw-countdown-unit {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 2px !important;
}

#saw-sessions-panel .saw-cd-num {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--saw-brand) !important;
  line-height: 1 !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.02em !important;
}

#saw-sessions-panel .saw-cd-label {
  font-size: 9px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--saw-faint) !important;
}

#saw-sessions-panel .saw-countdown-sep {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--saw-brand) !important;
  margin-bottom: 10px !important;
  opacity: 0.6 !important;
}

/* ============================================================
   13. MEETING LINK BOX
   ============================================================ */

#saw-sessions-panel .saw-meeting-link-box {
  margin-top: 12px !important;
  padding: 10px 14px !important;
  background: rgba(0,191,255,0.04) !important;
  border: 1px solid rgba(0,191,255,0.12) !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

#saw-sessions-panel .saw-meeting-link-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--saw-faint) !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

#saw-sessions-panel .saw-meeting-link-url {
  font-size: 11px !important;
  color: var(--saw-brand) !important;
  word-break: break-all !important;
  font-family: monospace !important;
  text-decoration: underline !important;
  cursor: pointer !important;
  flex: 1 1 200px !important;
}

#saw-sessions-panel .saw-meeting-link-url:hover {
  color: var(--saw-brand-light) !important;
}

/* ============================================================
   14. LOGIN NOTICE & BADGE
   ============================================================ */

#saw-sessions-panel .saw-login-notice {
  font-size: 12px !important;
  color: var(--saw-amber) !important;
  background: rgba(245,158,11,0.08) !important;
  border: 1px solid rgba(245,158,11,0.18) !important;
  border-radius: 999px !important;
  padding: 4px 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
}

#saw-sessions-panel .saw-login-notice a {
  color: var(--saw-amber) !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
}

#saw-header .saw-logged-in-badge {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--saw-green) !important;
  background: rgba(0,229,160,0.10) !important;
  border: 1px solid rgba(0,229,160,0.20) !important;
  border-radius: 999px !important;
  padding: 6px 14px !important;
}

/* ============================================================
   LIFTERLMS LESSON STYLES
   ============================================================ */

/* Section labels */
#saw-sessions-panel .saw-section-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--saw-faint) !important;
  margin-bottom: 8px !important;
  padding-bottom: 6px !important;
  border-bottom: 1px solid var(--saw-border) !important;
}

#saw-sessions-panel .saw-lessons-section,
#saw-sessions-panel .saw-meetings-section {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin-bottom: 12px !important;
}

/* Lesson card */
#saw-sessions-panel .saw-lesson-card {
  position: relative !important;
  overflow: hidden !important;
  background: var(--saw-card) !important;
  border: 1px solid var(--saw-border) !important;
  border-radius: var(--radius-md) !important;
  padding: 16px 16px 16px 20px !important;
  backdrop-filter: blur(12px) !important;
  transition: var(--transition) !important;
}

#saw-sessions-panel .saw-lesson-card:hover {
  border-color: rgba(0,191,255,0.20) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.22) !important;
}

#saw-sessions-panel .saw-lesson-stripe {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 4px !important;
  border-radius: 4px 0 0 4px !important;
  opacity: 0.8 !important;
}

/* Top row — course + badge */
#saw-sessions-panel .saw-lesson-top {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin-bottom: 8px !important;
  flex-wrap: wrap !important;
}

#saw-sessions-panel .saw-lesson-course {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.10em !important;
  color: var(--saw-muted) !important;
}

#saw-sessions-panel .saw-lesson-progress-badge {
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  white-space: nowrap !important;
}

/* Lesson title */
#saw-sessions-panel .saw-lesson-title {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: -0.01em !important;
  line-height: 1.3 !important;
  margin-bottom: 12px !important;
}

/* Open lesson button */
#saw-sessions-panel .saw-lesson-btn {
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* Lesson dot on calendar day cell */
#saw-calendar-grid .saw-lesson-dot {
  position: absolute !important;
  bottom: 5px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 4px !important;
  height: 4px !important;
  border-radius: 50% !important;
  background: var(--saw-green) !important;
  opacity: 0.9 !important;
}

/* ============================================================
   15. ERROR & LOADING STATES
   ============================================================ */

#saw-loading {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 80px 28px !important;
  gap: 16px !important;
  position: relative !important;
  z-index: 2 !important;
  min-height: 300px !important;
}

#saw-loading .saw-spinner {
  width: 40px !important;
  height: 40px !important;
  border: 3px solid rgba(0,191,255,0.15) !important;
  border-top-color: var(--saw-brand) !important;
  border-radius: 50% !important;
  animation: saw-spin 0.8s linear infinite !important;
}

#saw-loading .saw-loading-text {
  color: var(--saw-muted) !important;
  font-size: 14px !important;
}

#saw-calendar-root .saw-error {
  background: rgba(251,113,133,0.06) !important;
  border: 1px solid rgba(251,113,133,0.18) !important;
  border-radius: var(--radius-md) !important;
  padding: 16px 20px !important;
  color: var(--saw-red) !important;
  font-size: 13px !important;
  text-align: center !important;
}

/* ============================================================
   13. ANIMATIONS
   ============================================================ */

@keyframes saw-spin {
  to { transform: rotate(360deg); }
}

@keyframes saw-pulse {
  0%, 100% { opacity: 1;   transform: scale(1);    }
  50%       { opacity: 0.6; transform: scale(1.25); }
}

@keyframes saw-fadeup {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0);    }
}

#saw-calendar-root .saw-fadein {
  animation: saw-fadeup 0.35s ease both !important;
}

/* ============================================================
   14. RESPONSIVE
   ============================================================ */

@media (max-width: 1050px) {
  #saw-main {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 700px) {
  #saw-header,
  #saw-filters,
  #saw-main {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  #saw-calendar-grid .saw-cal-header h3 {
    font-size: 20px !important;
  }

  #saw-sessions-panel .saw-session-card {
    padding: 16px 16px 16px 20px !important;
  }

  #saw-sessions-panel .saw-session-title {
    font-size: 15px !important;
  }

  #saw-sessions-panel .saw-session-right {
    flex-direction: row !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    min-width: unset !important;
    width: 100% !important;
  }

  #saw-sessions-panel .saw-day-nav .saw-btn {
    font-size: 12px !important;
    padding: 8px 12px !important;
  }
}