/* ========================================
   CONSOLIDATED MAIN CSS FILE
   ======================================== */

/* Global Variables (extends header.css variables) */
:root {
    --ink:#0f172a; --muted:#64748b;
    --soft:#eef2ff; --accentA:#7c3aed; --accentB:#2563eb;
    --softBg:linear-gradient(135deg,#f6f8ff, #f8fafc);
    --orange-primary: #ff6b35;
    --orange-dark: #e55a2b;
    --orange-light: #ff8c5a;
    --orange-gradient: linear-gradient(135deg, var(--orange-primary), var(--orange-dark));
    --orange-subtle: rgba(255, 107, 53, 0.15);
    --primary-color: #4a6fff;
    --secondary-color: #7c3aed;
    --success-color: #10b981;
    --warning-color: #f59e0b;
}

/* Dark Mode Variables */
[data-theme="dark"] {
    --soft: #1e293b;
    --softBg: linear-gradient(135deg, #1e293b, #334155);
    --orange-subtle: rgba(255, 107, 53, 0.2);
}

/* ========================================
   GLOBAL UTILITIES
   ======================================== */

.text-gradient{background:linear-gradient(135deg,var(--accentA),var(--accentB));-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-text{ background:linear-gradient(135deg,var(--accentA),var(--accentB)); -webkit-background-clip:text; background-clip:text; color:transparent }
.bg-soft{background:#f3f6ff;color:#334155;border:1px solid #e5e7eb}
.btn-gradient{background:linear-gradient(135deg,var(--accentA),var(--accentB));color:#fff;border:0}
.btn-gradient:hover{filter:brightness(.96);color:#fff}
.object-fit-cover{ object-fit:cover }
.flex-shrink-0 { flex-shrink: 0; }
.min-vh-85{ min-height:85vh; }

/* Orange Theme Colors */
.orange-grad-text {
  background: var(--orange-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 800;
}
.text-white-90 { color: rgba(255, 255, 255, 0.9) !important; }
.text-orange { color: var(--orange-primary) !important; }
.bg-orange-subtle { background: var(--orange-subtle) !important; }
.bg-orange-gradient { background: var(--orange-gradient) !important; }

/* ========================================
   INDEX PAGE HERO SECTION
   ======================================== */

.hero-section{
  position: relative;
  padding: 6rem 0 4rem;
  background-image: url('../images/roma.jpeg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  isolation: isolate;
  padding: 4rem 0 3rem;
}

.hero-section::before{
  content:"";
  position:absolute; inset:0;
  z-index: 0;
  background:
    linear-gradient(to bottom,
      rgba(255,255,255,0.80) 0%,
      rgba(255,255,255,0.70) 35%,
      rgba(255,255,255,0.62) 100%);
  backdrop-filter: saturate(120%) blur(0.5px);
}

.hero-background,
.hero-bg{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(820px 300px at -10% -30%, rgba(124,58,237,.10), transparent 70%),
    radial-gradient(760px 260px at 120% -20%, rgba(37,99,235,.12), transparent 70%);
}

.hero-section .container{ position: relative; z-index: 2; }

.hero-title{ font-weight:800; letter-spacing:.2px; color:var(--orange-primary); }
.hero-subtitle{ color:#334155; text-shadow: 0 1px 0 rgba(255,255,255,.35); }
.hero-info-card{
  background:rgba(255,255,255,.88);
  border:1px solid #e5e7eb; border-radius:14px; padding:1rem 1.1rem;
  box-shadow:0 10px 30px rgba(15,23,42,.06);
}
.hero-info-card i{ font-size:1.25rem; margin-right:.5rem }

.scroll-indicator{ font-size:1.75rem; color:var(--accentB) }
.scroll-indicator i{ animation:bounce 1.8s infinite }
@keyframes bounce{
  0%,20%,50%,80%,100%{ transform:translateY(0) }
  40%{ transform:translateY(-8px) }
  60%{ transform:translateY(-4px) }
}

/* ========================================
   ABOUT PREVIEW SECTION
   ======================================== */

.about-preview {
    background: linear-gradient(135deg, #f8fafc 0%, #f0f4ff 100%);
}

[data-theme="dark"] .about-preview {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
}

.about-content {
    padding-right: 2rem;
}

.about-content p {
    line-height: 1.7;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.about-content .lead {
    font-size: 1.15rem;
    font-weight: 500;
    color: var(--text-primary);
}

.key-highlights {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 1.5rem;
    box-shadow: 0 2px 8px var(--shadow-color);
}

.highlight-title {
    color: var(--primary-color);
    font-weight: 700;
    font-size: 1.1rem;
}

.key-highlights .small {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.learning-outcomes {
    background: linear-gradient(135deg, #f0fdf4, #ffffff);
    border: 1px solid #d1fae5;
    border-radius: 12px;
    padding: 1.5rem;
    border-left: 4px solid var(--success-color);
}

.outcome-title {
    color: var(--success-color);
    font-weight: 700;
    font-size: 1.1rem;
}

/* ========================================
   SPEAKERS PAGE STYLES
   ======================================== */

/* Page Header */
main .page-header{ 
  padding: 2.5rem 0 1.5rem; 
  background:linear-gradient(135deg,#f8faff, #f6f9ff); 
  color: var(--text-primary);
}

[data-theme="dark"] main .page-header {
  background: linear-gradient(135deg, var(--bg-secondary), var(--bg-tertiary));
}

[data-theme="dark"] .page-content {
  background: var(--bg-primary);
  color: var(--text-primary);
}

.hero-title{ 
  font-weight:800; 
  letter-spacing:.2px; 
  color:var(--orange-primary); 
}

.hero-subtitle {
  color: var(--text-secondary);
}

.section-title{ 
  font-weight:800; 

  padding-left:.6rem; 
  margin-bottom:1rem; 
  color: var(--orange-primary); 
}

.orange-divider{ 
  height:4px; 
  border:0; 
  background:linear-gradient(90deg,#f59e0b,#fb923c); 
  border-radius:4px; 
  margin:1.5rem 0 0; 
}

/* Person Cards */
.person-link{ text-decoration:none; color:inherit; }
.person-card{ 
  border:1px solid var(--border-color); 
  border-radius:14px; 
  overflow:hidden; 
  transition:transform .15s ease, box-shadow .15s ease; 
  background: var(--card-bg);
  color: var(--text-primary);
}
.person-card:hover{ 
  transform:translateY(-4px); 
  box-shadow:0 16px 36px var(--shadow-color); 
}
.person-img-wrapper{ background: var(--bg-secondary); position:relative; }
.person-img{ width:100%; height:100%; object-fit:cover; display:block; }
.shine{ 
  position:absolute; 
  inset:auto -50% 0 -50%; 
  height:60%; 
  background:linear-gradient(180deg,rgba(255,255,255,.0),rgba(255,255,255,.45),rgba(255,255,255,.0)); 
  transform:translateY(40%); 
  filter:blur(10px); 
  pointer-events:none; 
}
.card-body h6{ color: var(--text-primary); }
.card-body p{ color: var(--text-secondary); }

/* Toolbar */
.toolbar{ 
  display:flex; 
  gap:.75rem; 
  align-items:center; 
  justify-content:space-between; 
  margin-bottom:1rem; 
  flex-wrap:wrap; 
}
.toolbar .form-control{ max-width:320px; }

/* Speaker Section Specific */
.speakers-section {
    background: var(--bg-primary);
    color: var(--text-primary);
}

.speakers-section .section-title{
    color:var(--orange-primary); 
    font-weight:800; 
    letter-spacing:.2px;
    border-bottom:2px solid var(--orange-primary); 
    display:inline-block; 
    padding-bottom:.35rem;
    padding-left: 0; /* Override the general section-title */
}

.speakers-section .text-muted {
    color: var(--text-secondary) !important;
}

.speaker-card{ 
  border:0; 
  border-radius:14px; 
  overflow:hidden; 
  transition:transform .16s ease, box-shadow .16s ease; 
}
.speaker-card:hover{ 
  transform:translateY(-4px); 
  box-shadow:0 16px 36px rgba(0,0,0,.12); 
}
.speaker-image{ background: var(--bg-secondary); }
.speaker-name{ font-weight:700; margin-bottom:.25rem; color: var(--text-primary); }
.speaker-affiliation{ color: var(--text-secondary); font-size:.9rem; margin-bottom:0; }
.speaker-badge{
  position:absolute; 
  left:.5rem; 
  top:.5rem; 
  background: var(--card-bg);
  color: var(--text-primary); 
  font-weight:700; 
  border-radius:999px; 
  padding:.2rem .5rem; 
  font-size:.72rem; 
  border:1px solid var(--border-color);
}
.company-logo{
  height: 24px; 
  max-width: 80px; 
  object-fit: contain; 
  opacity: 0.7; 
  transition: opacity .2s ease; 
  filter: grayscale(30%);
}
.speaker-card:hover .company-logo{ opacity: 1; filter: grayscale(0%); }

/* Speakers Page Mobile Responsive */
@media (max-width:576px){
  main .page-header{ padding: 2rem 0 1rem; }
}

/* ========================================
   LOGO SLIDERS (SHARED)
   ======================================== */

.logo-slider-container {
  overflow: hidden;
  border-radius: 16px;
  background: var(--card-bg);
  box-shadow: 0 4px 12px var(--shadow-color);
  padding: 2rem 0;
  margin-bottom: 1.5rem;
  border: 1px solid var(--border-color);
}

.logo-slider {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.logo-track {
  display: flex;
  align-items: center;
  gap: 3rem;
  width: max-content;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

.slider-ltr .logo-track {
  animation: slideLeftToRight 30s linear infinite;
}

.slider-rtl .logo-track {
  animation: slideRightToLeft 25s linear infinite;
}

.logo-item {
  height: 60px;
  width: auto;
  max-width: 150px;
  object-fit: contain;
  opacity: 0.8;
  transition: opacity 0.3s ease, transform 0.3s ease;
  filter: grayscale(20%);
  flex-shrink: 0;
}

.logo-item:hover {
  opacity: 1;
  transform: scale(1.1);
  filter: grayscale(0%);
}

/* Logo Slider Animations */
@keyframes slideLeftToRight {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0%);
  }
}

@keyframes slideRightToLeft {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}

.logo-slider:hover .logo-track {
  animation-play-state: paused;
}

/* ========================================
   SHARED COMPONENTS
   ======================================== */

/* Section Titles */
.section-title {
    color: var(--orange-primary);
    font-weight: 800;
    font-size: clamp(2rem, 4vw, 2.5rem);
    border-bottom: 3px solid var(--orange-primary);
    padding-bottom: 0.5rem;
    display: inline-block;
}

/* Stats Components */
.value-list li{ margin:.25rem 0; color:var(--muted) }
.value-list i{ color:var(--orange-primary); margin-right:.5rem }
.stat-card{ background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:1rem; box-shadow:0 6px 18px rgba(15,23,42,.06) }
.stat-number{ font-size:2rem; font-weight:800; line-height:1 }
.stat-label{ font-size:.9rem; color:var(--muted) }

.stats-card {
    background: var(--card-bg);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid var(--border-color);
}

.stats-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px var(--shadow-color) !important;
}

.stat-item {
    padding: 0.5rem;
}

.stat-number {
    font-size: clamp(1.5rem, 3vw, 1.75rem);
    line-height: 1;
    margin-bottom: 0.25rem;
}

.stat-label {
    font-size: 0.8rem;
    color: var(--text-muted);
    font-weight: 500;
}

/* CTA Components */
.cta-card{
  background:linear-gradient(135deg, #f0fdf4, #ffffff);
  backdrop-filter:saturate(1.1) blur(2px);
  border-radius:16px; overflow:hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.cta-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px rgba(74, 111, 255, 0.4);
}

.cta-card-orange {
  background: linear-gradient(135deg,rgb(255, 255, 255), #fefce8);
  border: 1px solid #fed7aa;
  border-radius: 16px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

[data-theme="dark"] .cta-card-orange {
  background: linear-gradient(135deg, var(--card-bg), var(--bg-secondary));
  border: 1px solid var(--border-color);
}

[data-theme="dark"] .cta-card-orange .text-dark {
  color: var(--text-primary) !important;
}

.cta-card-orange:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

/* Orange Buttons */
.btn-orange-cta {
  background: var(--orange-gradient);
  color: white;
  font-weight: 700;
  border: none;
  border-radius: 12px;
  padding: 0.9rem 1.5rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3);
}

.btn-orange-cta:hover {
  background: linear-gradient(135deg, #d97706, #ea580c);
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(245, 158, 11, 0.4);
}

.btn-outline-orange {
  border: 2px solid var(--orange-primary);
  color: var(--orange-primary);
  background: transparent;
  border-radius: 12px;
  padding: 0.9rem 1.5rem;
  font-weight: 600;
  transition: all 0.3s ease;
}

.btn-outline-orange:hover {
  background: var(--orange-primary);
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3);
}

/* Orange Countdown Components */
.cd-box-orange {
  width: 32%;
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.2);
  border-radius: 10px;
  padding: 0.5rem;
}

.cd-num-orange {
  font-weight: 800;
  font-size: 1.6rem;
  line-height: 1;
  color: var(--orange-primary);
}

.cd-label-orange {
  font-size: 0.8rem;
  color: #64748b;
}

/* Orange Sticky CTA */
.cta-sticky-orange {
  position: sticky;
  bottom: 12px;
  padding: 0.5rem 0;
  background: rgba(31, 41, 55, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 12px;
  margin: 0 10px;
  z-index: 1000;
  border: 1px solid rgba(245, 158, 11, 0.3);
}

/* Orange Icon Colors */
.bi-tools.text-orange,
.bi-cpu.text-orange,
.bi-award.text-orange,
.bi-hourglass-split.text-orange,
.bi-people.text-orange {
  color: var(--orange-primary) !important;
}

/* ========================================
   RESPONSIVE DESIGN
   ======================================== */

/* Tablet */
@media (max-width: 992px) {
    .about-preview {
        padding: 3rem 0;
    }
    
    .side-content {
        gap: 1.5rem;
    }
    
    .stats-section,
    .image-section,
    .cta-section {
        margin-bottom: 0.25rem !important;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .hero-subtitle{ font-size:1.25rem }
    
    .about-preview {
        padding: 2rem 0;
    }
    
    .about-content p {
        text-align: left;
        font-size: 1rem;
    }
    
    .about-content .lead {
        font-size: 1.1rem;
        text-align: left;
    }
    
    .key-highlights,
    .learning-outcomes {
        margin: 1rem 0;
        padding: 1.25rem;
    }
    
    .stat-number {
        font-size: 1.5rem;
    }
    
    .cta-card-orange {
        margin: 0 1rem;
    }
    
    .cd-num-orange {
        font-size: 1.4rem;
    }
    
    .btn-orange-cta,
    .btn-outline-orange {
        padding: 0.75rem 1rem;
        font-size: 0.9rem;
    }

    /* Logo Slider Mobile */
    .logo-item {
        height: 45px;
        max-width: 120px;
    }
    
    .logo-track {
        gap: 2rem;
    }
    
    .slider-ltr .logo-track {
        animation-duration: 20s;
    }
    
    .slider-rtl .logo-track {
        animation-duration: 18s;
    }
}

/* Small Mobile */
@media (max-width: 576px) {
    .section-title {
        font-size: 1.75rem;
    }
    
    .key-highlights .row {
        gap: 0.5rem;
    }
    
    .key-highlights .col-sm-6 {
        flex: 0 0 100%;
        max-width: 100%;
    }
    
    .stats-card .row {
        gap: 0.5rem;
    }
    
    .stats-card .col-6 {
        flex: 0 0 calc(50% - 0.25rem);
        max-width: calc(50% - 0.25rem);
    }

    /* Logo Slider Small Mobile */
    .logo-slider-container {
        padding: 1.5rem 0;
    }
    
    .logo-item {
        height: 35px;
        max-width: 100px;
    }
    
    .logo-track {
        gap: 1.5rem;
    }
}

/* ========================================
   ACCESSIBILITY & MOTION
   ======================================== */

@media (prefers-reduced-motion: reduce){
    .speaker-card,.btn-cta{ transition:none }
    .scroll-indicator i{ animation:none }
    
    /* Logo Slider Reduced Motion */
    .logo-track {
        animation: none;
    }
    
    .logo-slider {
        justify-content: center;
        display: flex;
    }
    
    .logo-track {
        justify-content: center;
        flex-wrap: wrap;
    }
}

/* Dark Mode Specific Styles */
[data-theme="dark"] .speaker-image { 
    background: var(--bg-secondary); 
}

[data-theme="dark"] .speaker-badge { 
    background: rgba(11,18,32,.92); 
    color: var(--text-primary); 
    border-color: var(--border-color); 
}

[data-theme="dark"] .hero-section::before {
    background: linear-gradient(to bottom,
        rgba(15, 23, 42, 0.80) 0%,
        rgba(15, 23, 42, 0.70) 35%,
        rgba(15, 23, 42, 0.62) 100%);
}

[data-theme="dark"] .hero-info-card {
    background: rgba(30, 41, 59, 0.88);
    border-color: var(--border-color);
    color: var(--text-primary);
}

[data-theme="dark"] .hero-subtitle {
    color: var(--text-secondary);
}

[data-theme="dark"] .learning-outcomes {
    background: linear-gradient(135deg, var(--bg-secondary), var(--card-bg));
    border-color: var(--border-color);
}

[data-theme="dark"] .cta-card {
    background: linear-gradient(135deg, var(--bg-secondary), var(--card-bg));
}

[data-theme="dark"] .section-title {
    color: var(--orange-primary);
}

/* Logo Sliders Section Dark Mode */
[data-theme="dark"] section[style*="background: linear-gradient(135deg, #f8fafc 0%, #f0f4ff 100%)"] {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%) !important;
    color: var(--text-primary);
}

[data-theme="dark"] .text-muted {
    color: var(--text-secondary) !important;
}

/* Main body and page backgrounds */
[data-theme="dark"] main {
    background: var(--bg-primary);
    color: var(--text-primary);
}

[data-theme="dark"] body {
    background: var(--bg-primary);
    color: var(--text-primary);
}

[data-theme="dark"] .container {
    color: var(--text-primary);
}

/* Badge components */
[data-theme="dark"] .badge {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border-color) !important;
}

[data-theme="dark"] .badge.bg-white {
    background: var(--card-bg) !important;
    color: var(--text-primary) !important;
}

/* Lists and other text elements */
[data-theme="dark"] ul, 
[data-theme="dark"] ol, 
[data-theme="dark"] li {
    color: var(--text-primary);
}

[data-theme="dark"] h1, 
[data-theme="dark"] h2, 
[data-theme="dark"] h3, 
[data-theme="dark"] h4, 
[data-theme="dark"] h5, 
[data-theme="dark"] h6 {
    color: var(--text-primary);
}

[data-theme="dark"] p {
    color: var(--text-primary);
}

[data-theme="dark"] span {
    color: inherit;
}

/* Form elements */
[data-theme="dark"] .form-control {
    background: var(--card-bg);
    border-color: var(--border-color);
    color: var(--text-primary);
}

[data-theme="dark"] .form-control:focus {
    background: var(--card-bg);
    border-color: var(--orange-primary);
    color: var(--text-primary);
    box-shadow: 0 0 0 0.2rem rgba(255, 107, 53, 0.25);
}

/* Progress bars */
[data-theme="dark"] .progress {
    background: var(--bg-secondary);
}

/* Buttons */
[data-theme="dark"] .btn-outline-secondary {
    color: var(--text-primary);
    border-color: var(--border-color);
}

[data-theme="dark"] .btn-outline-secondary:hover {
    background: var(--bg-secondary);
    border-color: var(--orange-primary);
    color: var(--orange-primary);
}

/* Small text elements */
[data-theme="dark"] small {
    color: var(--text-secondary);
}

[data-theme="dark"] .small {
    color: var(--text-secondary);
}

/* Fix any remaining hardcoded backgrounds */
[data-theme="dark"] section {
    background: var(--bg-primary) !important;
    color: var(--text-primary);
}

/* Override any inline styles that may conflict */
[data-theme="dark"] [style*="background"] {
    background: var(--bg-primary) !important;
}

[data-theme="dark"] [style*="color: #"] {
    color: var(--text-primary) !important;
}

/* Specific fixes for hardcoded elements */
[data-theme="dark"] .text-dark {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .bg-white {
    background: var(--card-bg) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .border {
    border-color: var(--border-color) !important;
}

/* Links */
[data-theme="dark"] a {
    color: var(--orange-primary);
}

[data-theme="dark"] a:hover {
    color: var(--orange-light);
}

@media (prefers-color-scheme: dark){
    .speaker-image{ background: var(--bg-secondary); }
    .speaker-badge{ background:rgba(11,18,32,.92); color: var(--text-primary); border-color: var(--border-color); }
}

/* ========================================
   ANIMATIONS
   ======================================== */

[data-aos] {
    transition: all 0.6s ease;
}

.stats-card,
.cta-card {
    animation: fadeInUp 0.8s ease-out;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ========================================
   PROGRAM PAGE STYLES
   ======================================== */

/* Program Variables */
.program-page {
  --nav-offset: 84px;
  --green-head: #0f5132;
  --green-border: #0a3622;
}

/* Sticky footer layout */
html, body { height: 100%; }
body { background: #fff; display: flex; flex-direction: column; min-height: 100vh; }
main { flex: 1 0 auto; }

/* Program Page Header */
.program-page .page-header {
  background: linear-gradient(rgba(255,255,255,.92), rgba(255,255,255,.92));
  padding: calc(4rem + var(--nav-offset)) 0 2rem;
}

/* Program table (green header, sticky) */
.program-table thead tr { background: var(--green-head); color: #fff; }
.program-table thead th {
  border-color: var(--green-border);
  position: sticky;
  top: 0;
  z-index: 1;
}
.program-table td, .program-table th { 
  vertical-align: middle; 
  color: var(--text-primary);
  border-color: var(--border-color);
}
.program-table tbody tr:hover { background: var(--bg-secondary); }

/* Dark Mode Program Table */
[data-theme="dark"] .program-table {
  background: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .program-table thead tr {
  background: var(--orange-primary);
  color: #ffffff;
}

[data-theme="dark"] .program-table thead th {
  border-color: var(--orange-dark);
  background: var(--orange-primary);
}

[data-theme="dark"] .program-table tbody tr {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .program-table tbody tr:hover {
  background: var(--bg-secondary);
}

[data-theme="dark"] .program-table td {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table {
  color: var(--text-primary);
  background: var(--card-bg);
}

[data-theme="dark"] .table th {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .table td {
  color: var(--text-primary);
  border-color: var(--border-color);
}

/* Comprehensive program.php table fixes */
[data-theme="dark"] .full-program-table {
  background: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .full-program-table th,
[data-theme="dark"] .full-program-table td {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .full-program-table thead {
  background: var(--orange-primary);
  color: #ffffff;
}

[data-theme="dark"] .full-program-table thead th {
  color: #ffffff;
  border-color: var(--orange-dark);
}

[data-theme="dark"] .table-responsive {
  background: var(--card-bg);
}

[data-theme="dark"] .table-wrap {
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 8px;
}

[data-theme="dark"] .table-hover tbody tr:hover {
  background: var(--bg-secondary);
}

/* Utility row meta */
.slot-title { font-weight: 600; color: var(--text-primary); }
.slot-meta { color: var(--text-secondary); font-size: .925rem; }
.slot-badge { 
  border: 1px solid var(--border-color); 
  background: var(--card-bg); 
  color: var(--text-primary);
  border-radius: 999px; 
  padding: .1rem .5rem; 
  font-size: .75rem; 
}

/* Program Toolbar */
.program-page .toolbar { 
  display: flex; 
  flex-wrap: wrap; 
  gap: .5rem; 
  align-items: center; 
  justify-content: space-between; 
  margin: .25rem 0 1rem; 
}
.program-page .toolbar .form-control { max-width: 280px; }
.program-page .toolbar .filters { display: flex; gap: .5rem; flex-wrap: wrap; }

/* Program Day Tabs */
.day-tabs .nav-link { border-radius: 999px; }
.day-tabs .nav-link.active { background: var(--orange-primary); }

/* Mobile cards (fallback view) */
@media(max-width: 575.98px) {
  .table-wrap { display: none; }
  .card-list { display: grid; gap: .75rem; }
}
@media(min-width: 576px) {
  .card-list { display: none; }
}

/* Full Program Styles */
.full-program-table {
  margin-top: 1rem;
}
.full-program-table .day-cell {
  border-left: 4px solid var(--orange-primary);
  vertical-align: top;
  padding: 1rem 0.75rem;
  background: rgba(255,107,53,.02);
  color: var(--text-primary);
}
.full-program-table .day-cell:not(.day-header) {
  border-left: 4px solid transparent;
  background: transparent;
  padding: 0.75rem;
  color: var(--text-primary);
}

[data-theme="dark"] .full-program-table .day-cell {
  background: rgba(255,107,53,.1);
  color: var(--text-primary);
}

[data-theme="dark"] .full-program-table .day-cell:not(.day-header) {
  background: var(--bg-primary);
  color: var(--text-primary);
}
.day-info {
  text-align: center;
  min-width: 80px;
}
.day-name {
  font-weight: 700;
  color: var(--orange-primary);
  font-size: 0.9rem;
  line-height: 1.2;
}

/* Day tabs dark mode */
[data-theme="dark"] .day-tabs .nav-link {
  color: var(--text-secondary);
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .day-tabs .nav-link:hover {
  color: var(--orange-primary);
  background: var(--bg-secondary);
}

[data-theme="dark"] .day-tabs .nav-link.active {
  color: var(--orange-primary);
  background: var(--card-bg);
  border-color: var(--orange-primary);
}
.day-date {
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin-top: 0.25rem;
}
.time-cell {
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
}
.session-cell {
  padding-right: 1rem;
  color: var(--text-primary);
}
.speaker-cell {
  color: var(--text-secondary);
  font-size: 0.95rem;
}

/* Full Program Mobile View */
.full-program-mobile {
  display: none;
}
.day-section-header {
  background: linear-gradient(135deg, var(--orange-primary), var(--orange-dark));
  color: white;
  padding: 1rem 1.5rem;
  border-radius: 12px 12px 0 0;
  margin-bottom: 0;
}
.day-section-title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 700;
}
.day-section .card:first-of-type {
  border-radius: 0;
  border-top: none;
}
.day-section .card:last-of-type {
  border-radius: 0 0 12px 12px;
}
.day-section .card {
  border-radius: 0;
  border-top: 1px solid #e9ecef;
  margin-bottom: 0 !important;
}

/* Enhanced Day Tabs */
.day-tabs .nav-link {
  border-radius: 25px;
  padding: 0.6rem 1.2rem;
  font-weight: 600;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}
.day-tabs .nav-link:hover {
  background: rgba(255,107,53,.1);
  border-color: rgba(255,107,53,.3);
}
.day-tabs .nav-link.active {
  background: var(--orange-primary);
  border-color: var(--orange-primary);
  color: white;
  box-shadow: 0 4px 12px rgba(255,107,53,.3);
}
.day-tabs .nav-link i {
  color: inherit;
}

/* Responsive Full Program */
@media (max-width: 991.98px) {
  .full-program-table .day-cell,
  .full-program-table .time-cell {
    font-size: 0.85rem;
  }
  .day-name {
    font-size: 0.8rem;
  }
  .day-date {
    font-size: 0.75rem;
  }
}

@media (max-width: 767.98px) {
  .full-program-table {
    display: none;
  }
  .full-program-mobile {
    display: block !important;
  }
  .day-tabs .nav-link {
    padding: 0.5rem 0.8rem;
    font-size: 0.85rem;
  }
  .day-tabs .nav-link i {
    margin-right: 0.25rem !important;
  }
}

@media (max-width: 575.98px) {
  .day-tabs {
    flex-wrap: wrap;
    gap: 0.25rem;
  }
  .day-tabs .nav-item {
    flex: 0 0 auto;
    margin-bottom: 0.25rem;
  }
  .day-tabs .nav-link {
    padding: 0.4rem 0.7rem;
    font-size: 0.8rem;
  }
}

/* Program Print Styles */
@media print {
  .program-page .page-header, 
  .program-page .toolbar, 
  .day-tabs, 
  .download-btns { display: none !important; }
  .program-page .section-title { margin-top: 0; }
  .program-table thead th { position: static; }
  .full-program-table .day-cell {
    background: transparent !important;
    border-left: 2px solid #333 !important;
  }
}

/* ========================================
   DATES PAGE STYLES
   ======================================== */

/* Dates Variables */
.dates-page {
  --nav-offset: 84px;
  --ring: 0 0 0 .25rem rgba(255,107,53,.18);
  --shadow: 0 14px 36px rgba(2,6,23,.10);
  --card-grad: linear-gradient(180deg,rgba(255,107,53,.09),rgba(255,107,53,.04));
}

/* Sticky footer layout for dates page */
.dates-page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--bg-primary);
  color: var(--text-primary);
}
.dates-page main { flex: 1 0 auto; }
.pre-footer-space { height: 72px; }

/* Dark mode dates page */
[data-theme="dark"] .dates-page {
  background: var(--bg-primary);
  color: var(--text-primary);
}

/* Dark mode glance cards and other dates components */
[data-theme="dark"] .glance-card {
  background: var(--card-bg);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
}

[data-theme="dark"] .glance-icon {
  color: var(--orange-primary);
}

[data-theme="dark"] .stat-num {
  color: var(--text-primary);
}

[data-theme="dark"] .stat-label {
  color: var(--text-secondary);
}

[data-theme="dark"] .nav-pills .nav-link {
  background: var(--card-bg);
  color: var(--text-secondary);
  border: 1px solid var(--border-color);
}

[data-theme="dark"] .nav-pills .nav-link:hover {
  background: var(--bg-secondary);
  color: var(--orange-primary);
}

[data-theme="dark"] .nav-pills .nav-link.active {
  background: var(--orange-primary);
  color: #ffffff;
}

[data-theme="dark"] .page-content {
  background: var(--bg-primary);
  color: var(--text-primary);
}

/* Additional fixes for dates.php important note and info sections */
[data-theme="dark"] .bi-info-circle-fill {
  color: var(--orange-primary) !important;
}

[data-theme="dark"] .text-primary {
  color: var(--orange-primary) !important;
}

/* Dates Page Header with orbs */
.dates-page .page-header {
  position: relative;
  overflow: hidden;
  padding: calc(3.25rem + var(--nav-offset)) 0 2rem;
  background:
    radial-gradient(900px 360px at 10% -10%, rgba(255,107,53,.18), transparent 60%),
    radial-gradient(900px 360px at 90% -15%, rgba(229,90,43,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.96));
}

[data-theme="dark"] .dates-page .page-header {
  background:
    radial-gradient(900px 360px at 10% -10%, rgba(255,107,53,.25), transparent 60%),
    radial-gradient(900px 360px at 90% -15%, rgba(229,90,43,.18), transparent 60%),
    linear-gradient(180deg, var(--bg-secondary), var(--bg-tertiary));
}
.dates-page .page-header:after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(0,0,0,.06) 1px, transparent 1px);
  background-size: 18px 18px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 65%);
}
.orb { position: absolute; border-radius: 50%; opacity: .35; pointer-events: none; }
.orb.o1 {
  width: 220px;
  height: 220px;
  left: -60px;
  top: -70px;
  background: radial-gradient(circle at 30% 30%, #ffd0c0, #ffc2aa);
  animation: floatY 9s ease-in-out infinite;
}
.orb.o2 {
  width: 260px;
  height: 260px;
  right: -80px;
  top: -90px;
  background: radial-gradient(circle at 40% 40%, #ffd6c9, #ffb69a);
  animation: floatY 12s ease-in-out infinite reverse;
}
@keyframes floatY { 0%,100% { transform: translateY(0); } 50% { transform: translateY(18px); } }

/* Scroll progress bar */
.scroll-progress {
  position: sticky;
  top: 0;
  z-index: 1031;
  height: 4px;
  background: transparent;
}
.scroll-progress .bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--orange-primary), var(--orange-dark));
  box-shadow: 0 0 12px rgba(229,90,43,.35);
  transition: width .15s ease-out;
}

/* Section pills (sticky navigation) */
.section-nav {
  position: sticky;
  top: calc(var(--nav-offset) + .5rem);
  z-index: 1020;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 999px;
  padding: .4rem;
  box-shadow: var(--shadow);
  backdrop-filter: saturate(140%) blur(6px);
}
.section-nav .nav-link { border-radius: 999px; transition: all .2s; }
.section-nav .nav-link.active { background: var(--orange-primary); color: #fff; }
.section-nav .nav-link:hover { background: rgba(255,107,53,.08); }

/* Wave divider */
.header-wave { display: block; width: 100%; height: 64px; margin-top: .5rem; }

/* Content Cards */
.content-card {
  position: relative;
  background: #fff;
  border-radius: 16px;
  padding: 1.6rem;
  box-shadow: var(--shadow);
  border: 1px solid #eee;
}
.content-card:before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 16px;
  padding: 1px;
  background: var(--card-grad);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}
@media (min-width:768px) { .content-card { padding: 2rem; } }

/* Simple Steps Section */
.dates-page #steps {
  padding: 4rem 0;
  background: linear-gradient(135deg, #f8fafc 0%, #f0f4ff 100%);
  margin: 0 !important;
}
.dates-page #steps .section-title {
  position: relative;
  display: inline-block;
  margin: 0 auto 3rem;
  padding-bottom: 1rem;
  border-bottom: 3px solid var(--orange-primary);
}
.dates-page #steps .section-title::after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 3px;
  background: var(--orange-dark);
  border-radius: 2px;
}

/* Steps Timeline */
.steps {
  list-style: none;
  padding-left: 0;
  margin: 0;
  position: relative;
  max-width: 800px;
  margin: 0 auto;
}
.steps::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--orange-primary), var(--orange-dark));
  border-radius: 2px;
  box-shadow: 0 0 10px rgba(255,107,53,.3);
}
.steps li {
  position: relative;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: 1.5rem 1.25rem 1.5rem 3.5rem;
  border-radius: 16px;
  background: #fff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 8px 25px rgba(2,6,23,.08);
  margin-bottom: 1.5rem;
  transition: transform .2s ease, box-shadow .2s ease;
}
.steps li:hover { 
  transform: translateY(-3px); 
  box-shadow: 0 16px 40px rgba(2,6,23,.12);
}
.steps li.emphasis {
  border: 2px solid var(--orange-primary);
  background: linear-gradient(135deg, rgba(255,107,53,.02), rgba(255,255,255,1));
}
.steps li .icon {
  position: absolute;
  left: 1rem;
  top: 1.5rem;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg,var(--orange-primary),var(--orange-dark));
  color: #fff;
  box-shadow: 0 6px 20px rgba(229,90,43,.4);
  z-index: 2;
  border: 3px solid #fff;
}
.steps li .icon i {
  font-size: 1.1rem;
}
.steps h5 { 
  margin: 0 0 .5rem; 
  font-weight: 800; 
  color: var(--ink);
  font-size: 1.2rem;
}
.steps p { 
  margin: 0; 
  color: #64748b;
  line-height: 1.6;
}
.timeline-progress {
  position: absolute;
  left: 23px;
  top: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--orange-light), var(--orange-primary));
  transform-origin: top;
  height: 0;
  border-radius: 2px;
  z-index: 1;
  box-shadow: 0 0 15px rgba(255,107,53,.5);
}

/* Enhanced Attendance Cards */
.attendance-card {
  background: var(--card-bg);
  color: var(--text-primary);
  border-radius: 20px;
  padding: 2rem;
  height: 100%;
  box-shadow: 0 10px 30px rgba(2,6,23,.08);
  border: 2px solid transparent;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  position: relative;
  overflow: hidden;
}

[data-theme="dark"] .attendance-card {
  background: var(--card-bg);
  color: var(--text-primary);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.attendance-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--orange-primary), var(--orange-dark));
}
.attendance-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 40px rgba(2,6,23,.15);
  border-color: var(--orange-primary);
}
.attendance-card.in-person {
  background: linear-gradient(135deg, var(--card-bg) 0%, rgba(255,107,53,.02) 100%);
}
.attendance-card.virtual {
  background: linear-gradient(135deg, var(--card-bg) 0%, rgba(59,130,246,.02) 100%);
}

[data-theme="dark"] .attendance-card.in-person {
  background: linear-gradient(135deg, var(--card-bg) 0%, rgba(255,107,53,.1) 100%);
}
[data-theme="dark"] .attendance-card.virtual {
  background: linear-gradient(135deg, var(--card-bg) 0%, rgba(59,130,246,.1) 100%);
}

.attendance-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}
.attendance-icon {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--orange-primary), var(--orange-dark));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(229,90,43,.25);
}
.attendance-icon i {
  font-size: 1.5rem;
  color: white;
}
.attendance-badge {
  background: rgba(255,107,53,.1);
  color: var(--orange-primary);
  padding: 0.5rem 1rem;
  border-radius: 50px;
  font-size: 0.85rem;
  font-weight: 600;
  border: 1px solid rgba(255,107,53,.2);
}
.attendance-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}
.attendance-subtitle {
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
}
.attendance-features {
  space-y: 0.75rem;
}
.feature-item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 0.75rem;
  padding: 0.5rem 0;
}
.feature-item span {
  flex: 1;
  line-height: 1.5;
}

.attendance-note {
  background: rgba(255,255,255,.9);
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 1.5rem;
  backdrop-filter: blur(10px);
}

/* Enhanced CTA Section */
.cta-decoration {
  position: absolute;
  top: -50%;
  right: -20%;
  width: 200%;
  height: 200%;
  background: 
    radial-gradient(circle at 30% 40%, rgba(255,255,255,.1), transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.05), transparent 50%);
  animation: ctaFloat 20s ease-in-out infinite;
}
@keyframes ctaFloat {
  0%, 100% { transform: rotate(0deg) translateY(0); }
  50% { transform: rotate(5deg) translateY(-10px); }
}

.cta-content {
  position: relative;
  z-index: 2;
}
.countdown-display {
  gap: 1rem !important;
}
.countdown-box {
  background: rgba(255,255,255,.15);
  border-radius: 12px;
  padding: 1rem;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.2);
  min-width: 80px;
}
.countdown-number {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1;
  color: white;
}
.countdown-label {
  font-size: 0.85rem;
  color: rgba(255,255,255,.8);
  margin-top: 0.25rem;
}
.cta-divider {
  color: rgba(255,255,255,.6);
  font-weight: 500;
  padding: 0 1rem;
}
.cta-info-item {
  color: rgba(255,255,255,.9);
}
.cta-info-item i {
  font-size: 1.5rem;
  color: rgba(255,255,255,.8);
}
.text-white-75 {
  color: rgba(255,255,255,.75) !important;
}

/* Policy Cards (fallback) */
.policy-card {
  background: #fff;
  border-radius: 16px;
  padding: 1.25rem 1.4rem;
  height: 100%;
  box-shadow: var(--shadow);
  border-top: 4px solid var(--orange-primary);
  transition: transform .15s ease, box-shadow .15s ease;
}
.policy-card:hover { transform: translateY(-2px); box-shadow: 0 16px 36px rgba(2,6,23,.12); }
.policy-card h5 { margin: 0 0 .5rem; font-weight: 800; }
.policy-card ul { margin: 0; padding-left: 1.2rem; }
.policy-card li { margin: .35rem 0; }

/* Enhanced Glance Section */
.glance-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 16px;
  padding: 2rem 1.5rem;
  box-shadow: var(--shadow);
  transition: transform .3s ease, box-shadow .3s ease;
  height: 100%;
}
.glance-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(2,6,23,.15);
}
.glance-card.highlighted {
  border: 2px solid var(--orange-primary);
  background: linear-gradient(135deg, rgba(255,107,53,.02), rgba(255,107,53,.08));
}
.glance-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--orange-primary), var(--orange-dark));
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  box-shadow: 0 8px 20px rgba(229,90,43,.25);
}
.glance-icon i {
  font-size: 1.8rem;
  color: white;
}
.glance-card .stat-num {
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(90deg,var(--orange-primary),var(--orange-dark));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: 0.5rem;
}
.glance-card .stat-label {
  color: var(--ink);
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 0;
}
.glance-date {
  padding-top: 0.5rem;
  border-top: 1px solid #eee;
}

