/* Self-hosted fonts */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('assets/fonts/inter/Inter-Variable.woff2') format('woff2-variations');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Reset */
*{margin:0;padding:0;box-sizing:border-box}

/* Warna & pembolehubah */
:root{
  --pas-green:#006B3C; --pas-green-dark:#004A2A; --pas-green-light:#00A157; --pas-green-pale:#E8F5F0;
  --pas-white:#FFFFFF; --pas-cream:#F8F9FA; --pas-gold:#FFD700; --pas-dark-gold:#DAA520;
  --text-primary:#1A1A1A; --text-secondary:#4A4A4A; --text-light:#6C757D;
  --border-light:#E5E5E5;
  --shadow-sm:0 2px 8px rgba(0,107,60,.1);
  --shadow-md:0 4px 12px rgba(0,107,60,.15);
  --shadow-lg:0 8px 25px rgba(0,107,60,.2);
  --radius-sm:6px; --radius-md:10px; --radius-lg:15px;
  --transition:all .3s cubic-bezier(.4,0,.2,1);

  /* alias */
  --primary-green:var(--pas-green);
  --white:var(--pas-white);
}

/* (Opsyenal) Inter lokal — letak fail di /assets/fonts/inter/Inter-Variable.woff2 */
@font-face{
  font-family:"Inter";
  src:url("/assets/fonts/inter/Inter-Variable.woff2") format("woff2-variations");
  font-weight:100 900; font-style:normal; font-display:swap;
}

body{
  font-family: "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  line-height:1.6; color:var(--text-primary); background:var(--white);
}

.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Header */
.header{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:4px solid var(--pas-green);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:1000}
.header-content{display:flex;align-items:center;justify-content:space-between;padding:15px 0}
.logo-section{display:flex;align-items:center;gap:15px}
.logo{width:80px;height:auto;border-radius:var(--radius-md)}
.site-title h1{font-size:1.5rem;font-weight:700;color:var(--primary-green);margin-bottom:2px}
.site-title p{font-size:.9rem;color:#6c757d}

.main-nav ul{display:flex;list-style:none;gap:2rem;align-items:center}
.main-nav a{text-decoration:none;color:var(--text-primary);font-weight:500;padding:8px 0;position:relative;transition:var(--transition)}
.main-nav a:hover{color:var(--pas-green);transform:translateY(-1px)}
.main-nav a::after{content:'';position:absolute;width:0;height:3px;bottom:-2px;left:50%;background:linear-gradient(90deg,var(--pas-gold) 0%,var(--pas-green) 100%);transition:.3s;transform:translateX(-50%);border-radius:2px}
.main-nav a:hover::after{width:100%}

/* Dropdown Menu */
.dropdown{position:relative;display:flex;align-items:center}
.dropdown-toggle{display:flex;align-items:center;gap:0.5rem}
.dropdown-toggle i{font-size:.8rem;transition:var(--transition)}
.dropdown:hover .dropdown-toggle i{transform:rotate(180deg)}
.dropdown-menu{
  position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);min-width:200px;opacity:0;visibility:hidden;transform:translateY(-10px);
  transition:all .3s ease;z-index:1000;padding:8px 0;margin-top:8px;
}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu li{width:100%}
.dropdown-menu a{
  padding:12px 20px;display:block;color:var(--text-primary);border-radius:0;background:transparent;
  font-weight:500;border-bottom:none;
}
.dropdown-menu a:hover{background:var(--pas-green-pale);color:var(--pas-green);transform:none}
.dropdown-menu a::after{display:none}

.mobile-menu-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;padding:12px;min-width:44px;min-height:44px;background:transparent;border:none;border-radius:var(--radius-sm);transition:var(--transition);touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,107,60,0.1)}
.mobile-menu-toggle:hover{background:rgba(0,107,60,0.05)}
.mobile-menu-toggle:active{background:rgba(0,107,60,0.1);transform:scale(0.95)}
.mobile-menu-toggle span{width:24px;height:3px;background:var(--primary-green);margin:2px 0;transition:var(--transition);border-radius:2px}
.mobile-menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(6px, 6px)}
.mobile-menu-toggle.active span:nth-child(2){opacity:0}
.mobile-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(6px, -6px)}

/* Breadcrumb */
.breadcrumb{background:var(--pas-cream);padding:12px 0;border-bottom:1px solid var(--border-light)}
.breadcrumb ol{display:flex;list-style:none;align-items:center;gap:8px;font-size:.9rem}
.breadcrumb li{display:flex;align-items:center}
.breadcrumb li:not(:last-child)::after{content:'›';margin-left:8px;color:var(--text-light);font-weight:bold}
.breadcrumb a{color:var(--pas-green);text-decoration:none;transition:var(--transition)}
.breadcrumb a:hover{color:var(--pas-green-dark);text-decoration:underline}
.breadcrumb .current{color:var(--text-secondary);font-weight:500}

