:root{
  --maroon:#083D62;
  --gold:#d4a017;
  --dark:#111;
  --muted:#666;
  --container:1100px;
  --radius:12px;
}

*{
  box-sizing: border-box;
  text-decoration: none;
  list-style: none;
}

html,body{
  height:100%;
  background: #FAFAFA;
}

body{
  font-family:Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  margin:0;
  color:var(--dark);
  font-size: 14px;
  line-height:1.45;
  background:#FAFAFA;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

h4.alamat{
  margin:0 0 5px;
  font-size:16px;
  color:#FDCB2C; 
  text-align: left;
}

h1 {
  margin:0;
  font-size:28px;
  color: #FDCB2C;
  line-height:1.2;
  font-weight:700
}

h2.kegiatan{
  text-align: left;
  margin: 0 20px;
  font-weight: 700; /* Membuat teks lebih tebal */
  font-size: 23px;
}

/* Memberi warna pada kata pertama */
h2.kegiatan .first-word {
  color: #fd0000; /* Warna merah, sama seperti garis bawah */
}

/* Memberi warna pada kata kedua */
h2.kegiatan .second-word {
  color: #083D62; /* Warna biru, sama seperti header */
}

hr.kegiatan {
  margin: 0 20px;
  background-color: #fd0000;
  height: 3px;
}

h2,h3,h4,h5,h6{
  margin:0;
  color:#083D62;
  line-height:1.2;
  font-weight:600;
  font-size: large;
}

ol {
  color: #083D62;
  font-weight: 700;
  font-size: 18px;
  padding: 0;
  margin: 0;
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}

.site-header{
  background:linear-gradient(90deg,var(--maroon),#6c1213);color:#fff;
  border-bottom: 10px solid var(--maroon);
  position: relative; /* Diperlukan untuk z-index */
  z-index: 100; /* Pastikan header di atas konten lain */
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:inherit;
  text-decoration:none
}

.brand img{
  width:64px;
  height:64px;
  object-fit:contain
}

.brand-text h1{
  font-size:18px;
  margin:0;
  font-weight:700
}

.brand-text p{
  margin:0;
  font-size:12px;
  opacity:0.95;
  font-style: italic;
}

.main-nav ul{

  list-style: none;
  margin:0;
  padding:0;
  display:flex;
  gap:10px;
  align-items:center
}

.main-nav a{
    color: #fff;
    text-decoration: none;
    padding: 8px 6px;
    font-weight: 600;
    display: inline-flex;
    align-items: center; /* Vertically center the image */
}
.main-nav a.cta{
  background:#17bb55;
  color:#fff;
  padding:8px 14px;
  border-radius:20px
}

.main-nav a img {
    width: 20px; /* Adjust the size as needed */
    margin-right: 5px; /* Add some spacing between the icon and text */
}

.nav-toggle{display:none;background:none;border:0;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;margin:4px 0;border-radius:2px;transition:transform .25s}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.hero{
  padding:46px 0;
  background: #f8da7a;
  /* background:linear-gradient(180deg, rgba(122,20,22,0.06), rgba(122,20,22,0.00)); */
}

.hero-inner{display:grid;grid-template-columns:1fr 480px;gap:28px;align-items:center}
.hero-text h2{font-size:30px;margin:0 0 12px;}
.hero-text p{color:var(--muted);margin:0 0 18px}
.btn{display:inline-block;border:2px solid var(--maroon);padding:10px 18px;border-radius:8px;background:var(--maroon);color:#fff;text-decoration:none;font-weight:600}
.btn.ghost{background:transparent;border:2px solid var(--maroon);color:var(--maroon)}
.hero-image img{width:100%;height:auto;border-radius:12px;box-shadow:0 8px 30px rgba(17,17,17,0.06)}

.quicklinks {
  margin-bottom: -10px;
  padding: 0 20px;
}

.quicklinks ul{
  display:flex;
  gap:10px;
  padding:12px 0;
  list-style:none;
  margin: 0;
  flex-wrap: wrap;
}

.quicklinks li {
  flex: 1;
}

.quicklinks a{
  display:block;
  padding:12px 16px;
  border-radius:8px;
  text-decoration:none;
  /* Menggunakan warna yang sama dengan tombol di header */
  background: var(--maroon);
  color: #fff;
  font-weight: 600;
  /* Menghilangkan border */
  border: none;
  text-align: center;
}

.quicklinks a:hover {
  background-color: #1A2C43;
}

.news{
  background: #FAFAFA;
}

.news.teratas {
  padding-top: 40px;
}

.news h3{margin:0 0 18px}

.card h3{
  text-align: center;
}

.news-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  background-color:#FAFAFA;
  padding: 20px; border-radius: var(--radius);
}

.card{
  background:#FAFAFA;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  position: relative; /* Diperlukan untuk pseudo-element */
}

/* Trik untuk border agar tidak tertutup oleh konten anak */
.card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit; /* Mengikuti border-radius induk */
  border: 1px solid #FAFAFA;
  pointer-events: none; /* Agar tidak mengganggu klik */
}
.card p {
  margin: 0; /* Menghapus margin default dari paragraf di dalam card */
}

/* Style untuk link yang membungkus card */
.card-link {
  text-decoration: none;
  margin: 0; /* Menghapus margin default dari paragraf di dalam card */
}

.card img{
  width:100%;
  height:auto;
  border: 0px solid #ffffff;
}

.kepsek {
  text-align: right; /* Meratakan gambar ke kiri di dalam kolomnya */
  align-self: start; /* Mencegah gambar meregang secara vertikal */
}

.kepsek img{
  width:70%;
  height:auto;
  border: 0px solid #ffffff;
}

img.page-banner {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  margin: 10px 0 20px;
  margin-bottom: 30px;
}

/* Layout khusus untuk halaman sambutan */
.sambutan-layout {
  grid-template-columns: 2fr 1fr; /* Kolom pertama 2/3, kolom kedua 1/3 */
  align-items: start; /* Menjaga agar item di atas */
}

/* Layout khusus untuk halaman sejarah */
.sejarah-layout {
  grid-template-columns: 1fr; /* Membuat layout menjadi satu kolom penuh */
}

.card-body{
  padding: 14px 0px 20px;
  background-color: #F2F3B6;
}

.card-body time{
  display:block;
  color:#083D62;
  font-size:13px;
  margin:-10px 0px 0px 10px;
  font-style: italic;
}

.card-body h4{
  margin:6px 10px;
}

.card-body p{
  margin:-5px 0px 0px 10px;
  color:#083D62;
}

.card.small{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.card.small img{
  height:280px;
  width:100%;
  object-fit:cover
}

.about{padding:28px 0}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.program-list{margin:0;padding-left:18px}

.site-footer{
  /* background:#083D62; */
  background:linear-gradient(90deg,var(--maroon),#6c1213);color:#fff;
  color:#fff;
  padding-top: 28px;
}

.footer-inner{
  display:flex;
  gap:28px;
  flex-wrap:wrap
}

.footer-col{
  flex:1;
  min-width:200px
}

.footer-links{
  margin:0;
  padding:0;
}

.footer-links a{
  color:#fff;
  text-decoration: none;
  font-size: 13px;
}

.site-credit{
  text-align:center;
  padding:12px 0;
  color:#ddd;
  font-size:13px;
  background: #083D62;
  margin-top: 30px;
}
.site-footer {
  margin-top: auto; /* Mendorong footer ke bawah */
}


.site-credit a {
  color:#fff; 
  text-decoration: none; 
  font-weight: 300;}

p.alamat {
  font-size:13px;
  margin: 0;
}

/* Social Links di Footer */
.social-links {
  display: flex;
  gap: 16px; /* Jarak antar ikon */
}

.social-links a {
  color: #fff;
  transition: opacity 0.2s;
  margin-top: 5px;
}
.social-links a:hover { opacity: 0.8; }

/* Overlay untuk menu mobile */
#nav-overlay{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,0,0,0.4);
  visibility:hidden;
  opacity:0;
  z-index: 98; /* Di bawah menu, tapi di atas konten */
  transition: opacity .28s, visibility .28s;
}

/* Responsive */
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  /* Kurangi jarak atas bagian hero di mobile */
  .hero {
    padding-top: 28px;
  }
  .news-grid{
    grid-template-columns:1fr;
  }
  
  .main-nav{position:fixed;top:0;right:0;height:100vh;width:260px;background:linear-gradient(180deg,var(--maroon),#6c1213);transform:translateX(110%);transition:transform .28s;padding-top:80px; z-index: 99;}
  .main-nav.open{transform:translateX(0)}
  .main-nav ul{flex-direction:column;gap:30px;padding:0 18px}

  .nav-toggle{display:block}

  .header-inner{gap:12px}
  .header-inner{padding: 14px 20px;}

  /* Rata tengah judul hero di mobile */
  .hero-text h2 {
    text-align: center;
  }

  .hero-text p {
    text-align: center;
  }

  .hero-actions{
    text-align: center;
  }

  /* Pusatkan konten kolom footer di mobile */
  .footer-col {
    text-align: center;
    align-items: center; /* Untuk flexbox alignment */
    /* Rata kiri untuk semua kolom footer di mobile */
    text-align: left;
    align-items: flex-start;
  }

  /* Khusus kolom terakhir (social), buat rata tengah */
  .footer-col:last-child {
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  /* Sesuaikan margin-top ikon sosial di mobile */
  .social-links a {
    margin-top: 0;
  }

  /* Beri jarak atas untuk tombol CTA di menu mobile */
  .main-nav .cta-item {
    margin-top: 10px; /* Jarak dari item menu di atasnya */
    padding-bottom: 50px; /* Jarak 50px untuk garis di bawah */
    border-bottom: 1px solid rgba(255, 255, 255, 0.2); /* Garis pemisah tipis */
  }

  /* Mengatur ulang urutan untuk layout sambutan di mobile */
  .sambutan-layout {
    display: flex;
    flex-direction: column;
  }
  .sambutan-layout .kepsek {
    order: 1; /* Pindahkan gambar ke atas */
    text-align: right; /* Pastikan gambar kembali ke tengah di mobile */
  }
  .sambutan-layout .kepsek img {
    width: 60%; /* Perkecil gambar di mobile agar lebih terlihat di tengah */
  }
  .sambutan-layout .card {
    order: 2; /* Pindahkan teks ke bawah */
  }
}
/* Tombol tutup untuk menu mobile */
.nav-close {
  display: none; /* Sembunyikan di desktop */
  margin-top: 30px; /* Jarak 50px dari .cta-item */
  margin-left: auto;
  margin-right: auto;
  background: rgba(0,0,0,0.2);
  border: none;
  color: #fff;
  font-size: 35px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  cursor: pointer;
}

/* Guru Grid Styles */
.guru-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 24px;
  padding: 20px 0;
}

.guru-card {
  background: #fff;
  border: 1px solid #FAFAFA;
  border-radius: var(--radius);
  text-align: center;
  padding: 20px 15px;
  transition: transform 0.2s, box-shadow 0.2s;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.guru-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}

.guru-card .avatar {
  width: 200px;
  height: 300px;
  border-radius: 3%;
  object-fit: cover;
  margin-bottom: 15px;
  border: 3px solid #f0f0f0;
}

.guru-card .name { font-weight: 700; color: var(--maroon); font-size: 16px; margin-bottom: 4px; text-align: center; }
.guru-card .title { font-weight: 600; color: var(--dark); margin-bottom: 8px; text-align: center; }
.guru-card .subject { font-size: 13px; color: var(--muted); text-align: center; }
@media (max-width:900px){
  .card img{

/* Style untuk gambar banner di halaman internal */
.page-banner {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  margin: 10px 0 20px;
}

img.page-banner {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  width:100%;
  height:auto;
  object-fit:cover;

    }
  }

@media (max-width:480px){
  .brand img{width:52px;height:52px}
  .brand-text h1{font-size:16px}
  .hero-text h2{
    font-size:24px;
    text-align: center;
  }
}
}

@media (max-width:900px){
  .main-nav.open .nav-close {
    display: block; /* Tampilkan hanya saat menu mobile terbuka */
  }
}

/* Table Styles */
table {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0;
  font-size: 14px;
  text-align: center;
  color: var(--dark);
}

table th, table td {
  padding: 12px 15px;
  border: 1px solid #1A2C43;
}

table th {
  background-color: var(--maroon);
  color: #fff;
  font-weight: 600;
}

table tbody tr:nth-of-type(even) {
  background-color: #AAD4FF;
}

table tfoot {
  font-weight: bold;
  background-color: #f2f2f2;
}

/* Class helper untuk tabel dengan kolom rata kiri */
.table-left-align td:nth-child(n+2) {
  text-align: left;
}

/* Responsive Iframe */
.responsive-iframe {
  width: 100%;
  height: 75vh; /* 75% dari tinggi viewport */
  border: none;
  border-radius: var(--radius);
}