/* Summary card */
.glance-summary {
  background: linear-gradient(135deg, #f8fafc, #ffffff);
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 10px 30px rgba(2,6,23,.08);
}
.summary-icon {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--orange-primary), var(--orange-dark));
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  box-shadow: 0 10px 25px rgba(229,90,43,.3);
}
.summary-icon i {
  font-size: 2.2rem;
  color: white;
}
.summary-item {
  padding: 0.75rem;
  background: rgba(255,255,255,.8);
  border-radius: 10px;
  border: 1px solid #f1f5f9;
}

/* Stats cards fallback for dates page */
.dates-page .stat-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 14px;
  padding: 1rem 1.25rem;
  box-shadow: var(--shadow);
}
.stat-num {
  font-size: 1.6rem;
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(90deg,var(--orange-primary),var(--orange-dark));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.stat-label { color: var(--muted); }

/* Sticky CTA */
.sticky-cta {
  position: sticky;
  bottom: 0;
  z-index: 1010;
  background: rgba(255,255,255,.96);
  backdrop-filter: saturate(120%) blur(6px);
  border-top: 1px solid #eee;
}

/* Back-to-top */
#toTop {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  display: none;
  z-index: 1031;
  border-radius: 999px;
}

/* Responsive Styles for Enhanced Sections */
@media (max-width: 768px) {
  .glance-card {
    padding: 1.5rem 1rem;
  }
  .glance-icon {
    width: 52px;
    height: 52px;
  }
  .glance-icon i {
    font-size: 1.5rem;
  }
  .glance-card .stat-num {
    font-size: 2rem;
  }
  .glance-card .stat-label {
    font-size: 1rem;
  }
  .glance-summary {
    padding: 1.5rem;
  }
  .summary-icon {
    width: 60px;
    height: 60px;
  }
  .summary-icon i {
    font-size: 1.8rem;
  }
  
  /* Steps mobile adjustments */
  .dates-page #steps {
    padding: 3rem 0;
  }
  .steps {
    max-width: none;
  }
  .steps li {
    padding: 1.25rem 1rem 1.25rem 3rem;
    margin-bottom: 1.25rem;
  }
  .steps li .icon {
    width: 36px;
    height: 36px;
    top: 1.25rem;
  }
  .steps li .icon i {
    font-size: 1rem;
  }
  .steps h5 {
    font-size: 1.1rem;
  }

  /* Attendance cards mobile */
  .attendance-card {
    padding: 1.5rem;
    margin-bottom: 1.5rem;
  }
  .attendance-icon {
    width: 50px;
    height: 50px;
  }
  .attendance-icon i {
    font-size: 1.3rem;
  }
  .attendance-title {
    font-size: 1.3rem;
  }
  .attendance-note {
    padding: 1.25rem;
  }

  /* CTA mobile adjustments */
  .countdown-box {
    min-width: 70px;
    padding: 0.75rem;
  }
  .countdown-number {
    font-size: 1.5rem;
  }
  .countdown-label {
    font-size: 0.75rem;
  }
  .cta-actions {
    flex-direction: column !important;
    gap: 1rem !important;
  }
  .cta-divider {
    display: none !important;
  }
}