/* Hero */
.hero{background:linear-gradient(135deg,var(--pas-green-dark) 0%,var(--pas-green) 50%,var(--pas-green-light) 100%);color:#fff;padding:100px 0;position:relative;text-align:center;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background-image:url('/assets/logo.jpeg');background-repeat:no-repeat;background-position:center;background-size:360px auto;opacity:.12}
.hero-content{position:relative;z-index:1}
.hero-text h1{font-size:2.8rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}
.hero-text p{font-size:1.2rem;margin-bottom:1rem;opacity:.9}

/* Hero Stats */
.hero-stats{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;margin:2rem 0;padding:1.5rem 0}
.stat{text-align:center;background:rgba(255,255,255,.1);padding:1.5rem 1rem;border-radius:var(--radius-lg);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:var(--transition);min-width:120px}
.stat:hover{background:rgba(255,255,255,.2);transform:translateY(-3px)}
.stat i{font-size:2rem;color:var(--pas-gold);margin-bottom:.5rem;display:block}
.stat span{font-size:2rem;font-weight:700;color:#fff;display:block;margin-bottom:.25rem}
.stat small{font-size:.9rem;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.5px}

.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}

/* Button */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);text-decoration:none;font-weight:600;font-size:1rem;transition:var(--transition);border:none;cursor:pointer}
.btn-primary{background:var(--pas-gold);color:#1a1a1a;box-shadow:var(--shadow-md);border:2px solid var(--pas-gold)}
.btn-primary:hover{background:var(--pas-dark-gold);border-color:var(--pas-dark-gold);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.btn-secondary{background:transparent;color:#fff;border:2px solid #fff}
.btn-secondary:hover{background:#fff;color:var(--pas-green);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--pas-green);border:2px solid var(--pas-green)}
.btn-outline:hover{background:var(--pas-green);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* Section */
section{padding:60px 0}
.section-header{text-align:center;margin-bottom:28px}
.section-header h2{font-size:2.2rem;font-weight:700;color:var(--primary-green);margin-bottom:15px}
.section-divider{width:80px;height:4px;background:var(--pas-gold);margin:0 auto 8px;border-radius:2px}
.section-header p{color:#6c757d;font-size:1.05rem}

/* News */
.news{background:var(--pas-cream)}
.news-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:900px;margin:0 auto 24px}
.news-item{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:24px;transition:var(--transition);position:relative;overflow:hidden}
.news-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--pas-green-light)}
.news-item.featured{border-left:4px solid var(--pas-gold);background:linear-gradient(135deg,#fff 0%,var(--pas-green-pale) 100%)}
.news-item.featured::before{content:'TERKINI';position:absolute;top:15px;right:15px;background:var(--pas-gold);color:#1a1a1a;padding:4px 8px;border-radius:3px;font-size:.65rem;font-weight:700;letter-spacing:.5px}
.news-date{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:.85rem;color:#6c757d}
.news-content h3{margin:0 0 10px;font-size:1.15rem;line-height:1.4;font-weight:600}
.news-content h3 a{color:var(--pas-green-dark);text-decoration:none}
.news-content h3 a:hover{color:var(--pas-green-light);text-decoration:underline}
.news-content p{color:#4a4a4a;line-height:1.6;margin-bottom:12px;font-size:.95rem}
.news-meta{display:flex;gap:15px;font-size:.82rem;color:#6c757d;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border-light)}
.news-meta i{font-size:.85rem;color:var(--pas-green)}
.news-more{text-align:center}

/* Jadual / Aturcara */
.schedule{background:var(--pas-cream)}
.schedule-days{display:grid;gap:40px}
.day-schedule{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}
.day-header{background:var(--primary-green);color:#fff;padding:25px 30px;text-align:center}
.day-header h3{font-size:1.5rem;margin-bottom:8px}
.schedule-items{padding:30px}
.schedule-item{display:grid;grid-template-columns:120px 1fr;gap:25px;padding:20px 0;border-bottom:1px solid var(--border-light)}
.schedule-item:last-child{border-bottom:none}
.schedule-item.highlight{background:var(--pas-green-pale);margin:0 -20px;padding:20px;border-radius:var(--radius-md);border:none}
.schedule-item.agenda{background:rgba(255,193,7,.1);margin:0 -20px;padding:20px;border-radius:var(--radius-md);border:none}
.time{font-weight:600;color:var(--primary-green);font-size:.95rem}


/* Video Featured Section */
.video-featured{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:2rem}
.featured-video{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:center}
.video-placeholder{aspect-ratio:16/9;background:var(--pas-green-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;position:relative}
.video-placeholder i{font-size:4rem;margin-bottom:1rem;color:var(--pas-gold)}
.video-placeholder span{font-size:1.2rem;font-weight:600}
.video-info{padding:2rem}
.video-info h3{color:var(--pas-green);font-size:1.5rem;margin-bottom:1rem}
.video-info p{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}
.video-meta{display:flex;gap:1rem;flex-wrap:wrap}
.video-meta span{background:var(--pas-green-pale);color:var(--pas-green);padding:6px 12px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500}

/* Toolbar (search/filter) */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;margin:12px 0}
.toolbar input[type="search"], .toolbar select{
  flex:1;min-width:220px;padding:10px;border:1px solid #dfe6e2;border-radius:8px;background:#fff
}
.live-toggle{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #dfe6e2;border-radius:8px;background:#f6faf8}

/* Dokumen */
.documents .document-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.filter-btn{border:1px solid #dbe7de;border-radius:999px;padding:8px 14px;background:#fff;cursor:pointer}
.filter-btn.active{background:#0b7a3b;color:#fff;border-color:#0b7a3b}
.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.doc-card{background:#fff;border:1px solid #e6efe8;border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,.05);overflow:hidden}
.doc-card__head{background:#0b7a3b;color:#fff;padding:12px 16px;display:flex;align-items:center;gap:10px}
.doc-card__icon{width:28px;height:28px;border-radius:6px;background:#f6fbdc;color:#2d3d00;display:flex;align-items:center;justify-content:center}
.doc-card__cat{font-weight:600}
.doc-card__body{padding:14px 16px}
.doc-card__title{margin:0 0 6px;font-size:18px}
.doc-card__desc{margin:0 0 10px;color:#555;min-height:44px}
.doc-card__meta{display:flex;gap:16px;color:#6a6a6a;font-size:13px;margin-bottom:12px}
.doc-card__actions{display:flex;gap:10px}
.btn.btn-warning{background:#ffc107;border:1px solid #e5b100;color:#000}

/* Contact */
.contact{background:#fff}
.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.contact-item{display:flex;align-items:flex-start;gap:20px;margin-bottom:30px}
.contact-item i{font-size:1.3rem;color:var(--primary-green);margin-top:5px}
.contact-item a{color:var(--primary-green);text-decoration:none;font-weight:500;border-bottom:1px solid var(--primary-green);transition:all 0.3s ease}
.contact-item a:hover{color:var(--pas-green-light);border-bottom-color:var(--pas-green-light);transform:translateY(-1px)}
.contact-form{background:var(--pas-green-pale);padding:35px;border-radius:var(--radius-lg)}
.form-group{margin-bottom:20px}
.form-group input,.form-group textarea{width:100%;padding:15px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:1rem;transition:var(--transition);background:#fff}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px rgba(27,94,32,.1)}
.btn-whatsapp{background:#25D366;color:#fff;border:none;width:100%;font-size:1.1rem;padding:15px 20px;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}
.btn-whatsapp:hover{background:#20BA5A;transform:translateY(-2px)}

/* Quick Access Section */
.quick-access{background:#fff;padding:60px 0}
.quick-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr)) !important;
  gap:2rem;margin-top:2rem;max-width:1400px;margin-left:auto;margin-right:auto;padding:0 1rem;
  /* Fallback untuk browser yang tak support grid */
  display:-webkit-flex !important;display:-ms-flexbox !important;display:flex !important;
  -webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;
  -webkit-justify-content:center;-ms-flex-pack:center;justify-content:center
}
.quick-item{
  flex:1 1 250px;min-width:250px;max-width:300px;
  background:var(--pas-cream);border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:2rem;
  text-align:center;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);
  /* Mobile touch optimization */
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(0,0,0,0.1);
  user-select: none;
}
.quick-item:hover{
  transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--pas-green);
  background:linear-gradient(135deg,var(--pas-green-pale) 0%,#fff 100%);
}
.quick-item i{font-size:3rem;color:var(--pas-green);margin-bottom:1rem;display:block;text-align:center;margin-left:auto;margin-right:auto}
.quick-item h3{color:var(--pas-green);font-size:1.3rem;margin-bottom:.5rem}
.quick-item p{color:var(--text-secondary);line-height:1.5}

/* PDF Viewer Styles */
.pdf-container {
  width: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow-sm);
  min-height: 80vh;
}

.pdf-iframe {
  min-height: 80vh !important;
  height: auto;
}

/* Tab content styling for PDF viewers */
.tab-content {
  min-height: 80vh;
}

.pdf-embed, .pdf-viewer {
  min-height: 80vh;
  display: flex;
  flex-direction: column;
}

.mobile-pdf-notice {
  background: linear-gradient(135deg, var(--pas-green-pale) 0%, #fff 100%);
  padding: 2rem;
  text-align: center;
  border-bottom: 1px solid var(--border-light);
}

.mobile-pdf-notice i {
  font-size: 3rem;
  color: var(--pas-green);
  margin-bottom: 1rem;
}

.mobile-pdf-notice h4 {
  color: var(--pas-green);
  margin-bottom: 0.5rem;
}

.mobile-pdf-notice p {
  color: var(--text-secondary);
  margin-bottom: 1.5rem;
}

.mobile-pdf-notice .btn {
  margin: 0.5rem;
}

.mobile-pdf-view {
  display: block;
  width: 100%;
  max-width: 300px;
  margin: 1.5rem auto 0 auto;
  padding: 1rem 2rem;
  font-size: 1.1rem;
  font-weight: 600;
  text-align: center;
  border-radius: var(--radius-lg);
}

.pdf-embed-fallback iframe {
  border: 0;
  border-radius: var(--radius-md);
}

.pdf-fallback {
  background: #f8f9fa;
  border: 2px dashed #dee2e6;
  border-radius: var(--radius-lg);
  padding: 2rem;
  text-align: center;
}

.pdf-fallback h4 {
  color: #e74c3c;
  margin-bottom: 1rem;
}

.pdf-fallback .btn {
  margin: 0.5rem;
}

/* PDF Fullscreen styles */
.pdf-fullscreen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 9999;
  background: #fff;
}

.pdf-fullscreen .pdf-iframe {
  width: 100%;
  height: 100vh !important;
  min-height: 100vh !important;
}

.pdf-exit-fullscreen {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(0,0,0,0.7);
  color: white;
  border: none;
  padding: 10px 15px;
  border-radius: 5px;
  cursor: pointer;
  z-index: 10000;
}

.pdf-exit-fullscreen:hover {
  background: rgba(0,0,0,0.9);
}

/* Gallery Section */
.gallery{background:var(--pas-cream)}
.gallery-filters{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.gallery-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;
}
.gallery-item{
  position:relative;overflow:hidden;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);
  cursor:pointer;transition:var(--transition);aspect-ratio:4/3;
}
.gallery-item:hover{transform:scale(1.03);box-shadow:var(--shadow-lg)}
.gallery-item img{width:100%;height:100%;object-fit:cover}
.gallery-overlay{
  position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));
  color:#fff;padding:1.5rem 1rem .75rem;transform:translateY(100%);transition:var(--transition);
}
.gallery-item:hover .gallery-overlay{transform:translateY(0)}
.gallery-overlay h4{font-size:1.1rem;margin-bottom:.5rem}
.gallery-overlay p{font-size:.9rem;opacity:.9;line-height:1.4}
.gallery-more{text-align:center}

/* Archive Section */
.archive{background:#fff}
.archive-years{text-align:center;margin-bottom:2rem}
.year-selector select{
  padding:12px 24px;border:2px solid var(--border-light);border-radius:var(--radius-md);
  font-size:1.1rem;background:#fff;color:var(--text-primary);min-width:250px;
}
.year-selector select:focus{outline:none;border-color:var(--pas-green);box-shadow:0 0 0 3px rgba(0,107,60,.1)}
.archive-placeholder{
  text-align:center;padding:4rem 2rem;color:var(--text-light);
}
.archive-placeholder i{font-size:4rem;color:var(--pas-green);margin-bottom:1rem}
.archive-placeholder h3{color:var(--text-primary);margin-bottom:1rem}
.archive-content{min-height:200px}

/* FAQ Section */
.faq{background:var(--pas-cream)}

/* Footer */
.footer{background:var(--primary-green);color:#fff;padding:50px 0 20px}
.footer-content{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-bottom:30px}
.footer-section h4{font-size:1.2rem;margin-bottom:20px;color:var(--pas-gold);font-weight:600}
.footer-section a{color:rgba(255,255,255,.85);text-decoration:none}
.footer-section a:hover{color:var(--pas-gold)}
.footer-bottom{text-align:center;padding-top:25px;border-top:1px solid rgba(255,255,255,.2)}

/* Responsif */
@media (max-width:768px){
  .main-nav{display:none}
  .mobile-menu-toggle{display:flex}
  .main-nav.mobile-active{display:flex;position:fixed;top:80px;left:0;width:100%;height:calc(100vh - 80px);background:#fff;flex-direction:column;justify-content:flex-start;padding:20px;z-index:999;box-shadow:var(--shadow-lg);animation:slideIn .3s ease-out}
  .main-nav.mobile-active ul{flex-direction:column;gap:1rem;width:100%}
  .main-nav.mobile-active a{padding:15px 20px;border-radius:var(--radius-md);background:var(--pas-green-pale);text-align:center;display:block;font-weight:600}
  
  /* Mobile dropdown */
  .main-nav.mobile-active .dropdown{position:relative}
  .main-nav.mobile-active .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;margin-top:0.5rem}
  .main-nav.mobile-active .dropdown-menu li{border:none}
  .main-nav.mobile-active .dropdown-menu a{background:rgba(0,107,60,0.1);margin-bottom:0.25rem;border-radius:var(--radius-sm)}
  
  
  .logo{width:60px}
  .hero-text h1{font-size:2rem}
  .toolbar input[type="search"], .toolbar select{flex:1 1 100%}
  .contact-content{grid-template-columns:1fr}
  .quick-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
}

/* Tablet screens */
@media (min-width: 768px) and (max-width: 1199px) {
  .quick-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr)) !important;gap:1.5rem}
}

/* Desktop large screens - ensure proper grid layout */
@media (min-width: 1200px) {
  .quick-grid{grid-template-columns:repeat(5,1fr) !important;gap:2rem}
}

/* Special Programs Section */
.special-programs{background:var(--pas-green-pale);padding:60px 0}
.special-programs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem;margin-top:2rem}
.special-program-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition)}
.special-program-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.program-header{background:linear-gradient(135deg,var(--pas-green) 0%,var(--primary-green) 100%);color:#fff;padding:2rem;text-align:center}
.program-icon{font-size:3rem;margin-bottom:1rem}
.program-header h3{font-size:1.5rem;margin-bottom:.5rem}
.program-badge{background:rgba(255,255,255,.2);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}
.program-details{padding:2rem}
.program-info{margin-bottom:1.5rem}
.info-item{display:flex;align-items:center;margin-bottom:.8rem;color:var(--text-secondary)}
.info-item i{color:var(--pas-green);margin-right:.8rem;width:20px}
.program-description h4{color:var(--pas-green);margin:1rem 0 .5rem}
.program-description ul{margin-left:1.5rem}
.program-description li{margin-bottom:.5rem;color:var(--text-secondary)}

/* Program Timeline Enhancement */
.timeline{position:relative;max-width:800px;margin:0 auto}
.timeline-item{display:flex;margin-bottom:3rem}
.timeline-date{margin-right:2rem}
.date-box{background:var(--pas-green);color:#fff;padding:1rem;border-radius:var(--radius-md);text-align:center;min-width:80px}
.date-box .day{display:block;font-size:2rem;font-weight:700}
.date-box .month{font-size:.9rem;text-transform:uppercase}
.timeline-content{flex:1;background:#fff;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm)}
.timeline-content h3{color:var(--pas-green);margin-bottom:1rem}
.program-list{margin-top:1rem}
.program-item{display:flex;align-items:center;padding:.8rem 0;border-bottom:1px solid var(--border-light)}
.program-item:last-child{border-bottom:none}
.program-item .time{background:var(--pas-green-pale);color:var(--pas-green);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;margin-right:1rem;min-width:100px;text-align:center}
.program-item .program{flex:1;color:var(--text-primary)}

/* Program Facilities */
.program-facilities{background:#fff;padding:60px 0}
.facilities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}
.facility-item{text-align:center;padding:2rem;background:var(--pas-cream);border-radius:var(--radius-lg);transition:var(--transition)}
.facility-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.facility-item i{font-size:3rem;color:var(--pas-green);margin-bottom:1rem}
.facility-item h4{color:var(--pas-green);margin-bottom:.5rem}

/* Ucapan Pages Styling */
.ucapan-content, .ucaptama-tabs{background:#fff;padding:60px 0}

/* Document Viewer Styling */
.document-viewer{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:2rem 0;overflow:hidden}
.viewer-header{background:linear-gradient(135deg,var(--pas-green) 0%,var(--primary-green) 100%);color:#fff;padding:2rem;text-align:center}
.viewer-header h3{font-size:1.5rem;margin-bottom:.5rem}
.viewer-header p{font-size:1rem;opacity:.9}

/* PDF Embedded Styling */
.pdf-embed{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:2rem 0;overflow:hidden}
.pdf-header{background:linear-gradient(135deg,var(--pas-green) 0%,var(--primary-green) 100%);color:#fff;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}
.pdf-header h4{font-size:1.2rem;margin:0;display:flex;align-items:center;gap:.5rem}
.pdf-actions{display:flex;gap:1rem}
.pdf-actions .btn{padding:.7rem 1.2rem;font-size:.9rem}
.pdf-viewer{background:#f5f5f5;padding:0;position:relative;min-height:600px}
.pdf-viewer iframe{width:100%;height:800px;border:none;display:block}

/* PDF Loading Fallback */
.pdf-large-file{padding:3rem;text-align:center;background:#f9f9f9}
.pdf-large-file i{font-size:4rem;color:var(--pas-green);margin-bottom:1.5rem}
.pdf-large-file h4{color:var(--pas-green);margin-bottom:1rem}
.pdf-large-file p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}
.pdf-large-file .file-size{background:var(--pas-green-pale);padding:1rem;border-radius:var(--radius-md);margin:1rem 0;font-weight:600}
.pdf-large-file .download-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Legacy fallback styling */
.pdf-container{position:relative;background:#f5f5f5;min-height:600px}
.pdf-container iframe{width:100%;height:100%;display:block}
.pdf-fallback{display:none;padding:3rem;text-align:center;background:#f9f9f9}
.pdf-fallback.show{display:block}
.fallback-content i{font-size:4rem;color:var(--pas-green);margin-bottom:1rem}
.fallback-content h4{color:var(--pas-green);margin-bottom:1rem}
.fallback-content p{color:var(--text-secondary);margin-bottom:2rem}

/* Responsive PDF Embed */
@media (max-width: 768px) {
  .pdf-header{flex-direction:column;gap:1rem;text-align:center;padding:1rem}
  .pdf-actions{flex-direction:column;width:100%}
  .pdf-viewer iframe{height:600px}
  .pdf-large-file{padding:2rem 1rem}
  .pdf-large-file .download-actions{flex-direction:column}
  .pdf-large-file .btn{width:100%}
}

/* Legacy paper styling for compatibility */
.ucapan-paper, .ucaptama-paper{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:2rem 0;overflow:hidden}
.paper-header{background:linear-gradient(135deg,var(--pas-green) 0%,var(--primary-green) 100%);color:#fff;padding:2rem;text-align:center}
.paper-content{padding:3rem;line-height:1.8;color:var(--text-primary)}
.download-section{text-align:center;margin-top:3rem}
.download-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1rem}

/* Ucaptama Tabs */
.tabs-navigation{display:flex;gap:0;background:var(--border-light);border-radius:var(--radius-lg);overflow:hidden;margin:2rem 0}
.tab-btn{flex:1;background:#fff;border:none;padding:1.5rem;font-size:1rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-right:1px solid var(--border-light)}
.tab-btn:last-child{border-right:none}
.tab-btn:hover{background:var(--pas-green-pale);color:var(--pas-green)}
.tab-btn.active{background:var(--pas-green);color:#fff}
.tab-btn i{display:block;font-size:1.5rem;margin-bottom:.5rem}


.tab-content{display:none}
.tab-content.active{display:block}

/* Program Section Styles */
.program-section{background:linear-gradient(135deg,#f8f9fa,#fff);padding:60px 0}

/* Enhanced Mobile Responsiveness */
@media (max-width: 768px) {
  /* General mobile adjustments */
  .container{padding:0 1rem}
  .section-header h2{font-size:2rem}
  .section-header p{font-size:0.95rem}
  
  /* Header and navigation */
  .header-content{flex-wrap:wrap}
  .site-title h1{font-size:1.25rem}
  .site-title p{font-size:0.875rem}
  
  /* Hero section */
  .hero{padding:3rem 0}
  .hero-text h1{font-size:2.5rem}
  .hero-buttons{flex-direction:column;gap:1rem}
  .hero-buttons .btn{width:100%;text-align:center}
  
  /* Quick access grid */
  .quick-access{grid-template-columns:repeat(2, 1fr);gap:1rem}
  .quick-item{padding:1.5rem 1rem;text-align:center}
  .quick-item i{font-size:2rem}
  .quick-item h3{font-size:1rem}
  
  /* Stats section */
  .hero-stats{grid-template-columns:repeat(2, 1fr);gap:1rem}
  .stat{padding:1rem}
  
  /* Toolbar adjustments */
  .toolbar{flex-direction:column;gap:1rem}
  .toolbar input, .toolbar select{width:100%}
  .live-toggle{justify-self:start}
  
  /* Video and gallery grids */
  .video-grid, .gallery-grid, .news-grid{grid-template-columns:1fr;gap:1rem}
  .doc-grid{grid-template-columns:1fr;gap:1rem}
  
  /* Document filters */
  .document-filters{flex-wrap:wrap;gap:0.5rem}
  .filter-btn{font-size:0.875rem;padding:0.5rem 0.75rem}
  
  /* Tab navigation */
  .tabs-navigation{flex-direction:column}
  .tab-btn{border-right:none;border-bottom:1px solid var(--border-light)}
  .tab-btn:last-child{border-bottom:none}
  
  /* PDF viewer adjustments */
  .pdf-header{flex-direction:column;gap:1rem;text-align:center}
  .pdf-actions{justify-content:center}
  .pdf-viewer iframe{height:400px}
  
  /* Modal adjustments */
  .photo-modal-content{margin:1rem;max-width:95%;max-height:95%}
  .photo-modal-info{padding:0.75rem}
  
  /* Footer */
  .footer-content{grid-template-columns:1fr;gap:2rem;text-align:center}
  
  /* FAQ mobile adjustments */
  .faq-question{padding:1rem}
  .faq-question h3{font-size:1rem}
  .faq-item.active .faq-answer{padding:1rem}
  
  /* Archive/Documents mobile adjustments */
  .year-selector select{min-width:100%;padding:0.75rem 1rem;font-size:1rem}
  .year-header{padding:1.5rem 1rem}
  .year-header h3{font-size:1.25rem}
  .year-header p{font-size:1rem}
  .search-bar{flex-direction:column}
  .search-bar input, .search-bar select{flex:none}
  .document-item{flex-direction:column;text-align:center;padding:1rem}
  .doc-icon{margin:0 auto 1rem}
  .doc-actions{margin:1rem 0 0}
  
  /* Dewan links mobile adjustments */
  .dewan-schedule-links{padding:1.5rem 1rem}
  .dewan-links{flex-direction:column}
  .dewan-link{justify-content:center;padding:1rem}
}

@media (max-width: 480px) {
  /* Extra small screens */
  .hero-text h1{font-size:2rem}
  .quick-access{grid-template-columns:1fr;gap:0.75rem}
  .hero-stats{grid-template-columns:1fr}
  
  /* Smaller buttons and text */
  .btn{padding:0.75rem 1.5rem;font-size:0.875rem}
  .quick-item{
    padding:1rem;
    /* Ensure adequate touch target size (minimum 44px) */
    min-height:120px;
    /* Improve touch responsiveness */
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(0,0,0,0.1);
  }
  .quick-item i{font-size:1.75rem}
  .quick-item h3{font-size:0.95rem}
  
  /* Mobile PDF styles */
  .mobile-pdf-notice {
    padding: 2rem 1rem;
    text-align: center;
  }
  
  .mobile-pdf-notice i {
    font-size: 4rem;
    color: var(--pas-green);
    margin-bottom: 1rem;
  }
  
  .mobile-pdf-notice h4 {
    font-size: 1.5rem;
    color: var(--pas-green);
    margin-bottom: 0.75rem;
  }
  
  .mobile-pdf-notice p {
    font-size: 1rem;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
  }
  
  .file-warning {
    color: #f39c12 !important;
    font-weight: 600;
    font-size: 0.9rem !important;
    margin-bottom: 0.5rem !important;
  }
  
  .mobile-pdf-view {
    padding: 1.25rem 2rem;
    font-size: 1.2rem;
    max-width: 250px;
  }
  
  /* Mobile PDF container adjustments */
  .pdf-container {
    min-height: 70vh;
  }
  
  .pdf-iframe {
    min-height: 70vh !important;
    height: 800px;
  }
  
  /* Schedule adjustments */
  .schedule-item{padding:1rem;font-size:0.875rem}
  .time{font-size:0.75rem;min-width:4rem}
  
  
  
  /* Photo modal */
  .photo-modal-content{margin:0.5rem}
  .photo-modal-close{top:-30px;font-size:1.5rem}
}

/* Overlay animasi */
.menu-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:998;backdrop-filter:blur(2px)}
.menu-overlay.active{display:block;animation:fadeIn .3s ease-out}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}

/* Aksesibiliti */
.btn:focus,.main-nav a:focus{outline:3px solid var(--pas-gold);outline-offset:2px}

/* FAQ Styling */
.faq-section{background:var(--pas-cream);padding:4rem 0}
.faq-grid{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.faq-item{background:var(--pas-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s ease}
.faq-item:hover{border-color:var(--pas-green);box-shadow:var(--shadow-md)}
.faq-item.active{border-color:var(--pas-green);box-shadow:var(--shadow-lg)}
.faq-category{background:var(--pas-green);color:var(--pas-white);padding:.5rem 1rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.faq-question{padding:1.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .3s ease;position:relative}
.faq-question:hover{background:var(--pas-cream)}
.faq-question h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600;line-height:1.4;flex:1;padding-right:1rem}
.faq-question i{color:var(--pas-green);font-size:1.2rem;transition:transform .3s ease;flex-shrink:0}
.faq-item.active .faq-question i{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;color:var(--text-secondary);line-height:1.6;border-top:1px solid var(--border-light)}
.faq-item.active .faq-answer{max-height:300px;padding:1.5rem}
.faq-answer p{margin:0}
.faq-answer.collapsed{max-height:0;padding:0 1.5rem}

/* Dewan Schedule Links */
.dewan-schedule-links{background:var(--pas-green-pale);border-radius:var(--radius-lg);padding:2rem;margin:2rem 0}
.dewan-schedule-links h3{text-align:center;color:var(--pas-green-dark);margin:0 0 1.5rem;font-size:1.25rem}
.dewan-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.dewan-link{display:flex;align-items:center;gap:0.5rem;padding:0.75rem 1.5rem;background:var(--pas-white);color:var(--pas-green);text-decoration:none;border-radius:var(--radius-md);border:1px solid var(--pas-green);transition:all .3s ease;font-weight:600}
.dewan-link:hover{background:var(--pas-green);color:var(--pas-white);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.dewan-link i{font-size:1rem}
.dewan-link span{white-space:nowrap}

.schedule-main{margin-top:2rem}
.schedule-main h3{color:var(--pas-green-dark);margin-bottom:1.5rem;font-size:1.25rem;text-align:center}

/* Archive & Documents Styling */
.year-selector{margin:2rem 0;text-align:center}
.year-selector select{padding:1rem 2rem;border:2px solid var(--pas-green);border-radius:var(--radius-lg);background:var(--pas-white);color:var(--pas-green);font-size:1.125rem;font-weight:600;cursor:pointer;min-width:300px}
.year-selector select:focus{outline:none;box-shadow:0 0 0 3px var(--pas-green-pale)}

.year-content{margin-top:2rem}
.year-section{display:none}
.year-section.active{display:block}

.year-header{text-align:center;margin:2rem 0;padding:2rem;background:var(--pas-green-pale);border-radius:var(--radius-lg)}
.year-header h3{color:var(--pas-green-dark);margin:0 0 0.5rem;font-size:1.5rem}
.year-header p{color:var(--text-secondary);margin:0;font-size:1.1rem}

.documents-search{margin:2rem 0}
.search-bar{display:flex;gap:1rem;align-items:center}
.search-bar input{flex:2;padding:0.75rem;border:1px solid var(--border-light);border-radius:var(--radius-md)}
.search-bar select{flex:1;padding:0.75rem;border:1px solid var(--border-light);border-radius:var(--radius-md)}

.documents-list{background:var(--pas-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.document-item{display:flex;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-light);transition:background-color .2s ease}
.document-item:last-child{border-bottom:none}
.document-item:hover{background:var(--pas-cream)}

.doc-icon{width:40px;height:40px;background:var(--pas-green);color:white;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-right:1rem;flex-shrink:0}
.doc-icon i{font-size:1.2rem}

.doc-info{flex:1;min-width:0}
.doc-title{font-weight:600;color:var(--text-primary);margin:0 0 0.25rem;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-meta{display:flex;gap:1rem;font-size:0.875rem;color:var(--text-secondary);flex-wrap:wrap}
.doc-category{background:var(--pas-green-pale);color:var(--pas-green-dark);padding:0.25rem 0.5rem;border-radius:var(--radius-sm);font-size:0.75rem;font-weight:600}
.doc-date{color:var(--pas-green);font-weight:500;display:flex;align-items:center;gap:4px}
.doc-size{color:var(--text-muted);display:flex;align-items:center;gap:4px}

.doc-actions{margin-left:1rem;display:flex;gap:0.5rem}
.doc-btn{padding:0.5rem 1rem;border:1px solid var(--pas-green);color:var(--pas-green);background:transparent;border-radius:var(--radius-sm);text-decoration:none;font-size:0.875rem;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:0.5rem}
.doc-btn:hover{background:var(--pas-green);color:white}
.doc-btn i{font-size:0.875rem}

/* Photo Gallery Styling */
.gallery-item{cursor:pointer;position:relative;border-radius:var(--radius-lg);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.gallery-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gallery-item img{width:100%;height:200px;object-fit:cover;display:block}
.gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));color:white;padding:1rem;transform:translateY(100%);transition:transform .3s ease}
.gallery-item:hover .gallery-overlay{transform:translateY(0)}
.gallery-overlay h4{margin:0 0 .5rem;font-size:1rem;font-weight:600}
.gallery-overlay p{margin:0;font-size:.875rem;opacity:.9}
.gallery-category{position:absolute;top:8px;right:8px;background:var(--pas-green);color:white;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}

/* Photo Modal */
.photo-modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.9);animation:fadeIn .3s ease}
.photo-modal-content{position:relative;margin:2% auto;max-width:90%;max-height:90%;text-align:center}
.photo-modal-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-lg)}
.photo-modal-close{position:absolute;top:-40px;right:0;color:white;font-size:2rem;font-weight:bold;cursor:pointer;z-index:1001}
.photo-modal-close:hover{color:var(--pas-gold)}
.photo-modal-info{background:rgba(0,0,0,.8);color:white;padding:1rem;border-radius:var(--radius-lg);margin-top:1rem}
.photo-modal-info h3{margin:0 0 .5rem;color:white}
.photo-modal-info p{margin:0;opacity:.9}

/* Dark mode asas */
@media (prefers-color-scheme: dark){
  :root{--pas-white:#1a1a1a;--pas-cream:#2d2d2d;--text-primary:#fff;--text-secondary:#ccc;--text-light:#999;--border-light:#404040;--pas-green-pale:#1a3428}
  .header{background:rgba(26,26,26,.95)}
  .day-schedule,.news-item,.hotel-card,.faq-item{background:var(--pas-cream);border-color:var(--border-light)}
  .contact-form{background:var(--pas-green-pale)}
}

/* Dark mode / Battery saver compatibility */
@media (prefers-color-scheme: dark) {
  :root {
    --bg-primary: #1a1a1a;
    --bg-secondary: #2d2d2d;
    --text-primary: #ffffff;
    --text-secondary: #cccccc;
    --text-muted: #999999;
    --border-light: #404040;
    --loading-overlay-bg: rgba(26,26,26,0.9);
  }
  
  body {
    background: var(--bg-primary) !important;
    color: var(--text-primary) !important;
  }
  
  .header {
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border-light) !important;
    color: var(--text-primary) !important;
  }
  
  .video {
    background: var(--bg-primary) !important;
  }
  
  .card {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-light) !important;
    color: var(--text-primary) !important;
  }
  
  .loading-overlay {
    background: var(--loading-overlay-bg) !important;
  }
  
  .schedule, .gallery, .news, .faq-section {
    background: var(--bg-primary) !important;
    color: var(--text-primary) !important;
  }
  
  .year-content, .year-section, .dewan-schedule-links, .schedule-main {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
  }
  
  /* Force white backgrounds for form elements */
  input, select, textarea {
    background: white !important;
    color: #333 !important;
    border: 1px solid var(--border-light) !important;
  }
  
  /* Ensure buttons remain visible */
  .btn {
    background: var(--primary-green) !important;
    color: white !important;
    border: 1px solid var(--primary-green) !important;
  }
  
  .btn-outline {
    background: transparent !important;
    color: var(--primary-green) !important;
    border: 1px solid var(--primary-green) !important;
  }
  
  /* Fix section backgrounds */
  .hero {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
  }
  
  .footer {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-top: 1px solid var(--border-light) !important;
  }
  
  /* Fix video toolbar for all dark mode devices */
  .toolbar {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-light) !important;
  }
  
  /* Fix section headers */
  .section-header h2 {
    color: var(--text-primary) !important;
  }
  
  .section-header p {
    color: var(--text-secondary) !important;
  }
  
  /* Fix live toggle in general dark mode */
  .live-toggle {
    background: white !important;
    color: #333 !important;
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
    padding: 0.5rem 1rem !important;
  }
  
  .live-toggle input[type="checkbox"] {
    background: white !important;
    border: 2px solid var(--primary-green) !important;
  }
  
  .live-toggle span {
    color: #333 !important;
  }
  
  /* Fix contact info visibility */
  .contact-info, .contact {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
  }
  
  .contact-item {
    color: var(--text-primary) !important;
  }
  
  .contact-item h4 {
    color: var(--text-primary) !important;
  }
  
  .contact-item p {
    color: var(--text-secondary) !important;
  }
  
  .contact-item a {
    color: var(--primary-green) !important;
  }
  
  .contact-item i {
    color: var(--primary-green) !important;
  }
}

/* Force light mode for critical UI elements regardless of dark mode */
.year-selector select,
.search-bar input,
.search-bar select,
.toolbar input,
.toolbar select,
.documents-search input,
.documents-search select {
  background: white !important;
  color: #333 !important;
  border: 1px solid #ddd !important;
}

/* Mobile dark mode fixes */
@media (max-width: 768px) and (prefers-color-scheme: dark) {
  /* Ensure proper contrast and layout */
  .container {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  
  /* Fix header positioning */
  .header {
    position: relative !important;
    z-index: 1000 !important;
  }
  
  /* Fix mobile menu */
  .mobile-menu {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-light) !important;
  }
  
  /* Fix footer positioning */
  .footer {
    position: relative !important;
    margin-top: 2rem !important;
  }
  
  /* Prevent content overflow */
  body {
    overflow-x: hidden !important;
  }
  
  /* Fix any floating elements */
  .floating, .fixed-element, .sticky-element {
    position: relative !important;
    transform: none !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
  }
  
  /* Ensure cards don't break layout */
  .card, .news-item, .document-item {
    max-width: 100% !important;
    margin: 0.5rem 0 !important;
  }
  
  /* Fix video toolbar in dark mode mobile */
  .toolbar {
    background: var(--bg-secondary) !important;
    padding: 1rem !important;
    border-radius: 8px !important;
    margin: 1rem 0 !important;
    border: 1px solid var(--border-light) !important;
  }
  
  /* Fix checkbox and label visibility */
  .live-toggle {
    background: white !important;
    color: #333 !important;
    padding: 0.75rem 1rem !important;
    border-radius: 6px !important;
    border: 1px solid #ddd !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    min-height: 44px !important; /* Touch target */
  }
  
  .live-toggle input[type="checkbox"] {
    background: white !important;
    border: 2px solid var(--primary-green) !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
  }
  
  .live-toggle span {
    color: #333 !important;
    font-weight: 500 !important;
  }
  
  /* Video section background */
  .video {
    background: var(--bg-primary) !important;
    padding: 2rem 0 !important;
  }
  
  /* Video header */
  .section-header h2 {
    color: var(--text-primary) !important;
  }
  
  /* Fix contact section in mobile dark mode */
  .contact {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    padding: 2rem 0 !important;
  }
  
  .contact-content {
    background: var(--bg-secondary) !important;
  }
  
  .contact-info {
    background: var(--bg-secondary) !important;
  }
  
  .contact-item {
    background: var(--bg-primary) !important;
    padding: 1rem !important;
    border-radius: 8px !important;
    margin-bottom: 1rem !important;
    border: 1px solid var(--border-light) !important;
  }
  
  .contact-item h4 {
    color: var(--text-primary) !important;
    font-size: 1.1rem !important;
    margin-bottom: 0.5rem !important;
  }
  
  .contact-item p {
    color: var(--text-secondary) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
  }
  
  .contact-item a {
    color: var(--primary-green) !important;
    text-decoration: underline !important;
    font-weight: 500 !important;
  }
  
  .contact-item a:hover {
    color: var(--pas-green-light) !important;
    text-decoration: none !important;
  }
  
  .contact-item i {
    color: var(--primary-green) !important;
    font-size: 1.2rem !important;
  }
}

/* Additional safety for battery saver mode */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