@media (max-width: 576px) {
  .glance-card .stat-num {
    font-size: 1.8rem;
  }
  .summary-item {
    padding: 0.5rem;
    font-size: 0.9rem;
  }
  .steps::before {
    left: 18px;
  }
  .steps li {
    padding: 1rem 0.75rem 1rem 2.5rem;
  }
  .steps li .icon {
    left: 0.75rem;
    width: 32px;
    height: 32px;
  }
  .timeline-progress {
    left: 19px;
  }
}

/* Dates Page Motion */
@media (prefers-reduced-motion: reduce) {
  .dates-page * { animation: none !important; transition: none !important; }
}

/* ========================================
   VENUE PAGE STYLES
   ======================================== */

/* Venue Page Variables */
.venue-page {
  --ink:#0f172a; --muted:#475569; --nav-offset:84px;
  --ring:0 0 0 .25rem rgba(255,107,53,.25); --shadow:0 14px 36px rgba(2,6,23,.10);
  --card-bg:#ffffff; --page-bg:#ffffff; --chip-bg:#ffffff; --chip-border:#e5e7eb;
  --outline:#e5e7eb; --grid-dot:rgba(0,0,0,.06);
  --focus-outline:#111827;
}
[data-theme="dark"] .venue-page,
html[data-theme="dark"] .venue-page {
  --ink:#e6e8ec; --muted:#9aa3ad; --card-bg:#111827; --page-bg:#0b1220;
  --outline:#1f2937; --chip-bg:#0f172a; --chip-border:#1f2937; --grid-dot:rgba(255,255,255,.08);
  --shadow:0 14px 36px rgba(0,0,0,.45);
  --focus-outline:#e6e8ec;
}

/* Venue Base Layout */
.venue-page html,
.venue-page body { height:100% }
.venue-page body { 
  display:flex; flex-direction:column; min-height:100vh; 
  background:var(--page-bg); color:var(--ink); line-height:1.6 
}
.venue-page main { flex:1 0 auto }
.venue-page .pre-footer-space { height:72px }

/* Venue Focus Visibility */
.venue-page :focus { outline:none }
.venue-page :focus-visible { outline:2px solid var(--focus-outline); outline-offset:2px }
.venue-page .btn:focus-visible,
.venue-page .form-control:focus-visible { box-shadow:var(--ring) }

/* Venue Navbar Accent */
.venue-page .navbar-light .navbar-nav .nav-link.active,
.venue-page .navbar-light .navbar-nav .nav-link:hover { color:var(--orange-primary)!important }

/* Venue Titles & Buttons */
.venue-page .hero-title { color:var(--orange-primary)!important; font-weight:800 }
.venue-page .section-title {
  color:var(--orange-primary)!important; border-bottom:2px solid var(--orange-primary);
  padding-bottom:.5rem; margin:2rem 0 1.25rem; font-weight:800; letter-spacing:.2px;
  text-align: center;
}
.venue-page .btn-primary { background:var(--orange-primary); border-color:var(--orange-primary) }
.venue-page .btn-primary:hover { background:var(--orange-dark); border-color:var(--orange-dark) }
.venue-page .btn-outline-primary { color:var(--orange-primary); border-color:var(--orange-primary) }
.venue-page .btn-outline-primary:hover { background:var(--orange-primary); color:#fff; border-color:var(--orange-primary) }

/* Venue Hero */
.venue-page .page-header {
  position:relative; overflow:hidden;
  padding:calc(3.5rem + var(--nav-offset)) 0 2rem;
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.92)),
    url('../images/fa1.jpeg') center/cover no-repeat;
}
[data-theme="dark"] .venue-page .page-header,
html[data-theme="dark"] .venue-page .page-header {
  background:
    linear-gradient(180deg, rgba(11,18,32,.78), rgba(11,18,32,.78)),
    url('../images/fa1.jpeg') center/cover no-repeat;
}
.venue-page .page-header::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: radial-gradient(var(--grid-dot) 1px, transparent 1px);
  background-size:18px 18px; mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 65%);
}
.venue-page .header-tools { position:absolute; right:1rem; top:calc(1rem + var(--nav-offset)); z-index:3 }
.venue-page .header-wave { display:block; width:100%; height:64px; margin-top:.5rem }
.venue-page .hero-subtitle { color:var(--muted) }

/* Venue Section Pills */
.venue-page .section-nav {
  position:sticky; top:calc(var(--nav-offset) + .5rem); z-index:1020;
  background:var(--card-bg); border:1px solid var(--outline); border-radius:999px; padding:.4rem; box-shadow:var(--shadow);
  backdrop-filter:saturate(140%) blur(6px)
}
.venue-page .section-nav .nav-link { border-radius:999px; transition:all .2s }
.venue-page .section-nav .nav-link.active { background:var(--orange-primary); color:#fff }
.venue-page .section-nav .nav-link:hover { background:rgba(255,107,53,.08) }

/* Venue Cards */
.venue-page .content-card,
.venue-page .info-card {
  background:var(--card-bg); border-radius:14px; padding:1.25rem 1.25rem; box-shadow:var(--shadow); border:1px solid var(--outline);
  border-left:4px solid var(--orange-primary)
}
.venue-page .info-card { padding:18px 18px 12px 20px; margin-bottom:24px }
.venue-page .venue-head { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap }
.venue-page .venue-head .logo-wrap { background:var(--card-bg); border:1px solid var(--outline); border-radius:12px; padding:8px 10px; box-shadow:0 4px 10px rgba(0,0,0,.05) }
.venue-page .venue-head .logo-wrap img { height:80px; width:auto; display:block }

/* Venue Chips */
.venue-page .chips { display:flex; flex-wrap:wrap; gap:.5rem }
.venue-page .chip { background:var(--chip-bg); border:1px solid var(--chip-border); border-radius:999px; padding:.4rem .8rem; box-shadow:0 4px 12px rgba(0,0,0,.06); font-size:.95rem }
.venue-page .chip i { color:var(--orange-primary); margin-right:.35rem }

/* Venue Gallery */
.venue-page .image-gallery { display:grid; grid-template-columns:1fr; gap:16px; margin:20px 0 10px }
@media (min-width:768px) { .venue-page .image-gallery { grid-template-columns:repeat(2,1fr) } }
.venue-page .gallery-img { border-radius:12px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.10); transition:transform .3s ease; position:relative; background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 37%,#f3f4f6 63%); background-size:400% 100% }
.venue-page .gallery-img img { width:100%; height:320px; object-fit:cover; display:block; opacity:0; transition:opacity .3s ease }
.venue-page .gallery-img.loaded { animation:none; background:none }
.venue-page .gallery-img.loaded img { opacity:1 }
.venue-page .gallery-img:hover { transform:translateY(-4px) }
.venue-page .caption { padding:10px; background:var(--card-bg); color:var(--muted); font-style:italic }

/* Venue Transport & Map */
.venue-page .transport-card { border:none; border-radius:12px; box-shadow:0 10px 24px rgba(0,0,0,.08); transition:transform .25s ease; height:100%; background:var(--card-bg) }
.venue-page .transport-card:hover { transform:translateY(-4px) }
.venue-page .transport-icon { font-size:2rem; color:var(--orange-primary); margin-bottom:12px }
.venue-page .map-container { border-radius:12px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.10); margin:14px 0 12px; background:var(--card-bg); border:1px solid var(--outline) }
.venue-page #venueMap { height:460px; width:100% }
.venue-page .map-tools { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1rem }

/* Venue Scroll Progress */
.venue-page .scroll-progress { position:sticky; top:0; z-index:1031; height:4px; background:transparent }
.venue-page .scroll-progress .bar {
  height:100%; width:0%;
  background:linear-gradient(90deg, var(--orange-primary), var(--orange-dark));
  box-shadow:0 0 12px rgba(229,90,43,.35); transition:width .15s ease-out;
}

/* Venue Floating Actions */
.venue-page .fab-stack { position:fixed; right:1rem; bottom:1rem; z-index:1032; display:flex; flex-direction:column; gap:.5rem }
.venue-page .fab-stack .btn { border-radius:999px; box-shadow:var(--shadow) }
@media (max-width: 575.98px) { .venue-page .fab-stack { right:.75rem; bottom:.75rem } }

/* Venue Misc */
.venue-page #toTop { display:none }
.venue-page .visually-hidden-focusable:focus { position:static!important; width:auto; height:auto; overflow:visible; clip:auto }

/* Venue Print Styles */
@media print {
  .venue-page .section-nav,
  .venue-page .fab-stack,
  .venue-page .scroll-progress,
  .venue-page .header-tools,
  .venue-page .header-wave,
  .venue-page .map-tools,
  .venue-page .alert,
  .venue-page .btn,
  .venue-page .modal { display:none!important }
  .venue-page .page-header { padding:1rem 0; background:#fff }
  .venue-page a[href]::after { content:" (" attr(href) ")"; font-size:80% }
}

/* Venue Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .venue-page * { animation:none!important; transition:none!important }
}

/* ========================================
   SPONSORS PAGE STYLES
   ======================================== */

/* Sponsors Page Variables */
.sponsors-page {
  --orange-primary:#ff6b35; --orange-light:#ff8c5a; --orange-dark:#e55a2b;
  --ink:#0f172a; --muted:#6c757d; --nav-offset:84px;
  --ring:0 0 0 .25rem rgba(255,107,53,.18);
  --shadow:0 14px 36px rgba(2,6,23,.10);
  --card-bg:#fff; --page-bg:#fff; --chip-bg:#fff; --chip-border:#eee;
  --outline:#eee; --grid-dot:rgba(0,0,0,.06);
  --gradient:linear-gradient(135deg, var(--orange-primary) 0%, var(--orange-dark) 100%);
  --gradient-light:linear-gradient(135deg, rgba(255,107,53,.1) 0%, rgba(229,90,43,.1) 100%);
}

[data-theme="dark"] .sponsors-page,
html[data-theme="dark"] .sponsors-page {
  --ink:#e6e8ec; --muted:#9aa3ad; --card-bg:#111827; --page-bg:#0b1220;
  --outline:#1f2937; --chip-bg:#0f172a; --chip-border:#1f2937; --grid-dot:rgba(255,255,255,.08);
  --shadow:0 14px 36px rgba(0,0,0,.45);
  --gradient-light:linear-gradient(135deg, rgba(255,107,53,.15) 0%, rgba(229,90,43,.15) 100%);
}

/* Sponsors Base Layout */
.sponsors-page html,
.sponsors-page body { height:100% }
.sponsors-page body { 
  display:flex; flex-direction:column; min-height:100vh; background:var(--page-bg); color:var(--ink); 
  font-family:'Inter',system-ui,-apple-system,sans-serif 
}
.sponsors-page main { flex:1 0 auto }
.sponsors-page .pre-footer-space { height:72px }

/* Sponsors Navbar & Links */
.sponsors-page .navbar-light .navbar-nav .nav-link:is(.active,:hover) { color:var(--orange-primary)!important }

.sponsors-page .hero-title { color:var(--orange-primary)!important; font-weight:800; font-size:3.5rem; line-height:1.1 }

.sponsors-page .section-title { 
  color:var(--orange-primary)!important; border-bottom:2px solid var(--orange-primary); padding-bottom:.5rem; 
  margin:2rem 0 1.25rem; font-weight:800; letter-spacing:.2px; position:relative; text-align: center;
}
.sponsors-page .section-title::after { 
  content:""; position:absolute; bottom:-2px; left:50%; transform: translateX(-50%); width:60px; height:4px; 
  background:var(--gradient); border-radius:2px 
}

.sponsors-page .btn-primary { 
  background:var(--gradient); border:none; font-weight:600; padding:.75rem 1.75rem; 
  transition:transform .3s ease, box-shadow .3s ease, background .3s ease 
}
.sponsors-page .btn-primary:hover { 
  background:var(--orange-dark); transform:translateY(-2px); box-shadow:0 8px 25px rgba(255,107,53,.3) 
}

.sponsors-page .btn-outline-primary { 
  color:var(--orange-primary); border-color:var(--orange-primary); font-weight:500; 
  transition:transform .3s ease, background .3s ease, color .3s ease, border-color .3s ease 
}
.sponsors-page .btn-outline-primary:hover { 
  background:var(--orange-primary); color:#fff; border-color:var(--orange-primary); transform:translateY(-2px) 
}

.sponsors-page .btn:focus,
.sponsors-page .form-control:focus { box-shadow:var(--ring) }

/* Sponsors Page Header */
.sponsors-page .page-header { 
  position:relative; overflow:hidden; padding:calc(4rem + var(--nav-offset)) 0 3rem; 
  background:
    linear-gradient(135deg, rgba(255,255,255,.95) 0%, rgba(255,255,255,.85) 100%),
    url('../images/hero-bg.jpg') center/cover no-repeat
}
[data-theme="dark"] .sponsors-page .page-header,
html[data-theme="dark"] .sponsors-page .page-header { 
  background:
    linear-gradient(135deg, rgba(11,18,32,.85) 0%, rgba(11,18,32,.75) 100%),
    url('../images/hero-bg.jpg') center/cover no-repeat
}
.sponsors-page .page-header::before { 
  content:""; position:absolute; inset:0; background:var(--gradient-light); z-index:0 
}
.sponsors-page .page-header::after { 
  content:""; position:absolute; inset:0; pointer-events:none; 
  background-image:radial-gradient(var(--grid-dot) 1px, transparent 1px); background-size:18px 18px; 
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 65%); z-index:0 
}
.sponsors-page .page-header>.container { position:relative; z-index:2 }
.sponsors-page .header-tools { position:absolute; right:1rem; top:calc(1rem + var(--nav-offset)); z-index:3 }
.sponsors-page .header-wave { display:block; width:100%; height:64px; margin-top:.5rem }
.sponsors-page .hero-subtitle { 
  color:#334155; min-height:28px; font-size:1.3rem; max-width:700px; margin:0 auto 
}
[data-theme="dark"] .sponsors-page .hero-subtitle,
html[data-theme="dark"] .sponsors-page .hero-subtitle { color:#9aa3ad }

/* Sponsors Section Nav */
.sponsors-page .section-nav { 
  position:sticky; top:calc(var(--nav-offset) + .5rem); z-index:1020; background:var(--card-bg); 
  border:1px solid var(--outline); border-radius:999px; padding:.4rem; box-shadow:var(--shadow); 
  backdrop-filter:saturate(140%) blur(6px); margin-top:1rem 
}
.sponsors-page .section-nav .nav-link { 
  border-radius:999px; transition:transform .2s ease, background .2s ease; font-weight:500 
}
.sponsors-page .section-nav .nav-link.active { 
  background:var(--gradient); color:#fff; box-shadow:0 4px 12px rgba(255,107,53,.3) 
}
.sponsors-page .section-nav .nav-link:hover { 
  background:rgba(255,107,53,.08); transform:translateY(-1px) 
}

/* Sponsors Cards */
.sponsors-page .content-card,
.sponsors-page .info-card { 
  background:var(--card-bg); border-radius:16px; padding:1.75rem; box-shadow:var(--shadow); 
  border:1px solid var(--outline); transition:transform .3s ease, box-shadow .3s ease; 
  position:relative; overflow:hidden 
}
.sponsors-page .content-card::before,
.sponsors-page .info-card::before { 
  content:""; position:absolute; left:0; right:0; top:0; height:4px; background:var(--gradient) 
}
.sponsors-page .content-card:hover,
.sponsors-page .info-card:hover { 
  transform:translateY(-5px); box-shadow:0 20px 40px rgba(2,6,23,.15) 
}
[data-theme="dark"] .sponsors-page .content-card:hover,
[data-theme="dark"] .sponsors-page .info-card:hover,
html[data-theme="dark"] .sponsors-page .content-card:hover,
html[data-theme="dark"] .sponsors-page .info-card:hover { box-shadow:0 20px 40px rgba(0,0,0,.4) }
.sponsors-page .info-card { margin-bottom:24px }

.sponsors-page .venue-head { 
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap 
}
.sponsors-page .venue-head .logo-wrap { 
  background:var(--card-bg); border:1px solid var(--outline); border-radius:12px; padding:12px 16px; 
  box-shadow:0 4px 12px rgba(0,0,0,.08); transition:transform .3s ease 
}
.sponsors-page .venue-head .logo-wrap:hover { transform:scale(1.05) }
.sponsors-page .venue-head .logo-wrap img { height:64px; width:auto; display:block }

/* Sponsors Chips */
.sponsors-page .chips { display:flex; flex-wrap:wrap; gap:.5rem }
.sponsors-page .chip { 
  background:var(--chip-bg); border:1px solid var(--chip-border); border-radius:999px; 
  padding:.5rem 1rem; box-shadow:0 4px 12px rgba(0,0,0,.06); font-weight:500; 
  display:flex; align-items:center 
}
.sponsors-page .chip i { color:var(--orange-primary); margin-right:.5rem; font-size:1.1rem }

/* Sponsors Benefit Table */
.sponsors-page .benefit-table th,
.sponsors-page .benefit-table td { 
  vertical-align:middle; 
  text-align:center; 
  color: var(--text-primary);
  border-color: var(--border-color);
}
.sponsors-page .benefit-table th { position:relative }
.sponsors-page .benefit-table tbody tr:hover { background:rgba(255,107,53,.04) }
.sponsors-page .col-hover { background:rgba(255,107,53,.07)!important }

/* Dark mode benefit table */
[data-theme="dark"] .sponsors-page .benefit-table {
  background: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .sponsors-page .benefit-table th,
[data-theme="dark"] .sponsors-page .benefit-table td {
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .sponsors-page .benefit-table tbody tr:hover {
  background: rgba(255,107,53,.1);
}

[data-theme="dark"] .sponsors-page .benefit-table .featured {
  background: rgba(255,107,53,.15);
}

/* Sponsors Marquee */
.sponsors-page .marquee { 
  overflow:hidden; white-space:nowrap; border:1px solid var(--outline); border-radius:16px; 
  background:var(--card-bg); box-shadow:var(--shadow); padding:1rem 0 
}
.sponsors-page .marquee-track { display:inline-block; animation:scroll 28s linear infinite }
.sponsors-page .marquee img { 
  height:48px; margin:14px 36px; opacity:.85; filter:grayscale(20%); 
  transition:transform .3s ease, opacity .3s ease, filter .3s ease 
}
.sponsors-page .marquee img:hover { opacity:1; filter:grayscale(0); transform:scale(1.05) }
@keyframes scroll { to { transform:translateX(-50%) } }

/* Sponsors Gallery */
.sponsors-page .image-gallery { display:grid; grid-template-columns:1fr; gap:20px; margin:20px 0 10px }
@media (min-width:768px) { .sponsors-page .image-gallery { grid-template-columns:repeat(2,1fr) } }
.sponsors-page .gallery-img { 
  border-radius:16px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.10); 
  transition:transform .3s ease, box-shadow .3s ease; position:relative 
}
.sponsors-page .gallery-img:hover { transform:translateY(-8px); box-shadow:0 20px 40px rgba(0,0,0,.15) }
.sponsors-page .gallery-img img { width:100%; height:320px; object-fit:cover; transition:transform .5s ease }
.sponsors-page .gallery-img:hover img { transform:scale(1.05) }
.sponsors-page .caption { padding:10px; background:var(--card-bg); color:#778; font-style:italic }

/* Sponsors Transport & Map */
.sponsors-page .transport-card { 
  border:none; border-radius:16px; box-shadow:0 10px 24px rgba(0,0,0,.08); 
  transition:transform .25s ease, box-shadow .3s ease; height:100%; background:var(--card-bg); 
  overflow:hidden; position:relative 
}
.sponsors-page .transport-card::before { 
  content:""; position:absolute; left:0; right:0; top:0; height:4px; background:var(--gradient) 
}
.sponsors-page .transport-card:hover { transform:translateY(-8px); box-shadow:0 20px 40px rgba(0,0,0,.15) }
.sponsors-page .transport-icon { 
  font-size:2.5rem; color:var(--orange-primary); margin-bottom:12px; display:inline-block; 
  padding:1rem; background:var(--gradient-light); border-radius:12px 
}
.sponsors-page .map-container { 
  border-radius:16px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.10); margin:14px 0 12px; 
  background:var(--card-bg); border:1px solid var(--outline); transition:box-shadow .3s ease 
}
.sponsors-page .map-container:hover { box-shadow:0 15px 30px rgba(0,0,0,.15) }
.sponsors-page #venueMap { height:420px; width:100% }
.sponsors-page .map-tools { 
  display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1rem; background:var(--card-bg); 
  padding:1rem; border-radius:12px; box-shadow:0 4px 12px rgba(0,0,0,.05) 
}

/* Sponsors Scroll Progress */
.sponsors-page .scroll-progress { position:sticky; top:0; z-index:1031; height:4px; background:transparent }
.sponsors-page .scroll-progress .bar { 
  height:100%; width:0%; background:var(--gradient); box-shadow:0 0 12px rgba(229,90,43,.35); 
  transition:width .15s ease-out 
}

/* Sponsors Floating Actions */
.sponsors-page .fab-stack { 
  position:fixed; right:1.5rem; bottom:1.5rem; z-index:1032; display:flex; flex-direction:column; gap:.75rem 
}
.sponsors-page .fab-stack .btn { 
  border-radius:999px; box-shadow:var(--shadow); width:56px; height:56px; display:flex; 
  align-items:center; justify-content:center; transition:transform .3s ease, box-shadow .3s ease 
}
.sponsors-page .fab-stack .btn:hover { 
  transform:translateY(-5px) scale(1.1); box-shadow:0 10px 25px rgba(255,107,53,.3) 
}
@media (max-width:575.98px) { .sponsors-page .fab-stack { right:1rem; bottom:1rem } }

/* Sponsors Stats */
.sponsors-page .stats { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:10px }
@media(min-width:768px) { .sponsors-page .stats { grid-template-columns:repeat(4,1fr) } }
.sponsors-page .stat { 
  background:var(--card-bg); border:1px solid var(--outline); border-radius:16px; padding:1.5rem; 
  text-align:center; box-shadow:var(--shadow); transition:transform .3s ease 
}
.sponsors-page .stat:hover { transform:translateY(-5px) }
.sponsors-page .stat .num { 
  font-size:2rem; font-weight:800; color:var(--orange-primary); line-height:1; margin-bottom:.5rem 
}
.sponsors-page .stat .label { font-size:.9rem; color:var(--muted); font-weight:500 }

/* Sponsors Share Bar */
.sponsors-page .share-bar { 
  position:sticky; bottom:0; z-index:1030; background:var(--card-bg); border:1px solid var(--outline); 
  box-shadow:var(--shadow); padding:1rem 1.5rem; border-radius:16px; margin:0 auto; max-width:980px; 
  display:flex; align-items:center; justify-content:space-between; gap:.75rem 
}
.sponsors-page .share-bar .btn { border-radius:999px }

/* Sponsors ROI Calculator */
.sponsors-page #roi .calc-card { 
  background:var(--card-bg); border:1px solid var(--outline); border-radius:16px; 
  box-shadow:var(--shadow); padding:1.5rem 
}
.sponsors-page #roi .result { display:grid; grid-template-columns:repeat(4,1fr); gap:.75rem }
.sponsors-page #roi .result .cell { 
  background:var(--chip-bg); border:1px solid var(--chip-border); border-radius:12px; 
  padding:1rem; text-align:center; transition:transform .3s ease 
}
.sponsors-page #roi .result .cell:hover { transform:translateY(-3px) }
.sponsors-page #roi .result .cell .label { font-size:.8rem; color:var(--muted); font-weight:500 }
.sponsors-page #roi .result .cell .val { font-weight:700; font-size:1.1rem }
@media(max-width:767.98px) { .sponsors-page #roi .result { grid-template-columns:repeat(2,1fr) } }

/* Sponsors Utilities */
.sponsors-page .gradient-text { 
  background:var(--gradient); -webkit-background-clip:text; background-clip:text; 
  color:transparent; font-weight:800 
}
.sponsors-page .glass { 
  backdrop-filter:saturate(150%) blur(8px); 
  background:linear-gradient(180deg,rgba(255,255,255,.65),rgba(255,255,255,.35)); 
  border:1px solid var(--outline); border-radius:16px 
}
[data-theme="dark"] .sponsors-page .glass,
html[data-theme="dark"] .sponsors-page .glass { 
  background:linear-gradient(180deg,rgba(17,24,39,.65),rgba(17,24,39,.35)) 
}
.sponsors-page .countdown { display:flex; gap:.75rem; justify-content:center; flex-wrap:wrap }
.sponsors-page .countdown .unit { 
  min-width:80px; border-radius:16px; padding:.75rem .6rem; text-align:center; 
  background:var(--card-bg); border:1px solid var(--outline); box-shadow:var(--shadow); 
  transition:transform .3s ease 
}
.sponsors-page .countdown .unit:hover { transform:translateY(-3px) }
.sponsors-page .countdown .num { 
  font-weight:800; font-size:1.5rem; color:var(--orange-primary); line-height:1 
}

.sponsors-page .video-thumb { 
  position:relative; border-radius:20px; overflow:hidden; box-shadow:var(--shadow); 
  transition:transform .3s ease, box-shadow .3s ease 
}
.sponsors-page .video-thumb:hover { transform:translateY(-5px); box-shadow:0 20px 40px rgba(0,0,0,.2) }
.sponsors-page .video-thumb::after { 
  content:"\f4f4"; font-family:"bootstrap-icons"; position:absolute; inset:auto auto 20px 20px; 
  font-size:3rem; color:#fff; text-shadow:0 6px 20px rgba(0,0,0,.35); transition:transform .3s ease 
}
.sponsors-page .video-thumb:hover::after { transform:scale(1.1) }

.sponsors-page .tilt { will-change:transform }

.sponsors-page .contact-icon { 
  width:60px; height:60px; background:var(--gradient-light); border-radius:50%; 
  display:flex; align-items:center; justify-content:center; margin:0 auto 1rem; 
  font-size:1.5rem; color:var(--orange-primary) 
}

/* Sponsors Packages Section */
.sponsors-page #packages .pricing { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1.25rem }
@media (max-width:992px) { .sponsors-page #packages .pricing { grid-template-columns:1fr } }

.sponsors-page #packages .price-card { 
  position:relative; background:var(--card-bg); border:1px solid var(--border-color); 
  border-radius:1rem; padding:1.25rem; box-shadow:0 10px 24px rgba(0,0,0,.06); 
  transition:transform .25s ease, box-shadow .25s ease; outline:none;
  color: var(--text-primary);
}

[data-theme="dark"] .sponsors-page #packages .price-card {
  background: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
}
.sponsors-page #packages .price-card:is(:hover,:focus-visible) { 
  transform:translateY(-4px); box-shadow:0 18px 40px rgba(0,0,0,.12) 
}

[data-theme="dark"] .sponsors-page #packages .price-card:is(:hover,:focus-visible) { 
  box-shadow:0 18px 40px rgba(0,0,0,.4) 
}
.sponsors-page #packages .price-card.featured { 
  border-color:var(--bs-primary); box-shadow:0 12px 28px rgba(var(--bs-primary-rgb),.25) 
}

.sponsors-page #packages .ribbon { 
  position:absolute; top:12px; right:-8px; background:var(--bs-primary); color:#fff; 
  padding:.25rem .75rem; border-radius:.5rem 0 0 .5rem; font-size:.8rem; 
  font-weight:600; letter-spacing:.2px 
}

.sponsors-page #packages .price { 
  font-size:clamp(1.35rem,1.1rem + 1vw,2rem); font-weight:700; 
  display:flex; align-items:baseline; gap:.35rem 
}
.sponsors-page #packages .price-symbol { opacity:.9 }

@media (hover:hover) and (prefers-reduced-motion:no-preference) {
  .sponsors-page #packages .tilt { transform-style:preserve-3d }
  .sponsors-page #packages .tilt:hover { 
    transform:perspective(800px) rotateX(2deg) rotateY(-2deg) translateY(-4px) 
  }
}

.sponsors-page #packages .benefit-table th[scope="col"] { text-align:center }
.sponsors-page #packages .benefit-table th[scope="row"] { font-weight:500 }
.sponsors-page #packages .benefit-table .featured { background:rgba(var(--bs-primary-rgb),.05) }

.sponsors-page #packages .tier-badge { 
  display:inline-flex; align-items:center; justify-content:center; width:1.5rem; height:1.5rem; 
  border-radius:999px; background:rgba(0,0,0,.04); box-shadow:inset 0 0 0 1px rgba(0,0,0,.06) 
}

/* Sponsors Print Styles */
@media print {
  .sponsors-page .section-nav,
  .sponsors-page .fab-stack,
  .sponsors-page .share-bar,
  .sponsors-page #confetti { display:none!important }
  .sponsors-page .page-header { padding:1rem 0; background:none }
  .sponsors-page a[href]:after { content:" (" attr(href) ")" }
}

.sponsors-page .visually-hidden { 
  position:absolute!important; width:1px!important; height:1px!important; 
  padding:0!important; margin:-1px!important; overflow:hidden!important; 
  clip:rect(0,0,0,0)!important; white-space:nowrap!important; border:0!important 
}

/* Sponsors Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .sponsors-page * { animation:none!important; transition:none!important }
}


/* ========================================
   TERMS PAGE STYLES
   ======================================== */

/* Terms page specific styles */
.terms-page .hero-section {
  position: relative;
  background: linear-gradient(135deg, #fff7ed, #ffedd5);
  padding: 5rem 0 3rem;
  isolation: isolate;
  overflow: hidden;
}

.terms-page .hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(ellipse at top left, rgba(255,255,255,0.5), transparent 70%),
              radial-gradient(ellipse at bottom right, rgba(255,255,255,0.4), transparent 70%);
  backdrop-filter: blur(0.5px);
}

.terms-page .hero-background {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(820px 300px at -10% -30%, rgba(255, 107, 53, 0.1), transparent 70%),
              radial-gradient(760px 260px at 120% -20%, rgba(234, 88, 12, 0.12), transparent 70%);
}

.terms-page .hero-section .container {
  position: relative;
  z-index: 2;
  text-align: center;
}

.terms-page .hero-title {
  font-weight: 800;
  font-size: 2.8rem;
  margin-bottom: 1rem;
  color: var(--orange-primary);
}

.terms-page .hero-subtitle {
  color: #334155;
  font-size: 1.2rem;
  text-shadow: 0 1px 0 rgba(255,255,255,0.35);
}

.terms-page .content-card {
  background: #ffffff;
  border-radius: 1rem;
  padding: 2rem;
  margin-bottom: 2.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
  transition: 0.2s ease;
}

.terms-page .content-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.05);
}

.terms-page .section-title {
  font-weight: 700;
  font-size: 1.6rem;
  margin-bottom: 1.25rem;
  color: #111827;
}

.terms-page .step {
  background-color: #fefbf7;
  padding: 1rem;
  border: 1px solid #fed7aa;
  border-radius: 0.75rem;
  transition: 0.2s ease;
  height: 100%;
}

.terms-page .step:hover {
  background-color: #fff7ed;
  border-color: var(--orange-light);
}

.terms-page .step .icon {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  color: var(--orange-primary);
}

.terms-page .muted {
  font-size: 0.9rem;
  color: #6c757d;
}

.terms-page .btn-primary.btn-lg {
  padding: 0.75rem 2rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 0.5rem;
}

/* Terms page dark mode support */
[data-theme="dark"] .hero-section {
  background: linear-gradient(135deg, var(--bg-secondary), var(--bg-tertiary)) !important;
}

[data-theme="dark"] .hero-section::before {
  background: radial-gradient(ellipse at top left, rgba(255,107,53,0.1), transparent 70%),
              radial-gradient(ellipse at bottom right, rgba(255,107,53,0.08), transparent 70%) !important;
}

[data-theme="dark"] .hero-background {
  background: radial-gradient(820px 300px at -10% -30%, rgba(255, 107, 53, 0.15), transparent 70%) !important;
}

[data-theme="dark"] .terms-content {
  background: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .terms-section {
  background: var(--bg-primary);
  color: var(--text-primary);
}

[data-theme="dark"] .card {
  background: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
}

/* Fix terms.php inline styles for dark mode */
[data-theme="dark"] .content-card {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .section-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .step {
  background-color: var(--bg-secondary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .step:hover {
  background-color: var(--bg-tertiary) !important;
  border-color: var(--orange-primary) !important;
}

[data-theme="dark"] .muted {
  color: var(--text-secondary) !important;
}

/* Fix primary button text color issue */
.btn-primary {
  color: #ffffff !important;
}

.btn-primary:hover {
  color: #ffffff !important;
}

.btn-primary:focus,
.btn-primary:active {
  color: #ffffff !important;
}

/* ========================================
   CONTACT PAGE STYLES
   ======================================== */

/* Contact page dark mode support */
[data-theme="dark"] .contact-page .hero-section {
  background: url('./assets/images/roma.jpeg') center center / cover no-repeat !important;
}

[data-theme="dark"] .contact-page .hero-section::before {
  background: linear-gradient(to bottom, rgba(15,23,42,0.85), rgba(15,23,42,0.75)) !important;
}

[data-theme="dark"] .contact-form {
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .contact-info {
  background: var(--card-bg);
  color: var(--text-primary);
}

[data-theme="dark"] .contact-section {
  background: var(--bg-primary);
  color: var(--text-primary);
}

/* Fix contact.php card styles */
[data-theme="dark"] .contact-card {
  background-color: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-color);
  box-shadow: 0 10px 30px rgba(0,0,0,0.25) !important;
}

[data-theme="dark"] .contact-card:hover {
  box-shadow: 0 16px 40px rgba(0,0,0,0.35) !important;
}

[data-theme="dark"] .contact-icon i {
  color: var(--orange-primary) !important;
}

[data-theme="dark"] .email-addr {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
}

/* Fix venue.php FAQ section (accordion) */
[data-theme="dark"] .accordion-item {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .accordion-button {
  background: var(--card-bg);
  color: var(--text-primary);
  border: none;
}

[data-theme="dark"] .accordion-button:not(.collapsed) {
  background: var(--bg-secondary);
  color: var(--text-primary);
  box-shadow: none;
}

[data-theme="dark"] .accordion-button:focus {
  border-color: var(--orange-primary);
  box-shadow: 0 0 0 0.2rem rgba(255, 107, 53, 0.25);
}

[data-theme="dark"] .accordion-body {
  background: var(--card-bg);
  color: var(--text-primary);
}

/* ========================================
   ADDITIONAL COMPREHENSIVE DARK MODE FIXES
   ======================================== */

/* Ensure all page classes work with dark mode */
[data-theme="dark"] .venue-page body,
[data-theme="dark"] .sponsors-page body,
[data-theme="dark"] .dates-page body,
[data-theme="dark"] .program-page body {
  background: var(--bg-primary);
  color: var(--text-primary);
}

/* Fix any Bootstrap components that might be missed */
[data-theme="dark"] .modal-content {
  background: var(--card-bg);
  color: var(--text-primary);
  border-color: var(--border-color);
}

[data-theme="dark"] .dropdown-menu {
  background: var(--card-bg);
  border-color: var(--border-color);
}

[data-theme="dark"] .dropdown-item {
  color: var(--text-primary);
}

[data-theme="dark"] .dropdown-item:hover {
  background: var(--bg-secondary);
  color: var(--orange-primary);
}

[data-theme="dark"] .alert {
  background: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
}

[data-theme="dark"] .list-group-item {
  background: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
}

/* Ensure all text elements are visible */
[data-theme="dark"] .text-dark {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .bg-light {
  background: var(--bg-secondary) !important;
}

/* Fix specific section backgrounds with inline styles */
[data-theme="dark"] section[style*="background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%)"] {
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%) !important;
}

/* Fix sponsors.php comparison table dark mode */
[data-theme="dark"] .benefit-table {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .benefit-table th,
[data-theme="dark"] .benefit-table td {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .benefit-table thead th {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .benefit-table .package-platinum,
[data-theme="dark"] .benefit-table .package-gold,
[data-theme="dark"] .benefit-table .package-silver {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .benefit-table .featured {
  background: var(--bg-tertiary) !important;
}

/* Fix dates.php attendance-note (Comparison note) dark mode */
[data-theme="dark"] .attendance-note {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

/* Fix all program.php tables dark mode */
[data-theme="dark"] .program-table {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .program-table th,
[data-theme="dark"] .program-table td {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .program-table thead th {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .program-table tbody tr:hover {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .day-cell,
[data-theme="dark"] .time-cell,
[data-theme="dark"] .session-cell,
[data-theme="dark"] .speaker-cell {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .day-info .day-name,
[data-theme="dark"] .day-info .day-date {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .slot-title {
  color: var(--text-primary) !important;
}

/* Fix program.php mobile cards dark mode */
[data-theme="dark"] .card-list .card {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .day-section-header {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .day-section-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .slot-meta {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .slot-badge {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
}

/* Fix index.php and footer.php buttons dark mode */
[data-theme="dark"] .btn-orange-cta {
  background: var(--orange-gradient) !important;
  color: #ffffff !important;
  border: none !important;
}

[data-theme="dark"] .btn-orange-cta:hover {
  background: linear-gradient(135deg, #d97706, #ea580c) !important;
  color: #ffffff !important;
}

[data-theme="dark"] .btn-outline-orange {
  border: 2px solid var(--orange-primary) !important;
  color: var(--orange-primary) !important;
  background: transparent !important;
}

[data-theme="dark"] .btn-outline-orange:hover {
  background: var(--orange-primary) !important;
  color: #ffffff !important;
}

[data-theme="dark"] .btn-brand {
  background: var(--orange-gradient) !important;
  color: #ffffff !important;
  border: none !important;
}

[data-theme="dark"] .btn-brand:hover {
  background: linear-gradient(135deg, #d97706, #ea580c) !important;
  color: #ffffff !important;
}

[data-theme="dark"] .btn-outline-dark {
  border: 2px solid var(--text-primary) !important;
  color: var(--text-primary) !important;
  background: transparent !important;
}

[data-theme="dark"] .btn-outline-dark:hover {
  background: var(--text-primary) !important;
  color: var(--bg-primary) !important;
}

[data-theme="dark"] .back-to-top {
  background: var(--orange-gradient) !important;
  color: #ffffff !important;
  border: none !important;
}

/* Fix dates.php Key Information section (glance-card) dark mode */
[data-theme="dark"] .glance-card {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .glance-card .stat-num {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .glance-card .stat-label {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .glance-card .glance-icon i {
  color: var(--orange-primary) !important;
}

[data-theme="dark"] .glance-card.highlighted {
  background: var(--bg-secondary) !important;
  border-color: var(--orange-primary) !important;
}

/* Fix apply.php hero section and content cards dark mode - Override inline styles */
[data-theme="dark"] body {
  background: var(--bg-primary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .page-header {
  background: 
    radial-gradient(900px 360px at 10% -10%, rgba(255,107,53,.18), transparent 60%),
    radial-gradient(900px 360px at 90% -20%, rgba(229,90,43,.16), transparent 60%),
    linear-gradient(180deg, var(--bg-primary), var(--bg-secondary)) !important;
}

[data-theme="dark"] .hero-subtitle {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .content-section {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-left-color: var(--orange-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .section-title {
  color: var(--orange-primary) !important;
  border-bottom-color: var(--orange-primary) !important;
}

[data-theme="dark"] .fee-card {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .note-box {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .table-fees {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .table-fees th {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .table-fees td {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .step {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .step .icon {
  background: var(--bg-secondary) !important;
  color: var(--orange-primary) !important;
}

[data-theme="dark"] .accordion-item {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .accordion-button {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .accordion-body {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
}

/* Fix dates.php and apply.php Section Pills navigation dark mode - Override inline styles */
[data-theme="dark"] .section-nav {
  background: var(--card-bg) !important;
  border-color: var(--border-color) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .section-nav .nav-link {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .section-nav .nav-link:hover {
  background: rgba(255, 107, 53, 0.15) !important;
  color: var(--orange-primary) !important;
}

[data-theme="dark"] .section-nav .nav-link.active {
  background: var(--orange-primary) !important;
  color: #ffffff !important;
}

/* Fix apply.php additional elements dark mode */
[data-theme="dark"] .sticky-cta {
  background: rgba(15, 23, 42, 0.95) !important;
  border-top-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

[data-theme="dark"] .badge-note {
  background: var(--card-bg) !important;
  color: var(--orange-primary) !important;
  border-color: var(--orange-primary) !important;
}

[data-theme="dark"] .fee-badge {
  background: rgba(255, 107, 53, 0.15) !important;
  color: var(--orange-primary) !important;
}

[data-theme="dark"] .requirement-list li::before {
  color: #22c55e !important;
}

[data-theme="dark"] .scroll-progress {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .stepper::before {
  background: linear-gradient(180deg, var(--border-color), var(--bg-tertiary)) !important;
}

[data-theme="dark"] #toTop {
  background: var(--orange-primary) !important;
  border-color: var(--orange-primary) !important;
  color: #ffffff !important;
}

[data-theme="dark"] .divider-label {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .text-danger {
  color: #ef4444 !important;
}

/* Additional apply.php inline style overrides */
[data-theme="dark"] .step {
  background: var(--card-bg) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] .step:hover {
  background: var(--bg-secondary) !important;
}

[data-theme="dark"] .step h5 {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .step small {
  color: var(--text-muted) !important;
}

/* Override apply.php page body background */
[data-theme="dark"] body.apply-page,
[data-theme="dark"] html body {
  background: var(--bg-primary) !important;
}

/* ========================================
   APPLY.PHP SPECIFIC STYLES (moved from inline)
   ======================================== */

/* Apply page variables */
.apply-page {
  --nav-offset: 84px; /* updated at runtime */
  --ring: 0 0 0 .25rem rgba(255,107,53,.15);
}

/* Apply page layout */
.apply-page html,
.apply-page body {
  height: 100%;
}

.apply-page body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: #fff;
  color: var(--ink);
}

.apply-page main {
  flex: 1 0 auto;
}

/* Apply page brand theme overrides */
.apply-page .btn-primary {
  background: var(--orange-primary);
  border-color: var(--orange-primary);
}

.apply-page .btn-primary:hover,
.apply-page .btn-primary:focus {
  background: var(--orange-dark);
  border-color: var(--orange-dark);
}

.apply-page .btn-outline-primary {
  color: var(--orange-primary);
  border-color: var(--orange-primary);
}

.apply-page .btn-outline-primary:hover,
.apply-page .btn-outline-primary:focus {
  background: var(--orange-primary);
  border-color: var(--orange-primary);
  color: #fff;
}

.apply-page .text-primary {
  color: var(--orange-primary) !important;
}

.apply-page .hero-title {
  color: var(--orange-primary) !important;
  font-weight: 800;
}

.apply-page .form-control:focus,
.apply-page .btn:focus {
  box-shadow: var(--ring);
}

/* Apply page navbar accent */
.apply-page .navbar-light .navbar-nav .nav-link.active,
.apply-page .navbar-light .navbar-nav .nav-link:hover {
  color: var(--orange-primary) !important;
}

/* Apply page header */
.apply-page .page-header {
  position: relative;
  padding: calc(2.25rem + var(--nav-offset)) 0 2rem;
  background:
    radial-gradient(900px 360px at 10% -10%, rgba(255,107,53,.18), transparent 60%),
    radial-gradient(900px 360px at 90% -20%, rgba(229,90,43,.16), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.96));
  overflow: hidden;
}

.apply-page .page-header:after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(0,0,0,.06) 1px, transparent 1px);
  background-size: 18px 18px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 65%);
}

.apply-page .header-wave {
  display: block;
  width: 100%;
  height: 64px;
  margin-top: .5rem;
}

.apply-page .hero-subtitle {
  color: var(--muted);
}

/* Apply page section pills */
.apply-page .section-nav {
  position: sticky;
  top: calc(var(--nav-offset) + .5rem);
  z-index: 1020;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 999px;
  padding: .4rem;
  box-shadow: var(--card-shadow);
  backdrop-filter: saturate(140%) blur(6px);
}

.apply-page .section-nav .nav-link {
  border-radius: 999px;
  transition: all .2s;
}

.apply-page .section-nav .nav-link.active {
  background: var(--orange-primary);
  color: #fff;
}

.apply-page .section-nav .nav-link:hover {
  background: rgba(255,107,53,.08);
}

/* Apply page scroll progress */
.apply-page .scroll-progress {
  position: sticky;
  top: 0;
  z-index: 1031;
  height: 4px;
  background: transparent;
}

.apply-page .scroll-progress .bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--orange-primary), var(--orange-dark));
  box-shadow: 0 0 12px rgba(229,90,43,.35);
  transition: width .15s ease-out;
}

/* Apply page content sections */
.apply-page .content-section {
  background: #fff;
  border-radius: 16px;
  padding: 1.5rem 1.25rem;
  box-shadow: var(--card-shadow);
  margin-bottom: 1.25rem;
  border-left: 4px solid var(--orange-primary);
}

@media (min-width:768px) {
  .apply-page .content-section {
    padding: 2rem;
  }
}

.apply-page .section-title {
  color: var(--orange-primary);
  border-bottom: 2px solid var(--orange-primary);
  padding-bottom: .5rem;
  margin-bottom: 1rem;
  font-weight: 800;
  letter-spacing: .2px;
}

/* Apply page fees table/cards */
.apply-page .table-fees {
  margin: 0;
}

.apply-page .table-fees th {
  background: #f8f9fa;
  font-weight: 600;
}

.apply-page .note-box {
  background: #fff3cd;
  border: 1px solid #ffe69c;
  color: #664d03;
  border-radius: 10px;
  padding: 1rem 1.25rem;
}

.apply-page .fee-card {
  border: 1px solid #eee;
  border-radius: 12px;
  padding: 1rem;
  box-shadow: var(--card-shadow);
}

.apply-page .fee-badge {
  background: rgba(255,107,53,.1);
  color: var(--orange-dark);
  border-radius: 999px;
  padding: .25rem .55rem;
  font-weight: 600;
}

/* Apply page timeline/stepper */
.apply-page .stepper {
  position: relative;
  margin-left: .25rem;
}

.apply-page .stepper::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, #ffd7c9, #ffc2aa);
}

.apply-page .step {
  position: relative;
  display: flex;
  gap: .9rem;
  align-items: flex-start;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 12px;
  padding: 1rem 1rem 1rem 1.1rem;
  margin-left: 0;
  margin-bottom: 1rem;
  box-shadow: var(--card-shadow);
  transition: transform .15s ease, box-shadow .15s ease;
}

.apply-page .step:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(2,6,23,.12);
}

.apply-page .step .icon {
  position: relative;
  z-index: 1;
  flex: 0 0 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg,var(--orange-primary),var(--orange-dark));
  color: #fff;
  font-size: 1.2rem;
  box-shadow: 0 10px 18px rgba(229,90,43,.28);
}

.apply-page .step.current {
  border-color: var(--orange-primary);
}

.apply-page .badge-note {
  background: #fff;
  color: var(--orange-primary);
  border: 1px solid var(--orange-primary);
}

.apply-page .divider-label {
  font-size: .85rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: .65rem 0 .25rem;
}

/* Apply page lists */
.apply-page .requirement-list {
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
}

.apply-page .requirement-list li {
  position: relative;
  padding-left: 1.6rem;
  margin: .35rem 0;
}

.apply-page .requirement-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #198754;
  font-weight: 700;
}

/* Apply page sticky CTA */
.apply-page .sticky-cta {
  position: sticky;
  bottom: 0;
  z-index: 1010;
  background: rgba(255,255,255,.95);
  backdrop-filter: saturate(120%) blur(6px);
  border-top: 1px solid #eee;
}

/* Apply page back-to-top */
.apply-page #toTop {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  display: none;
  z-index: 1031;
  border-radius: 999px;
}

/* ========================================
   PRINT STYLES
   ======================================== */

@media print {
    .about-preview {
        background: white !important;
    }
    
    .stats-card,
    .cta-card {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }
}